[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-Id: <20240221141504.3c3cec674553b4df4bd72ec1@linux-foundation.org>
Date: Wed, 21 Feb 2024 14:15:04 -0800
From: Andrew Morton <akpm@...ux-foundation.org>
To: Baolin Wang <baolin.wang@...ux.alibaba.com>
Cc: Zi Yan <ziy@...dia.com>, Vlastimil Babka <vbabka@...e.cz>,
mgorman@...hsingularity.net, linux-mm@...ck.org,
linux-kernel@...r.kernel.org
Subject: Re: [PATCH 1/2] mm: compaction: limit the suitable target page
order to be less than cc->order
On Mon, 19 Feb 2024 10:55:59 +0800 Baolin Wang <baolin.wang@...ux.alibaba.com> wrote:
>
>
> On 2024/2/12 23:00, Zi Yan wrote:
> > On 12 Feb 2024, at 4:13, Vlastimil Babka wrote:
> >
> >> On 1/22/24 14:01, Baolin Wang wrote:
> >>> It can not improve the fragmentation if we isolate the target free pages
> >>> exceeding cc->order, especially when the cc->order is less than pageblock_order.
> >>> For example, suppose the pageblock_order is MAX_ORDER (size is 4M) and cc->order
> >>> is 2M THP size, we should not isolate other 2M free pages to be the migration
> >>> target, which can not improve the fragmentation.
> >>>
> >>> Moreover this is also applicable for large folio compaction.
> >>
> >> So why not Cc: Zi Yan? (done)
> >>
> >
> > Thanks.
> >
> > Hi Baolin,
> >
> > How often do you see this happening?
>
> This is theoretically analyzed from the code inspection.
>
> >>> Signed-off-by: Baolin Wang <baolin.wang@...ux.alibaba.com>
> >>
> >> I doubt this will make much difference, because if such a larger order free
> >> page exists, we shouldn't have a reason to be compacting for a lower order
> >> in the first place?
> >
> > Unless kswapd gets us such a free block in the background right after
> > get_page_from_freelist() and before compaction finishes in the allocation
> > slow path.
> >
> > If this happens often and cc->order is not -1, it might be better to stop
> > compaction and get_page_from_freelist() to save cycles on unnecessary pfn
> > scanning. For completeness, when cc->order == -1, the logic does not change.
>
> Yes, this is one possible case. There are also some other concurrent
> scenarios, such as when compaction is running (after
> compaction_suitable()), at the same time, other applications release a
> large folio to the free list. In this case, the free large folio
> scanning should also be avoided.
This went quiet.
We have an ack from Mel. Are people OK with sending this change
upstream?
Powered by blists - more mailing lists