Received: by 2002:a05:6a10:206:0:0:0:0 with SMTP id 6csp3404209pxj; Tue, 11 May 2021 03:53:41 -0700 (PDT) X-Google-Smtp-Source: ABdhPJxuPnq0Pgt5lOK6kSzbB++7jY22L4hX0QyhrzRjVtENEStzRIDkIetRtkANg2rD1VGbAc1I X-Received: by 2002:a6b:ef1a:: with SMTP id k26mr18957664ioh.197.1620730421634; Tue, 11 May 2021 03:53:41 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1620730421; cv=none; d=google.com; s=arc-20160816; b=tjQ899mY2UFnr9ILvRtdQ2OOar07J51RKmTsOr24tSnvIk/JmlJRHZUItsYv9SwSST IjxyIUR3ClFrP1pr4LIaydjGSIDt+2MQBGU90SPVfTim4SKTbewaYrSFjbtnpmo/cii7 ThT7Fkc3sRbrqrlu85FYD4hDEHqZ44tmX8ZZRUMlsORywwP7uxrv818/L9hOXGcmv9wW kbf1nqcMtd6xToO7AmU8kMOzc3J+WFt+hSUNIvpHiF5Zws6jmxXJrx/Xpq5YNFzHQkUy 1q7it3zz4GsPn3hTbl8HjvH5Edl6U2wZZTV6FU2h5V78A5H0xsFSkUVQozel2ZqItajD GQ6w== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:mime-version :references:in-reply-to:message-id:date:subject:cc:to:from :dkim-signature; bh=UC6OZyaIhxumzS7XDWC0Pam7E2Uxa7uVbRoAHU6H0rc=; b=Q5QdyLO+6iRe7/R14mfLbSH4OhU3TmPpCu2GGWD5nlvreJaAJ+1+v7odr2tn6B0etS 6Pa0eO6uyr7mxl/x7TjWBBN0pUheUBfRUrDzPQViI2/cgpG9awj9zJ5shwYz76V9Tqsd emog6LWaxrALlwy/3z2ehyzpMvONH+GikI9hVv+lo09sBcjsXLeWueZiPx8+e6Ih8qhY 110f+taIksdmnI90fllXMjvlTDFmeT5YGLyadwwNk++If4Qf8JGZvcSnPAhJFoFXfoho 1RvrktgQ/m9rA7gr9xtyNEXz26+w+O9ZkDVo79VZPrWmZfYTRAtH+aNC1RIFtvDh9wb/ jzAw== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@bytedance-com.20150623.gappssmtp.com header.s=20150623 header.b=mvEtMpGA; spf=pass (google.com: domain of linux-nfs-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-nfs-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=bytedance.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id a11si16207741ilr.140.2021.05.11.03.53.28; Tue, 11 May 2021 03:53:41 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-nfs-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=@bytedance-com.20150623.gappssmtp.com header.s=20150623 header.b=mvEtMpGA; spf=pass (google.com: domain of linux-nfs-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-nfs-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=bytedance.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S231539AbhEKKyA (ORCPT + 99 others); Tue, 11 May 2021 06:54:00 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:56130 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S231563AbhEKKx6 (ORCPT ); Tue, 11 May 2021 06:53:58 -0400 Received: from mail-pf1-x42b.google.com (mail-pf1-x42b.google.com [IPv6:2607:f8b0:4864:20::42b]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id A8643C061574 for ; Tue, 11 May 2021 03:52:52 -0700 (PDT) Received: by mail-pf1-x42b.google.com with SMTP id v191so15757618pfc.8 for ; Tue, 11 May 2021 03:52:52 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=bytedance-com.20150623.gappssmtp.com; s=20150623; h=from:to:cc:subject:date:message-id:in-reply-to:references :mime-version:content-transfer-encoding; bh=UC6OZyaIhxumzS7XDWC0Pam7E2Uxa7uVbRoAHU6H0rc=; b=mvEtMpGAnQS8X8pRY7QVvYJqqFPUGuS6zE62rkByxR5oNroFVjCS/xKDGbYaocAf7z hH2gWvCBgKxEHy1XHZd1y2KTeOizDfHXJrv50DMYgnnhFlp1AEWzArmF/Ku8n2QKSQrw n0UxiRXkdGjhWXGofRNp7yl60YhBicMzxGfCQgcsFthk50VTyfFnVioBZCT6AnKa8Gel cUU1AQbGq6zAZMkEMMfKyksQht4k9fxrkdQdtKIQhRzpWK35znHAgqk3t5Bx1RDVKacM nKsk4K4cj9yoezeHv+dsCU7Is+7nMQ3Nk4ADCqY+FyBsQV/QqcmlmBAcD1ZLfyqdNc3V UYrA== 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:in-reply-to :references:mime-version:content-transfer-encoding; bh=UC6OZyaIhxumzS7XDWC0Pam7E2Uxa7uVbRoAHU6H0rc=; b=WcB4xhcJj7NpdM4a3vVkwxAbkwAfpA2/k0Ka2h3Cz8bqEGrxlNNh2ARX44SdbK9z1f iHDYWiJc7PFkJDcm6OA+We8aX77bSX5qieRUrFytDSD5Jsm0GgFPEiyU/KQogzUj5qW4 TQQ6jUAxdHsajBfntd1Zi2LPBxCLw7/2+Ch53u4U3rNZz9Yd3gPtRVLns0vyKUaPlK1d lVrVlD2gVw3pdpl6leiaPRv+cX0q4N+bZA7I151WCbCBzwdkYwATp+T+bvMyTEf/k8Ry wG1rTCdthqoz2AUHSz23IuYOCyAokI2LOniwei7J49f4x7K6QtuaK/5rYSPv6meNvHHE SvoQ== X-Gm-Message-State: AOAM530oMeNhV0Z6VQKfr1tNPHLaUEely73p8HpHtFk4qb2348P7xJqF GJGLKGPH0iwDox1dwBG5X8HJKA== X-Received: by 2002:a63:aa48:: with SMTP id x8mr6373173pgo.359.1620730372289; Tue, 11 May 2021 03:52:52 -0700 (PDT) Received: from localhost.localdomain ([139.177.225.240]) by smtp.gmail.com with ESMTPSA id n18sm13501952pgj.71.2021.05.11.03.52.45 (version=TLS1_2 cipher=ECDHE-ECDSA-AES128-GCM-SHA256 bits=128/128); Tue, 11 May 2021 03:52:52 -0700 (PDT) From: Muchun Song To: willy@infradead.org, akpm@linux-foundation.org, hannes@cmpxchg.org, mhocko@kernel.org, vdavydov.dev@gmail.com, shakeelb@google.com, guro@fb.com, shy828301@gmail.com, alexs@kernel.org, richard.weiyang@gmail.com, david@fromorbit.com, trond.myklebust@hammerspace.com, anna.schumaker@netapp.com Cc: linux-fsdevel@vger.kernel.org, linux-kernel@vger.kernel.org, linux-mm@kvack.org, linux-nfs@vger.kernel.org, zhengqi.arch@bytedance.com, duanxiongchun@bytedance.com, fam.zheng@bytedance.com, Muchun Song Subject: [PATCH 13/17] mm: workingset: allocate list_lru on xa_node allocation Date: Tue, 11 May 2021 18:46:43 +0800 Message-Id: <20210511104647.604-14-songmuchun@bytedance.com> X-Mailer: git-send-email 2.21.0 (Apple Git-122) In-Reply-To: <20210511104647.604-1-songmuchun@bytedance.com> References: <20210511104647.604-1-songmuchun@bytedance.com> MIME-Version: 1.0 Content-Transfer-Encoding: 8bit Precedence: bulk List-ID: X-Mailing-List: linux-nfs@vger.kernel.org The workingset will add the xa_node to its list_lru, we should use xas_set_lru() to pass which lru we want to insert. Signed-off-by: Muchun Song --- include/linux/swap.h | 5 ++++- mm/workingset.c | 2 +- 2 files changed, 5 insertions(+), 2 deletions(-) diff --git a/include/linux/swap.h b/include/linux/swap.h index 144727041e78..a2418ebad13d 100644 --- a/include/linux/swap.h +++ b/include/linux/swap.h @@ -322,9 +322,12 @@ void workingset_activation(struct page *page); /* Only track the nodes of mappings with shadow entries */ void workingset_update_node(struct xa_node *node); +extern struct list_lru shadow_nodes; #define mapping_set_update(xas, mapping) do { \ - if (!dax_mapping(mapping) && !shmem_mapping(mapping)) \ + if (!dax_mapping(mapping) && !shmem_mapping(mapping)) { \ xas_set_update(xas, workingset_update_node); \ + xas_set_lru(xas, &shadow_nodes); \ + } \ } while (0) /* linux/mm/page_alloc.c */ diff --git a/mm/workingset.c b/mm/workingset.c index b7cdeca5a76d..f6923865be47 100644 --- a/mm/workingset.c +++ b/mm/workingset.c @@ -426,7 +426,7 @@ void workingset_activation(struct page *page) * point where they would still be useful. */ -static struct list_lru shadow_nodes; +struct list_lru shadow_nodes; void workingset_update_node(struct xa_node *node) { -- 2.11.0