Received: by 2002:a05:6a10:f347:0:0:0:0 with SMTP id d7csp3060143pxu; Mon, 14 Dec 2020 19:37:32 -0800 (PST) X-Google-Smtp-Source: ABdhPJzQx54zOiTJaoTEkEOl1Y9b3k+2BWmqecamEmjF/ZnZxal9tKUKOo0ZIrPBoNbVX3PRBlyk X-Received: by 2002:a50:eb96:: with SMTP id y22mr27924029edr.91.1608003452321; Mon, 14 Dec 2020 19:37:32 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1608003452; cv=none; d=google.com; s=arc-20160816; b=KcJcUvCBnp62YAE8WBysBZs4ag0DSagiO6Yy8NuERD4z/BJZoKqMzIkxekXGB+Cffc 2UQNHpFdSCz81esRoz1YEGcl1D9P0h0o6FmOds6A+nBz5vXw2f69cP78C+Rcxs4NGlvQ 6tAqMzyrYyD2yN1QcOWAH4oEw7d0IObmE73OzRCIu+0tPWSJzrOr+Jp2JVE0JagDUUAc yws/QMqEdAvCrZWCFvu9+roxvFdcuSHAJ+uXCvwK8uOs3u/MmZLNvhofI08jmbxSalAs Ks7zkaw4R1Gnl6mK4xu2XDEvV8TwvC1D51aNOCZCpbIXXHspmJ5Hrw4XYaV4mhU5IohL C/wQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:in-reply-to:content-disposition:mime-version :references:message-id:subject:cc:to:from:date; bh=87Hv26DmbPBdG2RTwdGz6H0eaqohly+I6z7ALQoDQf4=; b=SgdmHpJswrIVpT20QhyFPZUbKiOvFhrAL2sFf6PuNF9+oIQvX2nn4ZhLmtNETJ33kC yNJEqL/gJFz73gGSV1COgx4Zxoi/ZpcPeq9gt05s8TMuRJfMyZdeL7LOZZu/8XjLAzoK +dmZrFkHTNoLx+9VcYkbUk3TKhS99UqdmpKZ0TE/l5mFDh5h9/gLJ7X8E/l3IjeHEviC Hd0dkvXHBkI82o/4rnR3XtpRjob5Gl1iTh9b5ybw2sNE91vNqITLmnmTDsyFjb8btZOe VwiiZP3LgCX2PvbgM/QgQbhm0rtvBNUiYKd91HgcWy1LKPNS5XDFwtKQod08BhYHUh/Y GDuA== 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 b2si267102ejh.264.2020.12.14.19.37.09; Mon, 14 Dec 2020 19:37:32 -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 S1727269AbgLODGY (ORCPT + 99 others); Mon, 14 Dec 2020 22:06:24 -0500 Received: from mail104.syd.optusnet.com.au ([211.29.132.246]:41330 "EHLO mail104.syd.optusnet.com.au" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1727090AbgLODGP (ORCPT ); Mon, 14 Dec 2020 22:06:15 -0500 Received: from dread.disaster.area (pa49-179-6-140.pa.nsw.optusnet.com.au [49.179.6.140]) by mail104.syd.optusnet.com.au (Postfix) with ESMTPS id 60AA458C677; Tue, 15 Dec 2020 14:05:29 +1100 (AEDT) Received: from dave by dread.disaster.area with local (Exim 4.92.3) (envelope-from ) id 1kp0eW-00454U-Mx; Tue, 15 Dec 2020 14:05:28 +1100 Date: Tue, 15 Dec 2020 14:05:28 +1100 From: Dave Chinner To: Yang Shi Cc: guro@fb.com, ktkhai@virtuozzo.com, shakeelb@google.com, hannes@cmpxchg.org, mhocko@suse.com, akpm@linux-foundation.org, linux-mm@kvack.org, linux-fsdevel@vger.kernel.org, linux-kernel@vger.kernel.org Subject: Re: [v2 PATCH 7/9] mm: vmscan: don't need allocate shrinker->nr_deferred for memcg aware shrinkers Message-ID: <20201215030528.GN3913616@dread.disaster.area> References: <20201214223722.232537-1-shy828301@gmail.com> <20201214223722.232537-8-shy828301@gmail.com> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <20201214223722.232537-8-shy828301@gmail.com> X-Optus-CM-Score: 0 X-Optus-CM-Analysis: v=2.3 cv=Ubgvt5aN c=1 sm=1 tr=0 cx=a_idp_d a=uDU3YIYVKEaHT0eX+MXYOQ==:117 a=uDU3YIYVKEaHT0eX+MXYOQ==:17 a=kj9zAlcOel0A:10 a=zTNgK-yGK50A:10 a=pGLkceISAAAA:8 a=7-415B0cAAAA:8 a=HoWvQtbgcFNr9bk3r4sA:9 a=CjuIK1q_8ugA:10 a=-RoEEKskQ1sA:10 a=biEYGPWJfzWAr4FL6Ov7:22 Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Mon, Dec 14, 2020 at 02:37:20PM -0800, Yang Shi wrote: > Now nr_deferred is available on per memcg level for memcg aware shrinkers, so don't need > allocate shrinker->nr_deferred for such shrinkers anymore. > > Signed-off-by: Yang Shi > --- > mm/vmscan.c | 28 ++++++++++++++-------------- > 1 file changed, 14 insertions(+), 14 deletions(-) > > diff --git a/mm/vmscan.c b/mm/vmscan.c > index bce8cf44eca2..8d5bfd818acd 100644 > --- a/mm/vmscan.c > +++ b/mm/vmscan.c > @@ -420,7 +420,15 @@ unsigned long lruvec_lru_size(struct lruvec *lruvec, enum lru_list lru, int zone > */ > int prealloc_shrinker(struct shrinker *shrinker) > { > - unsigned int size = sizeof(*shrinker->nr_deferred); > + unsigned int size; > + > + if (is_deferred_memcg_aware(shrinker)) { > + if (prealloc_memcg_shrinker(shrinker)) > + return -ENOMEM; > + return 0; > + } > + > + size = sizeof(*shrinker->nr_deferred); > > if (shrinker->flags & SHRINKER_NUMA_AWARE) > size *= nr_node_ids; > @@ -429,26 +437,18 @@ int prealloc_shrinker(struct shrinker *shrinker) > if (!shrinker->nr_deferred) > return -ENOMEM; > > - if (shrinker->flags & SHRINKER_MEMCG_AWARE) { > - if (prealloc_memcg_shrinker(shrinker)) > - goto free_deferred; > - } > - > return 0; > - > -free_deferred: > - kfree(shrinker->nr_deferred); > - shrinker->nr_deferred = NULL; > - return -ENOMEM; > } I'm trying to put my finger on it, but this seems wrong to me. If memcgs are disabled, then prealloc_memcg_shrinker() needs to fail. The preallocation code should not care about internal memcg details like this. /* * If the shrinker is memcg aware and memcgs are not * enabled, clear the MEMCG flag and fall back to non-memcg * behaviour for the shrinker. */ if (shrinker->flags & SHRINKER_MEMCG_AWARE) { error = prealloc_memcg_shrinker(shrinker); if (!error) return 0; if (error != -ENOSYS) return error; /* memcgs not enabled! */ shrinker->flags &= ~SHRINKER_MEMCG_AWARE; } size = sizeof(*shrinker->nr_deferred); .... return 0; } This guarantees that only the shrinker instances taht have a correctly set up memcg attached to them will have the SHRINKER_MEMCG_AWARE flag set. Hence in all the rest of the shrinker code, we only ever need to check for SHRINKER_MEMCG_AWARE to determine what we should do.... > void free_prealloced_shrinker(struct shrinker *shrinker) > { > - if (!shrinker->nr_deferred) > + if (is_deferred_memcg_aware(shrinker)) { > + unregister_memcg_shrinker(shrinker); > return; > + } > > - if (shrinker->flags & SHRINKER_MEMCG_AWARE) > - unregister_memcg_shrinker(shrinker); > + if (!shrinker->nr_deferred) > + return; > > kfree(shrinker->nr_deferred); > shrinker->nr_deferred = NULL; e.g. then this function can simply do: { if (shrinker->flags & SHRINKER_MEMCG_AWARE) return unregister_memcg_shrinker(shrinker); kfree(shrinker->nr_deferred); shrinker->nr_deferred = NULL; } Cheers, Dave. -- Dave Chinner david@fromorbit.com