Received: by 2002:a05:6a10:8c0a:0:0:0:0 with SMTP id go10csp390310pxb; Thu, 21 Jan 2021 09:25:59 -0800 (PST) X-Google-Smtp-Source: ABdhPJw3DzdmcXe5tl2X3Y7Gy0g71QlMwIYN5Iw1nGl+PBAGiXaypyNu832EeCGJvGj+zI1mXyG4 X-Received: by 2002:a50:9f65:: with SMTP id b92mr184527edf.74.1611249958988; Thu, 21 Jan 2021 09:25:58 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1611249958; cv=none; d=google.com; s=arc-20160816; b=gcgoCDJDwmTUBgxVvCVCTKE/WznZ7ljpiRfszqd9DushUnJG+tLaMlV8xKsnbbEA94 xRT0LPEeiEEor98sZ5UuyN+KLfsCMfrXmAcqhKJHK4oy3MSYM4iF3HaVoIJDHd4wTjkG NT5I2RpPRfgJ3CTV7sFxtsBt4hN4m+KtjtWY18v462drDg04eH54SKov00T6hhCxibuf vpvxZFi7ke5L70+bU7Xuj2BGxOJIwnGoS+8hbJH7/NJwZXD8K2MEhEnmNeTDPbOkWyhg WSmxihnp7gclD5ED/J8Ya5PC4E53kxV32k5ORJA8BhkbivSUhS9K4FIgqJSRJHYGl8PI yUvg== 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; bh=D90y9HqJDnSphy8O3sBDQU+/IMUr5u9YB8Anq/Uugeg=; b=hahLIwbbompT1h9vFGnavciDCoqF6Mql0wLKLROk7uWVcTRScQliPMvKzfMe/k4Utl iFpQDa5pES2LeBq2g8dT+caOxUAyTejqUuF3uoQ0O6Nex3Z88gZUTjIHCyXhL2qAiMR4 6lH9seR4tmzGvhW3knRkev7aplbfN7aJ3Mdr7Yb25sroLsaDF7M8jSjhXABTQn4vv8rd PYJ/9DgiAzVJc3KfIQRxp/6g/bXv2ViP99mINuI3vZS8XXeaRC1r9i4yzEulXRozBMTU qwtq3voJEUjvjWI2jiYCqnE3abULpHM07kkoQlwVAmzFtVO0JiMf6WUEhLN4QiD3M9vB uYDQ== ARC-Authentication-Results: i=1; mx.google.com; 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 Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id s13si2293287eds.57.2021.01.21.09.25.33; Thu, 21 Jan 2021 09:25:58 -0800 (PST) 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; 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 Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1733194AbhAURWx (ORCPT + 99 others); Thu, 21 Jan 2021 12:22:53 -0500 Received: from mx2.suse.de ([195.135.220.15]:44254 "EHLO mx2.suse.de" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1730552AbhAURWr (ORCPT ); Thu, 21 Jan 2021 12:22:47 -0500 X-Virus-Scanned: by amavisd-new at test-mx.suse.de Received: from relay2.suse.de (unknown [195.135.221.27]) by mx2.suse.de (Postfix) with ESMTP id 054CCAAAE; Thu, 21 Jan 2021 17:22:05 +0000 (UTC) From: Vlastimil Babka To: vbabka@suse.cz Cc: akpm@linux-foundation.org, bigeasy@linutronix.de, cl@linux.com, guro@fb.com, hannes@cmpxchg.org, iamjoonsoo.kim@lge.com, jannh@google.com, linux-kernel@vger.kernel.org, linux-mm@kvack.org, mhocko@kernel.org, minchan@kernel.org, penberg@kernel.org, rientjes@google.com, shakeelb@google.com, surenb@google.com, tglx@linutronix.de Subject: [RFC 1/2] mm, vmscan: add priority field to struct shrink_control Date: Thu, 21 Jan 2021 18:21:53 +0100 Message-Id: <20210121172154.27580-1-vbabka@suse.cz> X-Mailer: git-send-email 2.30.0 In-Reply-To: References: MIME-Version: 1.0 Content-Transfer-Encoding: 8bit Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Slab reclaim works with reclaim priority, which influences how much to reclaim, but is not directly passed to individual shrinkers. The next patch introduces a slab shrinker that uses the priority, so add it to shrink_control and initialize appropriately. We can then also remove the parameter from shrink_slab() and trace_mm_shrink_slab_start(). Signed-off-by: Vlastimil Babka --- include/linux/shrinker.h | 3 +++ include/trace/events/vmscan.h | 8 +++----- mm/vmscan.c | 14 ++++++++------ 3 files changed, 14 insertions(+), 11 deletions(-) diff --git a/include/linux/shrinker.h b/include/linux/shrinker.h index 0f80123650e2..1066f052be4f 100644 --- a/include/linux/shrinker.h +++ b/include/linux/shrinker.h @@ -29,6 +29,9 @@ struct shrink_control { */ unsigned long nr_scanned; + /* current reclaim priority */ + int priority; + /* current memcg being shrunk (for memcg aware shrinkers) */ struct mem_cgroup *memcg; }; diff --git a/include/trace/events/vmscan.h b/include/trace/events/vmscan.h index 2070df64958e..d42e480977c6 100644 --- a/include/trace/events/vmscan.h +++ b/include/trace/events/vmscan.h @@ -185,11 +185,9 @@ DEFINE_EVENT(mm_vmscan_direct_reclaim_end_template, mm_vmscan_memcg_softlimit_re TRACE_EVENT(mm_shrink_slab_start, TP_PROTO(struct shrinker *shr, struct shrink_control *sc, long nr_objects_to_shrink, unsigned long cache_items, - unsigned long long delta, unsigned long total_scan, - int priority), + unsigned long long delta, unsigned long total_scan), - TP_ARGS(shr, sc, nr_objects_to_shrink, cache_items, delta, total_scan, - priority), + TP_ARGS(shr, sc, nr_objects_to_shrink, cache_items, delta, total_scan), TP_STRUCT__entry( __field(struct shrinker *, shr) @@ -212,7 +210,7 @@ TRACE_EVENT(mm_shrink_slab_start, __entry->cache_items = cache_items; __entry->delta = delta; __entry->total_scan = total_scan; - __entry->priority = priority; + __entry->priority = sc->priority; ), TP_printk("%pS %p: nid: %d objects to shrink %ld gfp_flags %s cache items %ld delta %lld total_scan %ld priority %d", diff --git a/mm/vmscan.c b/mm/vmscan.c index 469016222cdb..bc5157625cec 100644 --- a/mm/vmscan.c +++ b/mm/vmscan.c @@ -410,7 +410,7 @@ EXPORT_SYMBOL(unregister_shrinker); #define SHRINK_BATCH 128 static unsigned long do_shrink_slab(struct shrink_control *shrinkctl, - struct shrinker *shrinker, int priority) + struct shrinker *shrinker) { unsigned long freed = 0; unsigned long long delta; @@ -439,7 +439,7 @@ static unsigned long do_shrink_slab(struct shrink_control *shrinkctl, total_scan = nr; if (shrinker->seeks) { - delta = freeable >> priority; + delta = freeable >> shrinkctl->priority; delta *= 4; do_div(delta, shrinker->seeks); } else { @@ -484,7 +484,7 @@ static unsigned long do_shrink_slab(struct shrink_control *shrinkctl, total_scan = freeable * 2; trace_mm_shrink_slab_start(shrinker, shrinkctl, nr, - freeable, delta, total_scan, priority); + freeable, delta, total_scan); /* * Normally, we should not scan less than batch_size objects in one @@ -562,6 +562,7 @@ static unsigned long shrink_slab_memcg(gfp_t gfp_mask, int nid, struct shrink_control sc = { .gfp_mask = gfp_mask, .nid = nid, + .priority = priority, .memcg = memcg, }; struct shrinker *shrinker; @@ -578,7 +579,7 @@ static unsigned long shrink_slab_memcg(gfp_t gfp_mask, int nid, !(shrinker->flags & SHRINKER_NONSLAB)) continue; - ret = do_shrink_slab(&sc, shrinker, priority); + ret = do_shrink_slab(&sc, shrinker); if (ret == SHRINK_EMPTY) { clear_bit(i, map->map); /* @@ -597,7 +598,7 @@ static unsigned long shrink_slab_memcg(gfp_t gfp_mask, int nid, * set_bit() do_shrink_slab() */ smp_mb__after_atomic(); - ret = do_shrink_slab(&sc, shrinker, priority); + ret = do_shrink_slab(&sc, shrinker); if (ret == SHRINK_EMPTY) ret = 0; else @@ -666,10 +667,11 @@ static unsigned long shrink_slab(gfp_t gfp_mask, int nid, struct shrink_control sc = { .gfp_mask = gfp_mask, .nid = nid, + .priority = priority, .memcg = memcg, }; - ret = do_shrink_slab(&sc, shrinker, priority); + ret = do_shrink_slab(&sc, shrinker); if (ret == SHRINK_EMPTY) ret = 0; freed += ret; -- 2.30.0