Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1752103AbcCBNcM (ORCPT ); Wed, 2 Mar 2016 08:32:12 -0500 Received: from mail-oi0-f43.google.com ([209.85.218.43]:36203 "EHLO mail-oi0-f43.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1751130AbcCBNcK (ORCPT ); Wed, 2 Mar 2016 08:32:10 -0500 MIME-Version: 1.0 In-Reply-To: <20160302095056.GB26701@dhcp22.suse.cz> References: <1450203586-10959-1-git-send-email-mhocko@kernel.org> <20160203132718.GI6757@dhcp22.suse.cz> <20160225092315.GD17573@dhcp22.suse.cz> <20160229210213.GX16930@dhcp22.suse.cz> <20160302021954.GA22355@js1304-P5Q-DELUXE> <20160302095056.GB26701@dhcp22.suse.cz> Date: Wed, 2 Mar 2016 22:32:09 +0900 Message-ID: Subject: Re: [PATCH 0/3] OOM detection rework v4 From: Joonsoo Kim To: Michal Hocko Cc: Joonsoo Kim , Andrew Morton , Hugh Dickins , Linus Torvalds , Johannes Weiner , Mel Gorman , David Rientjes , Tetsuo Handa , Hillf Danton , KAMEZAWA Hiroyuki , Linux Memory Management List , LKML , Sergey Senozhatsky Content-Type: text/plain; charset=UTF-8 Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Content-Length: 4786 Lines: 121 2016-03-02 18:50 GMT+09:00 Michal Hocko : > On Wed 02-03-16 11:19:54, Joonsoo Kim wrote: >> On Mon, Feb 29, 2016 at 10:02:13PM +0100, Michal Hocko wrote: > [...] >> > > + /* >> > > + * OK, so the watermak check has failed. Make sure we do all the >> > > + * retries for !costly high order requests and hope that multiple >> > > + * runs of compaction will generate some high order ones for us. >> > > + * >> > > + * XXX: ideally we should teach the compaction to try _really_ hard >> > > + * if we are in the retry path - something like priority 0 for the >> > > + * reclaim >> > > + */ >> > > + if (order && order <= PAGE_ALLOC_COSTLY_ORDER) >> > > + return true; >> > > + >> > > return false; >> >> This seems not a proper fix. Checking watermark with high order has >> another meaning that there is high order page or not. This isn't >> what we want here. > > Why not? Why should we retry the reclaim if we do not have >=order page > available? Reclaim itself doesn't guarantee any of the freed pages will > form the requested order. The ordering on the LRU lists is pretty much > random wrt. pfn ordering. On the other hand if we have a page available > which is just hidden by watermarks then it makes perfect sense to retry > and free even order-0 pages. If we have >= order page available, we would not reach here. We would just allocate it. And, should_reclaim_retry() is not just for reclaim. It is also for retrying compaction. That watermark check is to check further reclaim/compaction is meaningful. And, for high order case, if there is enough freepage, compaction could make high order page even if there is no high order page now. Adding freeable memory and checking watermark with it doesn't help in this case because number of high order page isn't changed with it. I just did quick review to your patches so maybe I am wrong. Am I missing something? >> So, following fix is needed. > >> 'if (order)' check isn't needed. It is used to clarify the meaning of >> this fix. You can remove it. >> >> diff --git a/mm/page_alloc.c b/mm/page_alloc.c >> index 1993894..8c80375 100644 >> --- a/mm/page_alloc.c >> +++ b/mm/page_alloc.c >> @@ -3125,6 +3125,10 @@ should_reclaim_retry(gfp_t gfp_mask, unsigned order, >> if (order > PAGE_ALLOC_COSTLY_ORDER && !(gfp_mask & __GFP_REPEAT)) >> return false; >> >> + /* To check whether compaction is available or not */ >> + if (order) >> + order = 0; >> + > > This would enforce the order 0 wmark check which is IMHO not correct as > per above. > >> /* >> * Keep reclaiming pages while there is a chance this will lead >> * somewhere. If none of the target zones can satisfy our allocation >> >> > > } >> > > >> > > @@ -3281,11 +3293,11 @@ __alloc_pages_slowpath(gfp_t gfp_mask, unsigned int order, >> > > goto noretry; >> > > >> > > /* >> > > - * Costly allocations might have made a progress but this doesn't mean >> > > - * their order will become available due to high fragmentation so do >> > > - * not reset the no progress counter for them >> > > + * High order allocations might have made a progress but this doesn't >> > > + * mean their order will become available due to high fragmentation so >> > > + * do not reset the no progress counter for them >> > > */ >> > > - if (did_some_progress && order <= PAGE_ALLOC_COSTLY_ORDER) >> > > + if (did_some_progress && !order) >> > > no_progress_loops = 0; >> > > else >> > > no_progress_loops++; >> >> This unconditionally increases no_progress_loops for high order >> allocation, so, after 16 iterations, it will fail. If compaction isn't >> enabled in Kconfig, 16 times reclaim attempt would not be sufficient >> to make high order page. Should we consider this case also? > > How many retries would help? I do not think any number will work > reliably. Configurations without compaction enabled are asking for > problems by definition IMHO. Relying on order-0 reclaim for high order > allocations simply cannot work. At least, reset no_progress_loops when did_some_progress. High order allocation up to PAGE_ALLOC_COSTLY_ORDER is as important as order 0. And, reclaim something would increase probability of compaction success. Why do we limit retry as 16 times with no evidence of potential impossibility of making high order page? And, 16 retry looks not good to me because compaction could defer actual doing up to 64 times. Thanks. > > -- > Michal Hocko > SUSE Labs > > -- > To unsubscribe, send a message with 'unsubscribe linux-mm' in > the body to majordomo@kvack.org. For more info on Linux MM, > see: http://www.linux-mm.org/ . > Don't email: email@kvack.org