Received: by 2002:a05:6902:102b:0:0:0:0 with SMTP id x11csp907530ybt; Wed, 1 Jul 2020 13:05:49 -0700 (PDT) X-Google-Smtp-Source: ABdhPJyMxAtqh8Cte++83JMRq5oFwfI9dY7x2fXmgINbOzrqvsD2tBr5ZWlVA6qngJV3d+1iUcvL X-Received: by 2002:a17:906:4356:: with SMTP id z22mr7474508ejm.414.1593633949061; Wed, 01 Jul 2020 13:05:49 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1593633949; cv=none; d=google.com; s=arc-20160816; b=ksdCGkVxBjCFhBuGeUlbnKAf2bFzhTI33f3AW1S0HsTUi0dDS3GAZ/b9ws172j7elF 11l7VdUNICWaMdpKga/kgOGXLY/uVsjWOlW8Cg48ns12VABI9WHI6bNm61WnpNjUzLA4 DimiJTfNT4I4745fv9VdefySuX9fEArmqkq13B4gFZmdTA4Bz94vfpdsRA+bDmD36INA 63Xu1b9ZqZrFWt5hNAHrUaOyWnwbTlqk4vogxsYXGGA3GQIeq8IJwdAJdlvf6+Bdyuk3 3HXQ01Nm3j/56pbGub30L/8E2ju54MaYaP6rlYz0SQmzDbA7u/XopVPGwlvjpIv2nWF+ ZUlQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:mime-version:user-agent:references :message-id:in-reply-to:subject:cc:to:from:date:dkim-signature; bh=h+1Zhw+IU5Q0TCwvXbDCPP03c9PbqFM6QbL3RKeglzg=; b=g7FGqN5QAHK4LPRMfBCeReJnqk6uJSA7+DlTqxeWWhr+BBtoFR1HnVSQtO9448aFvg YAMyGyIyRksvM+DyIQRXohLy2YIv4LHLJr6Q6qJ5eVnw5XeJxJtMsqSBibLykoQfaFek plI4bhTPMetR63H1Nl2VYyYDSqgcMGnYoqosKQ8W666CPa0nzQIZFleqChhLxx8q7455 tKEg4uXomFWPqyFbmE1eHMlGvYf78kPmsAw0/hUhJAkm42mUgTdyYI7nRZMaNPp8uzlq FKspn0pUkpG8g/qpeLf/yBL1x0KcQnHLzBZnGiOh1tZKKXHaNdGjYNK5KFWDLg8s0Gay vfJw== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@google.com header.s=20161025 header.b=m7ZV4ZqQ; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=REJECT sp=REJECT dis=NONE) header.from=google.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id oq5si4371615ejb.110.2020.07.01.13.05.25; Wed, 01 Jul 2020 13:05:49 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; dkim=pass header.i=@google.com header.s=20161025 header.b=m7ZV4ZqQ; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=REJECT sp=REJECT dis=NONE) header.from=google.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1726469AbgGAUDF (ORCPT + 99 others); Wed, 1 Jul 2020 16:03:05 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:46158 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726049AbgGAUDE (ORCPT ); Wed, 1 Jul 2020 16:03:04 -0400 Received: from mail-pj1-x1044.google.com (mail-pj1-x1044.google.com [IPv6:2607:f8b0:4864:20::1044]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id B648EC08C5C1 for ; Wed, 1 Jul 2020 13:03:04 -0700 (PDT) Received: by mail-pj1-x1044.google.com with SMTP id gc9so4904523pjb.2 for ; Wed, 01 Jul 2020 13:03:04 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=20161025; h=date:from:to:cc:subject:in-reply-to:message-id:references :user-agent:mime-version; bh=h+1Zhw+IU5Q0TCwvXbDCPP03c9PbqFM6QbL3RKeglzg=; b=m7ZV4ZqQ8dOTQW70jelDPr+AgEtdHXqgtBl2IgnF8daantVBxjfVIMK1Gm8F0Li+oI BxefPgOgTQmCaBj+1lln0RS9uWIH5LCJU7gk7KR2SdjqjdbouPMoV38yKEEhDWStJCD8 txk92EdtNZ31+swmcPZgxROjzV0toLSKWPt0Z/IGgj4fpbAspLLAgqqPeWx8ImLB6gjk b1WYj9qFzqvEkIMskziaG0QSnhRU49ZDaS7Z4Wfeo1H0npKeSez+MuLu9oZKekqHYcZd YUx9TrsSVGTjQYoH8C3lkeRO8GgtA6g+VV4oT4g19iMBZe6OPhKArE84hfJRK8QWZfp2 Fc0Q== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:date:from:to:cc:subject:in-reply-to:message-id :references:user-agent:mime-version; bh=h+1Zhw+IU5Q0TCwvXbDCPP03c9PbqFM6QbL3RKeglzg=; b=qZL3L0QAdqvAa/t3oMxIMggHxiILzZ87OXrF2BJSE6XAAAG5wtV6R/JxkktdWZ7PWq MTVXR28DI9jTpxkSU9z7qAOKmspOjRnGBGyOFmDAcvHKpqvB0wAjcPRswIGY4M02o5dF Ziq+6lqpLEJLs/u2u/ZuuCl+BHOg80O1f5/wvP7rVirjhDWQsiwTNfEhjwQl5nr2plXK mIIHABw3+8c6aoIrD1zFJ4DIFUxGPrVHM+MPvZURTBlHJyv+oUlR0PWuVw1d2WyRdQdZ KOGvhEoiGePzxku0M8XnkOn0YTde5StGEKCOZJWgo8mOXwvwG30BypYMP3Ic5olPX2bF ZeMQ== X-Gm-Message-State: AOAM530ux0PyhEyK4Z0cfd9PuWSxVEcx0i1Hoq/H2SflqAu51zMww6L2 ZBCWPNUIemXg5RMMmpiGQ9Az/XCfHPY= X-Received: by 2002:a17:902:d20c:: with SMTP id t12mr23683155ply.291.1593633783951; Wed, 01 Jul 2020 13:03:03 -0700 (PDT) Received: from [2620:15c:17:3:4a0f:cfff:fe51:6667] ([2620:15c:17:3:4a0f:cfff:fe51:6667]) by smtp.gmail.com with ESMTPSA id oc6sm6464478pjb.43.2020.07.01.13.03.02 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Wed, 01 Jul 2020 13:03:02 -0700 (PDT) Date: Wed, 1 Jul 2020 13:03:01 -0700 (PDT) From: David Rientjes X-X-Sender: rientjes@chino.kir.corp.google.com To: Dave Hansen cc: linux-kernel@vger.kernel.org, linux-mm@kvack.org, ben.widawsky@intel.com, alex.shi@linux.alibaba.com, dwagner@suse.de, tobin@kernel.org, cl@linux.com, akpm@linux-foundation.org, ying.huang@intel.com, dan.j.williams@intel.com, cai@lca.pw Subject: Re: [PATCH 3/3] mm/vmscan: replace implicit RECLAIM_ZONE checks with explicit checks In-Reply-To: <20200701152627.8761147E@viggo.jf.intel.com> Message-ID: References: <20200701152621.D520E62B@viggo.jf.intel.com> <20200701152627.8761147E@viggo.jf.intel.com> User-Agent: Alpine 2.23 (DEB 453 2020-06-18) MIME-Version: 1.0 Content-Type: text/plain; charset=US-ASCII Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Wed, 1 Jul 2020, Dave Hansen wrote: > diff -puN include/linux/swap.h~mm-vmscan-node_reclaim_mode_helper include/linux/swap.h > --- a/include/linux/swap.h~mm-vmscan-node_reclaim_mode_helper 2020-07-01 08:22:13.650955330 -0700 > +++ b/include/linux/swap.h 2020-07-01 08:22:13.659955330 -0700 > @@ -12,6 +12,7 @@ > #include > #include > #include > +#include > #include > > struct notifier_block; > @@ -374,6 +375,12 @@ extern int sysctl_min_slab_ratio; > #define node_reclaim_mode 0 > #endif > > +static inline bool node_reclaim_enabled(void) > +{ > + /* Is any node_reclaim_mode bit set? */ > + return node_reclaim_mode & (RECLAIM_ZONE|RECLAIM_WRITE|RECLAIM_UNMAP); > +} > + > extern void check_move_unevictable_pages(struct pagevec *pvec); > > extern int kswapd_run(int nid); If a user writes a bit that isn't a RECLAIM_* bit to vm.zone_reclaim_mode today, it acts as though RECLAIM_ZONE is enabled: we try to reclaim in zonelist order before falling back to the next zone in the page allocator. The sysctl doesn't enforce any max value :/ I dont know if there is any such user, but this would break them if there is. Should this simply be return !!node_reclaim_mode?