Received: by 2002:a25:1506:0:0:0:0:0 with SMTP id 6csp6206633ybv; Tue, 18 Feb 2020 12:02:14 -0800 (PST) X-Google-Smtp-Source: APXvYqwibVuBTZ47PZxNXm6N1VycG2MVl4ktxKz3Y4eQjopE/X6Oj4lAOuqRfNU0MOpEE6JmaA/T X-Received: by 2002:a05:6830:606:: with SMTP id w6mr17453819oti.323.1582056134467; Tue, 18 Feb 2020 12:02:14 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1582056134; cv=none; d=google.com; s=arc-20160816; b=kvbOpi3ihzOvfwZLNWUlRzbvmJw37H30HW/CmvJKA2B7LrlWd18E3HHxm2p8dHuyeH aIT6cQh5FjZLhK2CIny7L+XjkHMN1KU9G61Slyj/szAHPiSaHn2M6ArbMCZm0aOWvpyJ DfXrELbSsAirt1AhCkudlD83scMDauggJzWAq1sXNse/BAIORK4SgAt2LxldtGceySZM VN+pIQWa09V77WJOXFOfCH690vT7aFS8iDEbfGNZ6O+WeqLDG6L8AQkZkpaK+A4xDb9a 9AbT8QIOdPUs+qospR+QTqJkfvLSLQIDJ7o4Ff10B0NcYnCuPgLUjstwjx47rwQHmoPE uosg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-transfer-encoding:mime-version :user-agent:references:in-reply-to:message-id:date:subject:cc:to :from:dkim-signature; bh=gCmUgYT5GecIKA0uiMewHLQTzq20j9B43Jryy1Wy9ek=; b=qQp6kDsUzocxXPCVycnxVX3qhhoreEnZatAdiElGuj/6CjrZuc102F9hQJIOCMnfG5 Flk4QRnMretsKXkNphJF6SkQhLSvOpXQux1102HwB4s5KqB+wcWgU6KabUWGeuHs05ob eRQsAlodM91nIy4PLApmzZhSMgsYnNM9bNr38QXaV+fIuHR+scD02NswIQ3LFOz4ab0n yCq2Y7RxyHTJSJkNVxGCLeLzUOhzh5WWiBHXQsWg3TTvXJnVZ9aT9kzoG1IbZTlgC1uA cXeaeXx5Gz7fWbmFhZvnb3u18i2MShVcHscoMn4Gjz7GB1cOTAd8IfuOudPVw9NJnI8U p0sw== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=jkOXhjIs; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id j143si8634950oib.16.2020.02.18.12.02.02; Tue, 18 Feb 2020 12:02:14 -0800 (PST) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=jkOXhjIs; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1728426AbgBRUCA (ORCPT + 99 others); Tue, 18 Feb 2020 15:02:00 -0500 Received: from mail.kernel.org ([198.145.29.99]:41824 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1728847AbgBRUB6 (ORCPT ); Tue, 18 Feb 2020 15:01:58 -0500 Received: from localhost (83-86-89-107.cable.dynamic.v4.ziggo.nl [83.86.89.107]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by mail.kernel.org (Postfix) with ESMTPSA id 9B1862465D; Tue, 18 Feb 2020 20:01:57 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=default; t=1582056118; bh=MsuaI/HgEQAFlCw8QnXlY0IG7Q+77tzdvi9ttefGTN0=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=jkOXhjIsraZ1/h03HU5PL9/hLZar3OAG87/+9XeC8Rmr0eH3Cdxdls7tGNp7Gdm+X WpmOVIhTkaGZal3fTvxdRELGveTcEIKsmxtMAE50F3ZN0eLdgDU44CALHThfkSBJJj wbhVwAEX9rGylRdKurMcJzTmBT/r3av7a7FsV8rA= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, Boris Brezillon , Steven Price , Rob Herring Subject: [PATCH 5.5 42/80] drm/panfrost: Make sure the shrinker does not reclaim referenced BOs Date: Tue, 18 Feb 2020 20:55:03 +0100 Message-Id: <20200218190436.393793164@linuxfoundation.org> X-Mailer: git-send-email 2.25.1 In-Reply-To: <20200218190432.043414522@linuxfoundation.org> References: <20200218190432.043414522@linuxfoundation.org> User-Agent: quilt/0.66 MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Boris Brezillon commit 7e0cf7e9936c4358b0863357b90aa12afe6489da upstream. Userspace might tag a BO purgeable while it's still referenced by GPU jobs. We need to make sure the shrinker does not purge such BOs until all jobs referencing it are finished. Fixes: 013b65101315 ("drm/panfrost: Add madvise and shrinker support") Cc: Signed-off-by: Boris Brezillon Reviewed-by: Steven Price Signed-off-by: Rob Herring Link: https://patchwork.freedesktop.org/patch/msgid/20191129135908.2439529-9-boris.brezillon@collabora.com Signed-off-by: Greg Kroah-Hartman --- drivers/gpu/drm/panfrost/panfrost_drv.c | 1 + drivers/gpu/drm/panfrost/panfrost_gem.h | 6 ++++++ drivers/gpu/drm/panfrost/panfrost_gem_shrinker.c | 3 +++ drivers/gpu/drm/panfrost/panfrost_job.c | 7 ++++++- 4 files changed, 16 insertions(+), 1 deletion(-) --- a/drivers/gpu/drm/panfrost/panfrost_drv.c +++ b/drivers/gpu/drm/panfrost/panfrost_drv.c @@ -166,6 +166,7 @@ panfrost_lookup_bos(struct drm_device *d break; } + atomic_inc(&bo->gpu_usecount); job->mappings[i] = mapping; } --- a/drivers/gpu/drm/panfrost/panfrost_gem.h +++ b/drivers/gpu/drm/panfrost/panfrost_gem.h @@ -30,6 +30,12 @@ struct panfrost_gem_object { struct mutex lock; } mappings; + /* + * Count the number of jobs referencing this BO so we don't let the + * shrinker reclaim this object prematurely. + */ + atomic_t gpu_usecount; + bool noexec :1; bool is_heap :1; }; --- a/drivers/gpu/drm/panfrost/panfrost_gem_shrinker.c +++ b/drivers/gpu/drm/panfrost/panfrost_gem_shrinker.c @@ -41,6 +41,9 @@ static bool panfrost_gem_purge(struct dr struct drm_gem_shmem_object *shmem = to_drm_gem_shmem_obj(obj); struct panfrost_gem_object *bo = to_panfrost_bo(obj); + if (atomic_read(&bo->gpu_usecount)) + return false; + if (!mutex_trylock(&shmem->pages_lock)) return false; --- a/drivers/gpu/drm/panfrost/panfrost_job.c +++ b/drivers/gpu/drm/panfrost/panfrost_job.c @@ -269,8 +269,13 @@ static void panfrost_job_cleanup(struct dma_fence_put(job->render_done_fence); if (job->mappings) { - for (i = 0; i < job->bo_count; i++) + for (i = 0; i < job->bo_count; i++) { + if (!job->mappings[i]) + break; + + atomic_dec(&job->mappings[i]->obj->gpu_usecount); panfrost_gem_mapping_put(job->mappings[i]); + } kvfree(job->mappings); }