Message ID | 20240618114941.5935-1-zhangpengpeng0808@gmail.com (mailing list archive) |
---|---|
State | New |
Headers | show |
Series | [RFC] mm/readahead: Fix repeat initial_readahead | expand |
To illustrate this problem, I created the following example: Assuming that the process reads sequentially from the beginning of the file and calls the `page_cache_sync_readahead` function. In this sync readahead function, since the index is 0, it will proceed to `initial_readahead` and initialize `ra_state`. It allocates a folio with an order of 2 and marks it as PG_readahead. Next, because` (folio_test_readahead(folio))` is true, the page_cache_async_ra function is called, which causes the `ra_state` to be initialized again.
On Tue 25-06-24 14:28:34, zippermonkey wrote: > To illustrate this problem, I created the following example: > > Assuming that the process reads sequentially from the beginning of the file > and > calls the `page_cache_sync_readahead` function. In this sync readahead > function, > since the index is 0, it will proceed to `initial_readahead` and initialize > `ra_state`. It allocates a folio with an order of 2 and marks it as > PG_readahead. > Next, because` (folio_test_readahead(folio))` is true, the > page_cache_async_ra > function is called, which causes the `ra_state` to be initialized again. Good spotting guys! There are actually more problems in the readahead code. I have just pushed out a patch series [1] addressing several issues that should also address the problem you've found. Can you please test whether it provides a similar speedup as your fix (sorry, I forgot to CC you on the series)? Thanks! [1] https://lore.kernel.org/20240625100859.15507-1-jack@suse.cz Honza
diff --git a/mm/readahead.c b/mm/readahead.c index c1b23989d..498708b4b 100644 --- a/mm/readahead.c +++ b/mm/readahead.c @@ -571,7 +571,7 @@ static void ondemand_readahead(struct readahead_control *ractl, /* * start of file */ - if (!index) + if (!folio && !index) goto initial_readahead; /*