Received: by 2002:a05:6358:701b:b0:131:369:b2a3 with SMTP id 27csp2965633rwo; Mon, 24 Jul 2023 04:24:00 -0700 (PDT) X-Google-Smtp-Source: APBJJlFLcThJmuewmb13m0zDA2pDeN9FifTEr9wCPONI4C0B9JBYnD2EGwsTcJ7DcYQdMDGSZ4o2 X-Received: by 2002:a17:90a:fc85:b0:267:f329:947d with SMTP id ci5-20020a17090afc8500b00267f329947dmr3210990pjb.33.1690197839730; Mon, 24 Jul 2023 04:23:59 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1690197839; cv=none; d=google.com; s=arc-20160816; b=TAamBsmjWk1GMD8cPr6/lYAjjsL7sVxhGrh9iYF6uAIf/gji7l4b8CEx1FrTOkwhll fsvgM9sFDuqXJsQF9neKLQHf+WGsGqvq/4xOfcJgD0K1v9B4uRCpd5Rb5X5QNqq39CBA cLk29+jIPb3q0+ipVIx0yYABmV7H44WNc5p1IBpIer/EueZj8LypBMV+v1A+pUd33R4T zQceQmlPvtrYBmkRyD6Kw+SiCs96LXY5pCbLgZmD2aowhl5IdbNlaqP64puZ03z5G2b5 ataS95sXBzENzvAj0hHdq6hcsq4uETohInHTM/01BYQbDM1f8UCitdXSWEanef22mZGm Rkbw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:in-reply-to:from :content-language:references:cc:to:subject:user-agent:mime-version :date:message-id; bh=fRq9dwwGFiUYnhelgiMFCqaFSvyn1Iy7L8f3oV4pu3I=; fh=abPoA8zHgLj90Cp2iQmzep2R6xTp52oGjb/bu8SFfPc=; b=VFHVFoivNuNRI1pTfhKl5P91E99ymgBsq/g78L0c6xd/c87Z7D99vzIhgnBLB8SNtR xK7TmXpmtdLmuQ0QyUiRnKYTLoUOXyP/5+TL9Ukv2WNpg24BH1NcP4coEzr3U/1nnar/ C3nQeqAtYq3IP8BvWtFptWr1HXaKsr0inY+DGS2WY4XojH81icYJMyRKslN53XKQSemW eZf3M1KqtWZy27t+hezzLsGZjXDfvjk5q2rqKX9u528NFlUME0WduliZ7FbT1lwevY8G r0xcSso7kaZdRYkxJ9VoC7IyuGTKBIDIwZyK6fAjR5TNqOBan8hFMhHR/yq0k3RNJw/b PDEw== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: domain of linux-nfs-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-nfs-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=arm.com Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id f5-20020a17090ab94500b00262ee7c6cafsi8967385pjw.87.2023.07.24.04.23.45; Mon, 24 Jul 2023 04:23:59 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-nfs-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) client-ip=2620:137:e000::1:20; Authentication-Results: mx.google.com; spf=pass (google.com: domain of linux-nfs-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-nfs-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=arm.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S230503AbjGXLSK (ORCPT + 99 others); Mon, 24 Jul 2023 07:18:10 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:43994 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S229813AbjGXLSI (ORCPT ); Mon, 24 Jul 2023 07:18:08 -0400 Received: from foss.arm.com (foss.arm.com [217.140.110.172]) by lindbergh.monkeyblade.net (Postfix) with ESMTP id 24B84E65; Mon, 24 Jul 2023 04:17:47 -0700 (PDT) Received: from usa-sjc-imap-foss1.foss.arm.com (unknown [10.121.207.14]) by usa-sjc-mx-foss1.foss.arm.com (Postfix) with ESMTP id B206CDE0; Mon, 24 Jul 2023 04:18:29 -0700 (PDT) Received: from [10.57.34.62] (unknown [10.57.34.62]) by usa-sjc-imap-foss1.foss.arm.com (Postfix) with ESMTPSA id C518B3F5A1; Mon, 24 Jul 2023 04:17:39 -0700 (PDT) Message-ID: Date: Mon, 24 Jul 2023 12:17:40 +0100 MIME-Version: 1.0 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:102.0) Gecko/20100101 Thunderbird/102.13.0 Subject: Re: [PATCH v2 24/47] drm/panfrost: dynamically allocate the drm-panfrost shrinker To: Qi Zheng , akpm@linux-foundation.org, david@fromorbit.com, tkhai@ya.ru, vbabka@suse.cz, roman.gushchin@linux.dev, djwong@kernel.org, brauner@kernel.org, paulmck@kernel.org, tytso@mit.edu, cel@kernel.org, senozhatsky@chromium.org, yujie.liu@intel.com, gregkh@linuxfoundation.org, muchun.song@linux.dev Cc: linux-kernel@vger.kernel.org, linux-mm@kvack.org, x86@kernel.org, kvm@vger.kernel.org, xen-devel@lists.xenproject.org, linux-erofs@lists.ozlabs.org, linux-f2fs-devel@lists.sourceforge.net, cluster-devel@redhat.com, linux-nfs@vger.kernel.org, linux-mtd@lists.infradead.org, rcu@vger.kernel.org, netdev@vger.kernel.org, dri-devel@lists.freedesktop.org, linux-arm-msm@vger.kernel.org, dm-devel@redhat.com, linux-raid@vger.kernel.org, linux-bcache@vger.kernel.org, virtualization@lists.linux-foundation.org, linux-fsdevel@vger.kernel.org, linux-ext4@vger.kernel.org, linux-xfs@vger.kernel.org, linux-btrfs@vger.kernel.org References: <20230724094354.90817-1-zhengqi.arch@bytedance.com> <20230724094354.90817-25-zhengqi.arch@bytedance.com> Content-Language: en-GB From: Steven Price In-Reply-To: <20230724094354.90817-25-zhengqi.arch@bytedance.com> Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 7bit X-Spam-Status: No, score=-4.3 required=5.0 tests=BAYES_00,NICE_REPLY_A, RCVD_IN_DNSWL_MED,SPF_HELO_NONE,SPF_NONE,T_SCC_BODY_TEXT_LINE autolearn=ham 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-nfs@vger.kernel.org On 24/07/2023 10:43, Qi Zheng wrote: > In preparation for implementing lockless slab shrink, use new APIs to > dynamically allocate the drm-panfrost shrinker, so that it can be freed > asynchronously using kfree_rcu(). Then it doesn't need to wait for RCU > read-side critical section when releasing the struct panfrost_device. > > Signed-off-by: Qi Zheng One nit below, but otherwise: Reviewed-by: Steven Price > --- > drivers/gpu/drm/panfrost/panfrost_device.h | 2 +- > drivers/gpu/drm/panfrost/panfrost_drv.c | 6 +++- > drivers/gpu/drm/panfrost/panfrost_gem.h | 2 +- > .../gpu/drm/panfrost/panfrost_gem_shrinker.c | 32 ++++++++++++------- > 4 files changed, 27 insertions(+), 15 deletions(-) > > diff --git a/drivers/gpu/drm/panfrost/panfrost_device.h b/drivers/gpu/drm/panfrost/panfrost_device.h > index b0126b9fbadc..e667e5689353 100644 > --- a/drivers/gpu/drm/panfrost/panfrost_device.h > +++ b/drivers/gpu/drm/panfrost/panfrost_device.h > @@ -118,7 +118,7 @@ struct panfrost_device { > > struct mutex shrinker_lock; > struct list_head shrinker_list; > - struct shrinker shrinker; > + struct shrinker *shrinker; > > struct panfrost_devfreq pfdevfreq; > }; > diff --git a/drivers/gpu/drm/panfrost/panfrost_drv.c b/drivers/gpu/drm/panfrost/panfrost_drv.c > index bbada731bbbd..f705bbdea360 100644 > --- a/drivers/gpu/drm/panfrost/panfrost_drv.c > +++ b/drivers/gpu/drm/panfrost/panfrost_drv.c > @@ -598,10 +598,14 @@ static int panfrost_probe(struct platform_device *pdev) > if (err < 0) > goto err_out1; > > - panfrost_gem_shrinker_init(ddev); > + err = panfrost_gem_shrinker_init(ddev); > + if (err) > + goto err_out2; > > return 0; > > +err_out2: > + drm_dev_unregister(ddev); > err_out1: > pm_runtime_disable(pfdev->dev); > panfrost_device_fini(pfdev); > diff --git a/drivers/gpu/drm/panfrost/panfrost_gem.h b/drivers/gpu/drm/panfrost/panfrost_gem.h > index ad2877eeeccd..863d2ec8d4f0 100644 > --- a/drivers/gpu/drm/panfrost/panfrost_gem.h > +++ b/drivers/gpu/drm/panfrost/panfrost_gem.h > @@ -81,7 +81,7 @@ panfrost_gem_mapping_get(struct panfrost_gem_object *bo, > void panfrost_gem_mapping_put(struct panfrost_gem_mapping *mapping); > void panfrost_gem_teardown_mappings_locked(struct panfrost_gem_object *bo); > > -void panfrost_gem_shrinker_init(struct drm_device *dev); > +int panfrost_gem_shrinker_init(struct drm_device *dev); > void panfrost_gem_shrinker_cleanup(struct drm_device *dev); > > #endif /* __PANFROST_GEM_H__ */ > diff --git a/drivers/gpu/drm/panfrost/panfrost_gem_shrinker.c b/drivers/gpu/drm/panfrost/panfrost_gem_shrinker.c > index bf0170782f25..9a90dfb5301f 100644 > --- a/drivers/gpu/drm/panfrost/panfrost_gem_shrinker.c > +++ b/drivers/gpu/drm/panfrost/panfrost_gem_shrinker.c > @@ -18,8 +18,7 @@ > static unsigned long > panfrost_gem_shrinker_count(struct shrinker *shrinker, struct shrink_control *sc) > { > - struct panfrost_device *pfdev = > - container_of(shrinker, struct panfrost_device, shrinker); > + struct panfrost_device *pfdev = shrinker->private_data; > struct drm_gem_shmem_object *shmem; > unsigned long count = 0; > > @@ -65,8 +64,7 @@ static bool panfrost_gem_purge(struct drm_gem_object *obj) > static unsigned long > panfrost_gem_shrinker_scan(struct shrinker *shrinker, struct shrink_control *sc) > { > - struct panfrost_device *pfdev = > - container_of(shrinker, struct panfrost_device, shrinker); > + struct panfrost_device *pfdev = shrinker->private_data; > struct drm_gem_shmem_object *shmem, *tmp; > unsigned long freed = 0; > > @@ -97,13 +95,24 @@ panfrost_gem_shrinker_scan(struct shrinker *shrinker, struct shrink_control *sc) > * > * This function registers and sets up the panfrost shrinker. > */ > -void panfrost_gem_shrinker_init(struct drm_device *dev) > +int panfrost_gem_shrinker_init(struct drm_device *dev) > { > struct panfrost_device *pfdev = dev->dev_private; > - pfdev->shrinker.count_objects = panfrost_gem_shrinker_count; > - pfdev->shrinker.scan_objects = panfrost_gem_shrinker_scan; > - pfdev->shrinker.seeks = DEFAULT_SEEKS; > - WARN_ON(register_shrinker(&pfdev->shrinker, "drm-panfrost")); > + > + pfdev->shrinker = shrinker_alloc(0, "drm-panfrost"); > + if (!pfdev->shrinker) { > + WARN_ON(1); I don't think this WARN_ON is particularly useful - if there's a failed memory allocation we should see output from the kernel anyway. And we're changing the semantics from "continue just without a shrinker" (which argueably justifies the warning) to "probe fails, device doesn't work" which will be obvious to the user so I don't feel we need the additional warn. > + return -ENOMEM; > + } > + > + pfdev->shrinker->count_objects = panfrost_gem_shrinker_count; > + pfdev->shrinker->scan_objects = panfrost_gem_shrinker_scan; > + pfdev->shrinker->seeks = DEFAULT_SEEKS; > + pfdev->shrinker->private_data = pfdev; > + > + shrinker_register(pfdev->shrinker); > + > + return 0; > } > > /** > @@ -116,7 +125,6 @@ void panfrost_gem_shrinker_cleanup(struct drm_device *dev) > { > struct panfrost_device *pfdev = dev->dev_private; > > - if (pfdev->shrinker.nr_deferred) { > - unregister_shrinker(&pfdev->shrinker); > - } > + if (pfdev->shrinker) > + shrinker_unregister(pfdev->shrinker); > }