Received: by 2002:a25:4158:0:0:0:0:0 with SMTP id o85csp4550832yba; Sun, 19 May 2019 22:41:01 -0700 (PDT) X-Google-Smtp-Source: APXvYqysskg9dA6aD1Xc4OnPZAwDHhJRtXHqU7LLNa3WVyPCC83Q1rO1bm76ALQ2++WyoHauYXbN X-Received: by 2002:a17:902:bd8a:: with SMTP id q10mr26009702pls.155.1558330861895; Sun, 19 May 2019 22:41:01 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1558330861; cv=none; d=google.com; s=arc-20160816; b=NGM3xygosap8qzxiLrUN3+GKxBwFapElpKwRtx8jQyY7gRvizvsVpRkysVR8S0wYw7 qRPK3i5qkDTJxf6fMcm34NRkSuvdVVQHfFB360KjKRK9oaCvw/3DARhCnw/lksPzocDo QB67JQhNh3LpjILLzjXg6vBH/XV551BdJPxzQTIMgJOXMNKGH8AmseQk2H3sPK1TQa0m EjyZ8VKbe8pHS3kSzHJwznmzZqIsi1S4xc5LDx2HJDRhcOKTZG99olGrUvUQSe4ZZvDK JWNwgbld86GhKCuKeQRX5DgvwKK9nByn1kcJD5FvMqVOGR2wwrl9p70mfLUFu4FFl/wh MQng== 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:mime-version :message-id:date:subject:cc:to:from:dkim-signature; bh=xkToWfPhUbXUlBSKuzZG3pFF8m3+cgJ3j1xebIaK/EI=; b=UWxoyyzm34oBYHHs1xGY3RoQL49y2wl4d43QEBwsniXr+LmovN3lbVpdLfx0GKj//M NkcVD1g80gEwB8DToSyjP074ukvscV932rgCav/2G0ER5DNAbR23b1VkbpMOnyFnBqFt n6hY6xYUas+wlUzw5O2DvbSYDG2ERCo8VuBwvsXJEsC4KbiDgWPIG0EQGupZKtmrmM9N A/Ch97YaxmZXrQAOWhRFmgctYPu7KAz1Ne9XU6jYZ9aOgA/zHifdFpP7t5MGll2yZRwi 3wrfB/YhT29qut7sXZ1E0PTEThHaLOLkx126walGfNys+qtz8Gzs4j2n0eKv0LsRssk4 xO7A== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@chromium.org header.s=google header.b=mI5vScJ4; 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 k29si19231556pfp.45.2019.05.19.22.40.47; Sun, 19 May 2019 22:41:01 -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=mI5vScJ4; 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 S1730328AbfETEt7 (ORCPT + 99 others); Mon, 20 May 2019 00:49:59 -0400 Received: from mail-pf1-f194.google.com ([209.85.210.194]:37891 "EHLO mail-pf1-f194.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1725372AbfETEt7 (ORCPT ); Mon, 20 May 2019 00:49:59 -0400 Received: by mail-pf1-f194.google.com with SMTP id b76so6575747pfb.5 for ; Sun, 19 May 2019 21:49:58 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=chromium.org; s=google; h=from:to:cc:subject:date:message-id:mime-version :content-transfer-encoding; bh=xkToWfPhUbXUlBSKuzZG3pFF8m3+cgJ3j1xebIaK/EI=; b=mI5vScJ46CfONQKk0BXuJqgqaOpncnnzaBz3sQRykYdFNJRSapviixTBiuyNXhv3Lj IKXhEYu8bwmxqqhsj4jf31vawxOk5hgaSWCzkrl3jSNirETmZA+np4paeXOlSZGefx++ v/lIzQqsOCjlows+Onq9agp+5xzN+dFq06s1M= X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:from:to:cc:subject:date:message-id:mime-version :content-transfer-encoding; bh=xkToWfPhUbXUlBSKuzZG3pFF8m3+cgJ3j1xebIaK/EI=; b=MH4xeuI4O/WqxVWN3ID0d++4JtFVS7qbYO3f/WYIWu2FnxR1ngoQ2/6ylo9+YSNojR /8qWtgRVIE2171EzP0OSbNbubSpspiEjl4cTIq6FvUC/DaCZOZDCG9s1BGGUFmj/KQSu BHIDsOEB21aIIfoQ1LuWV8d7wBuCxt9XD/cZdAUXhiajRT0EANFAikTBTIFDlIImTrO8 U8QIomLMYj+KVeKMv9LW89OtgsbTf/YPNpEWWH8fK+LQ6aO0cUcM5qmHRkWCU9CrG6iJ KvBeYTxyoc/O2FZWn4RK9MA6iupmZcWkEM9az4EoOlsSm4C7YPohrCvjEC6uDAcCx2Ye Pswg== X-Gm-Message-State: APjAAAVKw8Yzjht5majKxw+uawlQa0g9Qfr+SWmI643b/b7YNSn3UpeW wh7/snoHHQ092VguOOJq96m05A== X-Received: by 2002:a62:ee05:: with SMTP id e5mr76083541pfi.117.1558327798179; Sun, 19 May 2019 21:49:58 -0700 (PDT) Received: from drinkcat2.tpe.corp.google.com ([2401:fa00:1:b:d8b7:33af:adcb:b648]) by smtp.gmail.com with ESMTPSA id 140sm26022608pfw.123.2019.05.19.21.49.55 (version=TLS1_2 cipher=ECDHE-RSA-AES128-GCM-SHA256 bits=128/128); Sun, 19 May 2019 21:49:57 -0700 (PDT) From: Nicolas Boichat To: Andrew Morton Cc: David Rientjes , Nicolas Boichat , Michal Hocko , Joe Perches , Greg Kroah-Hartman , linux-mm@kvack.org, Akinobu Mita , Pekka Enberg , Mel Gorman , linux-kernel@vger.kernel.org Subject: [PATCH] mm/failslab: By default, do not fail allocations with direct reclaim only Date: Mon, 20 May 2019 12:49:51 +0800 Message-Id: <20190520044951.248096-1-drinkcat@chromium.org> X-Mailer: git-send-email 2.21.0.1020.gf2820cf01a-goog MIME-Version: 1.0 Content-Transfer-Encoding: 8bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org 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_RECLAIM") Signed-off-by: Nicolas Boichat --- 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 gfpflags) 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; if (failslab.cache_filter && !(s->flags & SLAB_FAILSLAB)) -- 2.21.0.1020.gf2820cf01a-goog