Re: [PATCH] mm: migrate.c: migrate PG_readahead flag

From: Andrew Morton
Date: Thu Feb 13 2020 - 21:55:17 EST


On Fri, 14 Feb 2020 08:29:45 +0800 Yang Shi <yang.shi@xxxxxxxxxxxxxxxxx> wrote:

> Currently migration code doesn't migrate PG_readahead flag.
> Theoretically this would incur slight performance loss as the
> application might have to ramp its readahead back up again. Even though
> such problem happens, it might be hidden by something else since
> migration is typically triggered by compaction and NUMA balancing, any
> of which should be more noticeable.
>
> Migrate the flag after end_page_writeback() since it may clear
> PG_reclaim flag, which is the same bit as PG_readahead, for the new
> page.
>
> --- a/mm/migrate.c
> +++ b/mm/migrate.c
> @@ -647,6 +647,14 @@ void migrate_page_states(struct page *newpage, struct page *page)
> if (PageWriteback(newpage))
> end_page_writeback(newpage);
>
> + /*
> + * PG_readahead share the same bit with PG_reclaim, the above
> + * end_page_writeback() may clear PG_readahead mistakenly, so set
> + * the bit after that.
> + */
> + if (PageReadahead(page))
> + SetPageReadahead(newpage);
> +
> copy_page_owner(page, newpage);
>

Why not

if (PageWriteback(newpage)) {
end_page_writeback(newpage);
/*
* PG_readahead share the same bit with PG_reclaim, the above
* end_page_writeback() may clear PG_readahead mistakenly, so
* set the bit after that.
*/
if (PageReadahead(page))
SetPageReadahead(newpage);
}

?