public inbox for linux-ext4@vger.kernel.org
 help / color / mirror / Atom feed
* ext4 stable page writes question
@ 2013-04-09 13:38 Dmitry Monakhov
  2013-04-09 14:28 ` Jan Kara
  0 siblings, 1 reply; 3+ messages in thread
From: Dmitry Monakhov @ 2013-04-09 13:38 UTC (permalink / raw)
  To: ext4 development, Jan Kara, Theodore Ts'o


According to stable write assumptions (1d1d1a767206fb)
grab_cache_page_write_begin() now calls relaxed method wait_for_stable_page()
which will wait for writeback to finish only if bdi demand that.
Commit message states that ext4 may not wait
But there are a lot of write-paths where we expect that:
BUG_ON(!PageLocked(page));
BUG_ON(PageWriteback(page));
And the only reason we avoid this bugon is because of commit 47564bfb95b
which use following trick to avoid lock inversion over journal_start:
page = grab_cache_page_write_begin()
unlock_page(page);
ext4_journal_start()
lock_page(page);
wait_on_page_writeback(page); <<<< unconditional wait

So as far as I understand this was done just by occasion because
ext4_page_mkwrite() use wait_for_stable_page().

So here is my question:  Do we have to wait for page's writeback to
finish for all write paths in ext4 code or we may use
wait_for_stable_page() and should cleanup all places where 
we may trigger BUG_ON(PageWriteback(page));
 

^ permalink raw reply	[flat|nested] 3+ messages in thread

end of thread, other threads:[~2013-04-09 15:01 UTC | newest]

Thread overview: 3+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2013-04-09 13:38 ext4 stable page writes question Dmitry Monakhov
2013-04-09 14:28 ` Jan Kara
2013-04-09 15:01   ` Dmitry Monakhov

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox