Received: by 2002:a05:6358:16cc:b0:ea:6187:17c9 with SMTP id r12csp10784184rwl; Thu, 12 Jan 2023 02:29:07 -0800 (PST) X-Google-Smtp-Source: AMrXdXuRp6jmdUPwMd2iDDCjh604e32nTwpCosl3l4cgAlWUYbOr0R6jcRRBaqdeOdPLk3ejwo5e X-Received: by 2002:a05:6402:294d:b0:48e:c0c3:7974 with SMTP id ed13-20020a056402294d00b0048ec0c37974mr30676532edb.12.1673519347778; Thu, 12 Jan 2023 02:29:07 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1673519347; cv=none; d=google.com; s=arc-20160816; b=t9/6OGkkZiLnOIzPV8QCrSrUCRgIZ5eze19UdCBTt1MHGO63cfdEF5IkY5P6v35a4q EwBmro/apBrTM1l2GEX5e3Xqf7Ykdsic+wFCAMBmLC2o1zwLrXmKmgUtGbSUrc8CPkWA ANo7+HAkBQ15K9gF4e0F9XBEuWTAk187Re/75/kUQP2z3rR4J1YHvHN+XyDcwA3qmekE 8IT7SBamw7BzD0Ahl88yK4mLmMdKr9VBtM/RUVIL7IadTOPterIPetGQgmeC9Sl7IOsJ ajz2bvCDJldZqXzljCvQ4jvqd3q6FhOCu/0eowwCd9A5O0QKr1N5X/Le6CmKQ59ZYfAa Ahhw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:in-reply-to:content-disposition:mime-version :references:message-id:subject:cc:to:from:date; bh=Bnyt9tw/sjK9UlySSsFxyzgArKoqLGR9+fKawzbyTwc=; b=XzbwXaC5RkkjIE31JTgCs41WcyeXz8FZDctzVgnJhqK0nSDv41ECh8MlvHw92ou8mH h30muVtLJaFTKU6HdBChBBU3rz+6c5YGnVeRbe9t7RAkz8yrVWl7LCL+13M45RWEoL1N S+3/gg59KSzPKQLprq49di0QnlxaJO1wyntayi2mvvkbpEfKRHwRgl4uygs+DR14f5o0 noHx8BXXgrFad0m1FmkuXXo7LhbSuNPlh87ujaZc9YP6BBAMnrfsFM/RvYTKnSZF7noL CeHG54DzG1Yr1RgxiKm1q6tDhF8nyjkmxW4ClZj0Tslwxd/JaGRE2lPxcweqiWB9QPhE 9j0w== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id wy7-20020a170906fe0700b0078df1c345dcsi18705404ejb.535.2023.01.12.02.28.56; Thu, 12 Jan 2023 02:29:07 -0800 (PST) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) client-ip=2620:137:e000::1:20; Authentication-Results: mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S229549AbjALJaa (ORCPT + 50 others); Thu, 12 Jan 2023 04:30:30 -0500 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:41124 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S239833AbjALJ3o (ORCPT ); Thu, 12 Jan 2023 04:29:44 -0500 Received: from outbound-smtp37.blacknight.com (outbound-smtp37.blacknight.com [46.22.139.220]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 8B0B050E75 for ; Thu, 12 Jan 2023 01:24:56 -0800 (PST) Received: from mail.blacknight.com (pemlinmail05.blacknight.ie [81.17.254.26]) by outbound-smtp37.blacknight.com (Postfix) with ESMTPS id 1277A1FDB for ; Thu, 12 Jan 2023 09:24:55 +0000 (GMT) Received: (qmail 22350 invoked from network); 12 Jan 2023 09:24:54 -0000 Received: from unknown (HELO techsingularity.net) (mgorman@techsingularity.net@[84.203.198.246]) by 81.17.254.9 with ESMTPSA (AES256-SHA encrypted, authenticated); 12 Jan 2023 09:24:54 -0000 Date: Thu, 12 Jan 2023 09:24:52 +0000 From: Mel Gorman To: Michal Hocko Cc: Linux-MM , Andrew Morton , NeilBrown , Thierry Reding , Matthew Wilcox , Vlastimil Babka , LKML Subject: Re: [PATCH 6/7] mm/page_alloc: Give GFP_ATOMIC and non-blocking allocations access to reserves Message-ID: <20230112092452.rtvo6tkp4rpmxm7v@techsingularity.net> References: <20230109151631.24923-1-mgorman@techsingularity.net> <20230109151631.24923-7-mgorman@techsingularity.net> <20230111170552.5b7z5hetc2lcdwmb@techsingularity.net> MIME-Version: 1.0 Content-Type: text/plain; charset=iso-8859-15 Content-Disposition: inline In-Reply-To: X-Spam-Status: No, score=-2.6 required=5.0 tests=BAYES_00,RCVD_IN_DNSWL_LOW, SPF_HELO_NONE,SPF_PASS autolearn=ham autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on lindbergh.monkeyblade.net Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Thu, Jan 12, 2023 at 09:11:06AM +0100, Michal Hocko wrote: > On Wed 11-01-23 17:05:52, Mel Gorman wrote: > > On Wed, Jan 11, 2023 at 04:58:02PM +0100, Michal Hocko wrote: > > > On Mon 09-01-23 15:16:30, Mel Gorman wrote: > > > > Explicit GFP_ATOMIC allocations get flagged ALLOC_HARDER which is a bit > > > > vague. In preparation for removing __GFP_ATOMIC, give GFP_ATOMIC and > > > > other non-blocking allocation requests equal access to reserve. Rename > > > > ALLOC_HARDER to ALLOC_NON_BLOCK to make it more clear what the flag > > > > means. > > > > > > GFP_NOWAIT can be also used for opportunistic allocations which can and > > > should fail quickly if the memory is tight and more elaborate path > > > should be taken (e.g. try higher order allocation first but fall back to > > > smaller request if the memory is fragmented). Do we really want to give > > > those access to memory reserves as well? > > > > Good question. Without __GFP_ATOMIC, GFP_NOWAIT only differs from GFP_ATOMIC > > by __GFP_HIGH but that is not enough to distinguish between a caller that > > cannot sleep versus one that is speculatively attempting an allocation but > > has other options. That changelog is misleading, it's not equal access > > as GFP_NOWAIT ends up with 25% of the reserves which is less than what > > GFP_ATOMIC gets. > > > > Because it becomes impossible to distinguish between non-blocking and > > atomic without __GFP_ATOMIC, there is some justification for allowing > > access to reserves for GFP_NOWAIT. bio for example attempts an allocation > > (clears __GFP_DIRECT_RECLAIM) before falling back to mempool but delays > > in IO can also lead to further allocation pressure. mmu gather failing > > GFP_WAIT slows the rate memory can be freed. NFS failing GFP_NOWAIT will > > have to retry IOs multiple times. The examples were picked at random but > > the point is that there are cases where failing GFP_NOWAIT can degrade > > the system, particularly delay the cleaning of pages before reclaim. > > Fair points. > > > A lot of the truly speculative users appear to use GFP_NOWAIT | __GFP_NOWARN > > so one compromise would be to avoid using reserves if __GFP_NOWARN is > > also specified. > > > > Something like this as a separate patch? > > I cannot say I would be happy about adding more side effects to > __GFP_NOWARN. You are right that it should be used for those optimistic > allocation requests but historically all many of these subtle side effects > have kicked back at some point. True. > Wouldn't it make sense to explicitly > mark those places which really benefit from reserves instead? That would be __GFP_HIGH and would require context from every caller on whether they need reserves or not and to determine what the consequences are if there is a stall. Is there immediate local fallout or wider fallout such as a variable delay before pages can be cleaned? > This is > more work but it should pay off long term. Your examples above would use > GFP_ATOMIC instead of GFP_NOWAIT. > Yes, although it would confuse the meaning of GFP_ATOMIC as a result. It's described as "%GFP_ATOMIC users can not sleep and need the allocation to succeed" and something like the bio callsite does not *need* the allocation to succeed. It can fallback to the mempool and performance simply degrades temporarily. No doubt there are a few abuses of GFP_ATOMIC just to get non-blocking behaviour already. > The semantic would be easier to explain as well. GFP_ATOMIC - non > sleeping allocations which are important so they have access to memory > reserves. GFP_NOWAIT - non sleeping allocations. > People's definition of "important" will vary wildly. The following would avoid reserve access for GFP_NOWAIT for now. It would need to be folded into this patch and a new changelog diff --git a/mm/page_alloc.c b/mm/page_alloc.c index 7244ab522028..aa20165224cf 100644 --- a/mm/page_alloc.c +++ b/mm/page_alloc.c @@ -3989,18 +3989,19 @@ bool __zone_watermark_ok(struct zone *z, unsigned int order, unsigned long mark, * __GFP_HIGH allows access to 50% of the min reserve as well * as OOM. */ - if (alloc_flags & ALLOC_MIN_RESERVE) + if (alloc_flags & ALLOC_MIN_RESERVE) { min -= min / 2; - /* - * Non-blocking allocations can access some of the reserve - * with more access if also __GFP_HIGH. The reasoning is that - * a non-blocking caller may incur a more severe penalty - * if it cannot get memory quickly, particularly if it's - * also __GFP_HIGH. - */ - if (alloc_flags & ALLOC_NON_BLOCK) - min -= min / 4; + /* + * Non-blocking allocations (e.g. GFP_ATOMIC) can + * access more reserves than just __GFP_HIGH. Other + * non-blocking allocations requests such as GFP_NOWAIT + * or (GFP_KERNEL & ~__GFP_DIRECT_RECLAIM) do not get + * access to the min reserve. + */ + if (alloc_flags & ALLOC_NON_BLOCK) + min -= min / 4; + } /* * OOM victims can try even harder than the normal reserve -- Mel Gorman SUSE Labs