Received: by 2002:a05:6a10:6d10:0:0:0:0 with SMTP id gq16csp984809pxb; Fri, 22 Apr 2022 16:00:22 -0700 (PDT) X-Google-Smtp-Source: ABdhPJyumpKf0T5RXmd21KvhAP5upwB+nK+BxwpEmkz27Z1xEGo4MxhxIXl4Rr2jfq2PBFxxGyGO X-Received: by 2002:a65:4189:0:b0:3a2:1682:5fc with SMTP id a9-20020a654189000000b003a2168205fcmr5754916pgq.426.1650668422133; Fri, 22 Apr 2022 16:00:22 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1650668422; cv=none; d=google.com; s=arc-20160816; b=J8vaq6EwphoggZ5qQxUJZjKh0/9+S40LTyOeo4xObTbOveTE19xi9Oor6SkPAJCt5o 9N877flkSJdvwJPwt0QEkDB4m4B5CAzbrKWxGu1vi3Mgfm0ge0mDrUxVLhx+w1Pa3KQI l5HLH04oXsXkgxcb46g72jCBYCEtCSkkzWrc6RxuVKrI6B0BjMGjMSmEZa6J0/EiAVZ3 CuuAkc9dc20f36/gkI7Y9o0Vz1qkQtd+4l/8aIXVYMiCqhBaTfmKxFOJrqN+4oZqKO2F LZmDz67AjpZP66JyABxja3Ni+Nk0qiqnwT+KjrobGd2wxXL3ivLgif06fJ7VVYSaK51j Le0Q== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:cc:to:subject:message-id:date:from:in-reply-to :references:mime-version:dkim-signature; bh=PLxWgfNIqb0f6MOCKWhoyP5UgmjbIvJbEaB9oK2PBEI=; b=xMrfBsfIK7M0+btTr+h/of24TCnpNmUpGm+Z48qs0WQVRGrvtl0Kk69Ax0heq02Xmg aV17IIOVKK3AEE9D54XkwYshkFU5cw1Aieyqy651DXcCZiXRUnmcpbhOadfsYACsrjnq DzjwxRv1Oqy5l8qxwDkpdfn5tLdXhjbhqnzxoOeouVOhN34/NmAYTp2bilPnGyM9Q4CI 9kH2aVLoplJHEZfmOA+fnsB+vUj4+fnXqquOARW7ZJHMuMhiBQWpnyvlDTfYNM1l3fp5 BiYRUD08WO7IiCz0/pmt/BdN9hYRhO3S/WNfuuGtoRZ93nYuzerQwE1YFDbhV4BAG7QU UhGA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@google.com header.s=20210112 header.b=KmWunHFw; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1: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 lindbergh.monkeyblade.net (lindbergh.monkeyblade.net. [2620:137:e000::1:18]) by mx.google.com with ESMTPS id p27-20020a631e5b000000b00386123c9f67si9734774pgm.148.2022.04.22.16.00.21 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Fri, 22 Apr 2022 16:00:22 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:18 as permitted sender) client-ip=2620:137:e000::1:18; Authentication-Results: mx.google.com; dkim=pass header.i=@google.com header.s=20210112 header.b=KmWunHFw; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1: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: from vger.kernel.org (vger.kernel.org [23.128.96.18]) by lindbergh.monkeyblade.net (Postfix) with ESMTP id A84F92C522F; Fri, 22 Apr 2022 14:58:23 -0700 (PDT) Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S231281AbiDVWA6 (ORCPT + 99 others); Fri, 22 Apr 2022 18:00:58 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:46946 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S231240AbiDVWAi (ORCPT ); Fri, 22 Apr 2022 18:00:38 -0400 Received: from mail-pl1-x633.google.com (mail-pl1-x633.google.com [IPv6:2607:f8b0:4864:20::633]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 582B040E31B for ; Fri, 22 Apr 2022 13:43:44 -0700 (PDT) Received: by mail-pl1-x633.google.com with SMTP id u15so9952957ple.4 for ; Fri, 22 Apr 2022 13:43:44 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=20210112; h=mime-version:references:in-reply-to:from:date:message-id:subject:to :cc; bh=PLxWgfNIqb0f6MOCKWhoyP5UgmjbIvJbEaB9oK2PBEI=; b=KmWunHFwmhZ7+/Z0zkVhdm6bYlodk2R4jIYhIdJ6TpI7Ncz4EEZv2P5/ZKRin+K3CY LEW2VPEsRB9iu9U1wVrDx7H2ZCsP0X+PwNoiQxWuLBXC9iefYrWR5t7bwmyHfk69wuWW 4xvMPSD5UpI88QZKV32T0JqeArgRbKqUeVQqJ971ag1+dUKy1Qr5odxP375OcM/gabpc ObNCGU3a9bXSrWXKXimjbFYaaWDdU5LDkfqHpHjktW5joHj6DTM2j60L4V+h33qn5D0q lEuny2FIILqyXyJ/9I2br9SYrobHi2UnXKujmJFPKRAYYh/ul/5irlOqb7vyELRB8O6u eZ0g== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20210112; h=x-gm-message-state:mime-version:references:in-reply-to:from:date :message-id:subject:to:cc; bh=PLxWgfNIqb0f6MOCKWhoyP5UgmjbIvJbEaB9oK2PBEI=; b=lfKgGMjWSwK5ztsYs09ktAi3wdu2yI7vBvafJfP5xU6LAJE3omDas/zoBszEjbEzMA dZuuDB3qY+LYW3fLRtz9wMtLyPy81MQHmw22xiS25/SgnVjpFHf06RtZrfZkVJaG4jVU mMMxqKgljlGqWWSmQmX2X+C0z62eiwLXwelJ3gIjPENUPfBZEhrSA+bLGlROdDPjr9Pu JmnLINYG/Y6ryMkOvESqXVnVxxiwUU8IMTDzROLq5o7dsBDVkWzfrgcI9rfWwhNwkke1 7iu4B3N8ywrQoV4c4Yk6OSUG6C/UKpu7i7ilngeeWtpXIEW0BtDw1bpmfaSl41ZdQtrU jTrw== X-Gm-Message-State: AOAM533nijcj4ULDs4IieFlbEy6Y6Y3Byz6IWIPNi8KLRsOIN80RPkOU PX3LOS6hzTOd1SrotmXiLlH36yDRj4BNA8o6d4UA4QRPJ96sWA== X-Received: by 2002:a05:6102:3106:b0:32a:18c8:1633 with SMTP id e6-20020a056102310600b0032a18c81633mr2070333vsh.51.1650659373899; Fri, 22 Apr 2022 13:29:33 -0700 (PDT) MIME-Version: 1.0 References: <20220422195516.10769-1-jvgediya@linux.ibm.com> <20220422195516.10769-3-jvgediya@linux.ibm.com> In-Reply-To: <20220422195516.10769-3-jvgediya@linux.ibm.com> From: Wei Xu Date: Fri, 22 Apr 2022 13:29:22 -0700 Message-ID: Subject: Re: [PATCH v3 2/7] mm: demotion: Add new node state N_DEMOTION_TARGETS To: Jagdish Gediya Cc: linux-mm@kvack.org, linux-kernel@vger.kernel.org, akpm@linux-foundation.org, baolin.wang@linux.alibaba.com, dave.hansen@linux.intel.com, ying.huang@intel.com, aneesh.kumar@linux.ibm.com, shy828301@gmail.com, gthelen@google.com, dan.j.williams@intel.com Content-Type: text/plain; charset="UTF-8" X-Spam-Status: No, score=-9.5 required=5.0 tests=BAYES_00,DKIMWL_WL_MED, DKIM_SIGNED,DKIM_VALID,DKIM_VALID_AU,HEADER_FROM_DIFFERENT_DOMAINS, MAILING_LIST_MULTI,RDNS_NONE,SPF_HELO_NONE,USER_IN_DEF_DKIM_WL autolearn=no 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 Fri, Apr 22, 2022 at 12:55 PM Jagdish Gediya wrote: > > Some systems(e.g. PowerVM) have DRAM(fast memory) only NUMA node > which are N_MEMORY as well as slow memory(persistent memory) only > NUMA node which are also N_MEMORY. As the current demotion target > finding algorithm works based on N_MEMORY and best distance, it can > choose DRAM only NUMA node as demotion target instead of persistent > memory node on such systems. If DRAM only NUMA node is filled with > demoted pages then at some point new allocations can start falling > to persistent memory, so basically cold pages are in fast memory > (due to demotion) and new pages are in slow memory, this is why > persistent memory nodes should be utilized for demotion and dram node > should be avoided for demotion so that they can be used for new > allocations. > > Add new state N_DEMOTION_TARGETS, node_states[N_DEMOTION_TARGETS] > then can be used to hold the list of nodes which can be used > as demotion targets, later patches in the series builds demotion > targets based on nodes available in node_states[N_DEMOTION_TARGETS]. > > Signed-off-by: Aneesh Kumar K.V > Signed-off-by: Jagdish Gediya > --- > drivers/base/node.c | 4 ++++ > include/linux/nodemask.h | 1 + > 2 files changed, 5 insertions(+) > Acked-by: Wei Xu > diff --git a/drivers/base/node.c b/drivers/base/node.c > index ec8bb24a5a22..6eef22e6413e 100644 > --- a/drivers/base/node.c > +++ b/drivers/base/node.c > @@ -1038,6 +1038,9 @@ static struct node_attr node_state_attr[] = { > [N_CPU] = _NODE_ATTR(has_cpu, N_CPU), > [N_GENERIC_INITIATOR] = _NODE_ATTR(has_generic_initiator, > N_GENERIC_INITIATOR), > + [N_DEMOTION_TARGETS] = _NODE_ATTR(demotion_targets, > + N_DEMOTION_TARGETS), > + > }; > > static struct attribute *node_state_attrs[] = { > @@ -1050,6 +1053,7 @@ static struct attribute *node_state_attrs[] = { > &node_state_attr[N_MEMORY].attr.attr, > &node_state_attr[N_CPU].attr.attr, > &node_state_attr[N_GENERIC_INITIATOR].attr.attr, > + &node_state_attr[N_DEMOTION_TARGETS].attr.attr, > NULL > }; > > diff --git a/include/linux/nodemask.h b/include/linux/nodemask.h > index 567c3ddba2c4..17844300fd57 100644 > --- a/include/linux/nodemask.h > +++ b/include/linux/nodemask.h > @@ -400,6 +400,7 @@ enum node_states { > N_MEMORY, /* The node has memory(regular, high, movable) */ > N_CPU, /* The node has one or more cpus */ > N_GENERIC_INITIATOR, /* The node has one or more Generic Initiators */ > + N_DEMOTION_TARGETS, /* Nodes that should be considered as demotion targets */ > NR_NODE_STATES > }; > > -- > 2.35.1 >