Received: by 2002:a25:86ce:0:0:0:0:0 with SMTP id y14csp206742ybm; Mon, 20 May 2019 14:42:39 -0700 (PDT) X-Google-Smtp-Source: APXvYqwThW1i6jU4UUUVjpE7wcVpBYFAd2F0bUkeZdRsaxjACbD8S35hK9k8/lqhn02TRT5asO3N X-Received: by 2002:a63:d756:: with SMTP id w22mr78113918pgi.382.1558388559703; Mon, 20 May 2019 14:42:39 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1558388559; cv=none; d=google.com; s=arc-20160816; b=WssyEpNyKHTl+mtYzOxVRIcfJ9vlQlArbUcc/wCjhkKe78GPR72VR8+yyajFstSRP8 qYVdtIp0fGD5goce/EuQsh46jv94Nhe9nh4o418JZ8qnLB7b2ilE61p+nQoUpjD5lM4L XAcWySaoU8H+FhuJ1nXKSmgjz4S7+SnugEEMBF+dz0oPXXo1WHeKwN81+3LUu+uoKa9V NQ8yEvfrkd49caKV5gpHO8DEjeHC8VlaA+VSAcoQRCWSF+f96a8i5C1CPVyMPFm1Owc8 mDi5YaEjqK2NOkLUihqfgBmcPvnzVHVq0U4ak/kp+DtmQBZgLF7iZ75iTqUdbdlXAvfg NLaQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-transfer-encoding:cc:to:subject :message-id:date:from:in-reply-to:references:mime-version :dkim-signature; bh=IThQGlwZN4WtsbLkk3oukuwrzsnq23H8GMI8BgIL1f8=; b=fdkpHTC++9iM5gL5227BgcAsOvByfKhLrYf6OX9I5ICPD+YgKlsRz0qa91q2pjyX4D gkYJsQA9shAiAnpDU3aH+keEGItsnw81hBqZMOyVsoxlYErVg8ox/F8BReHHExt0yiOe k5l0RdudYg7UZbXQMSbEa5eR7dcExwCQ3KPrGdOVHvcw0zQqTVjXHGiGiuFxA3Npu43B jOALA3CgQrVOkCxxsKY2hSlCDVtnlL2715pB1VX9vrXu18RiQ/yjNSEIWn++z+HK2cQo vK8ISmM1EG1UEdaD2Xev5tDuOJWcMRQhhDTh0bDLvb7lrMJkJJlQD08iXUR9CnSEICzP RTqQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@chromium.org header.s=google header.b=hK2eyv+R; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=chromium.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id f64si19348988plf.128.2019.05.20.14.42.25; Mon, 20 May 2019 14:42:39 -0700 (PDT) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; dkim=pass header.i=@chromium.org header.s=google header.b=hK2eyv+R; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=chromium.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1726646AbfETVkt (ORCPT + 99 others); Mon, 20 May 2019 17:40:49 -0400 Received: from mail-qk1-f195.google.com ([209.85.222.195]:37839 "EHLO mail-qk1-f195.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1725810AbfETVks (ORCPT ); Mon, 20 May 2019 17:40:48 -0400 Received: by mail-qk1-f195.google.com with SMTP id d10so9813841qko.4 for ; Mon, 20 May 2019 14:40:48 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=chromium.org; s=google; h=mime-version:references:in-reply-to:from:date:message-id:subject:to :cc:content-transfer-encoding; bh=IThQGlwZN4WtsbLkk3oukuwrzsnq23H8GMI8BgIL1f8=; b=hK2eyv+RmjhJBhO9xW7nmAOoLOTUPMU93WRuMaB8KV1/Ipcsc6fF4RwDKaRanXgiiQ 1moFfP9ko3eAH7gEqqzVhMRmuadceiV7qXi2MurSlIpZ9Llv91z5GHWZ/1aX3y7jM18+ IGN5yM1LK6mMLNa40n1/AIP0iJDcB2m08JUvM= X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:mime-version:references:in-reply-to:from:date :message-id:subject:to:cc:content-transfer-encoding; bh=IThQGlwZN4WtsbLkk3oukuwrzsnq23H8GMI8BgIL1f8=; b=VVrrWS5qdcR9XWAmjkjHggiQE5zqC3/CuZY2zM+GI364cWIt6RexSBQFp5R4d6LX8+ tJc57QANuo1VO2YP1mxdq3VsI7flW9dCNPRMj/SaVhAqiUXIabxL9uSTFlm0++Vyjfir nE1+JXvpjuANKPJGS2JI5lsX4k2LVrlGm7iphe+zLy183gDzvUMbRtckQ7P7QgH4itRc I83pFJ7/KmqyLpjcZzJ9N6peiviVmEvdtlIySCFQO9syvbO5DeW7eahFpwTH0kqUdLCy uc5LI74598CmPlepjklP/pNQwYELK9X0nqxfnlK6WbzQMMGtXPyDLpTV+czkVDF/ooUz h8Og== X-Gm-Message-State: APjAAAVjAWIXTtuqVAfth0dqOlWQhctqiuATMhPe0JDvQ/PBhMZtRH1y AubrXeRhrxNjf6zdYIf9kGbkT9qQ4WALjW3d2VeDWw== X-Received: by 2002:a37:4c04:: with SMTP id z4mr43466352qka.195.1558388447854; Mon, 20 May 2019 14:40:47 -0700 (PDT) MIME-Version: 1.0 References: <20190520044951.248096-1-drinkcat@chromium.org> In-Reply-To: From: Nicolas Boichat Date: Tue, 21 May 2019 05:40:36 +0800 Message-ID: Subject: Re: [PATCH] mm/failslab: By default, do not fail allocations with direct reclaim only To: Akinobu Mita Cc: Andrew Morton , David Rientjes , Michal Hocko , Joe Perches , Greg Kroah-Hartman , linux-mm@kvack.org, Pekka Enberg , Mel Gorman , LKML Content-Type: text/plain; charset="UTF-8" Content-Transfer-Encoding: quoted-printable Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Tue, May 21, 2019 at 12:29 AM Akinobu Mita wrot= e: > > 2019=E5=B9=B45=E6=9C=8820=E6=97=A5(=E6=9C=88) 13:49 Nicolas Boichat : > > > > When failslab was originally written, the intention of the > > "ignore-gfp-wait" flag default value ("N") was to fail > > GFP_ATOMIC allocations. Those were defined as (__GFP_HIGH), > > and the code would test for __GFP_WAIT (0x10u). > > > > However, since then, __GFP_WAIT was replaced by __GFP_RECLAIM > > (___GFP_DIRECT_RECLAIM|___GFP_KSWAPD_RECLAIM), and GFP_ATOMIC is > > now defined as (__GFP_HIGH|__GFP_ATOMIC|__GFP_KSWAPD_RECLAIM). > > > > This means that when the flag is false, almost no allocation > > ever fails (as even GFP_ATOMIC allocations contain > > __GFP_KSWAPD_RECLAIM). > > > > Restore the original intent of the code, by ignoring calls > > that directly reclaim only (___GFP_DIRECT_RECLAIM), and thus, > > failing GFP_ATOMIC calls again by default. > > > > Fixes: 71baba4b92dc1fa1 ("mm, page_alloc: rename __GFP_WAIT to __GFP_RE= CLAIM") > > Signed-off-by: Nicolas Boichat > > Good catch. > > Reviewed-by: Akinobu Mita > > > --- > > mm/failslab.c | 3 ++- > > 1 file changed, 2 insertions(+), 1 deletion(-) > > > > diff --git a/mm/failslab.c b/mm/failslab.c > > index ec5aad211c5be97..33efcb60e633c0a 100644 > > --- a/mm/failslab.c > > +++ b/mm/failslab.c > > @@ -23,7 +23,8 @@ bool __should_failslab(struct kmem_cache *s, gfp_t gf= pflags) > > if (gfpflags & __GFP_NOFAIL) > > return false; > > > > - if (failslab.ignore_gfp_reclaim && (gfpflags & __GFP_RECLAIM)) > > + if (failslab.ignore_gfp_reclaim && > > + (gfpflags & ___GFP_DIRECT_RECLAIM)) > > return false; > > Should we use __GFP_DIRECT_RECLAIM instead of ___GFP_DIRECT_RECLAIM? > Because I found the following comment in gfp.h > > /* Plain integer GFP bitmasks. Do not use this directly. */ Oh, nice catch. I must say I had no idea I was using the 3-underscore version, hard to tell them apart depending on the font. I'll send a v2 with both your tags right away. Thanks,