Received: by 2002:a25:1506:0:0:0:0:0 with SMTP id 6csp6212520ybv; Tue, 18 Feb 2020 12:07:55 -0800 (PST) X-Google-Smtp-Source: APXvYqzuEHleiFXeS9Eo4mBeKojFgnCWmJL+iY//LNn1lGnLxevb4sVHQV+Clb83wSjkLoDfflYr X-Received: by 2002:a05:6830:2361:: with SMTP id r1mr16307450oth.88.1582056475650; Tue, 18 Feb 2020 12:07:55 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1582056475; cv=none; d=google.com; s=arc-20160816; b=ENG8U79gpsFajyOVTf9wbKMt9xS0QwnsxifXk9BMnhdfwr84bkgjvVwYNzmd7jdHqX O99er6u5P4q5qGrjjg0PaL5ARCHO5tVuxp5W9UjFNJZNi1e0/GelgCkKz4zsToWwR5yj vQ2/iNRrf+PlL4eBHRo8LfvRzmOkIa3JLJniKpjz9oDVz5tImRr7Niv+keMt/E6yYpnc Ga/bDgTaAHW9gdvkbxrr0INIcjHkmysToEcrwiUkgp7r141TVKRYTYGOe23mdE5HIk4i D0AlqtgLdGfAWed1Yxo6wnLbzn2ZFBQKtryh3cFKXjMUpWVtveprpTSakE4lwpoY/84s X0RA== 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=OMSE5El6Enj2YR1w653BkRjC/0QZNEgCrzg1B/D0FUA=; b=FH3vibEWq60+HP9ZwoCnvLl4aLB89PSntDRoTvfplhkXGs6jGFflnkj6YSMEf6dQ2u WqqDZy4/qWpY4yJsyj7BL2CStMZYKW0Al7ZmPUH2nGbUGXo3o1Cbhg3VnuWR3N8qFMM+ L+gCEXYKYcza/xO3NXX1mcUss4BN2bqR9opwaicVFB3NemjlJjBSiFPIfW4oWj2tZYjk C9e5I68FFJe6553tEMoDBRGMIMLqjwmBxSilHgGu7UOjY8Slh63v1afuHP4EuGta2u+n kkl/ITr/ucVvSzWhjhP5gPewII0bn5dM1RTWirIBBxqYre5wXT31pvdE/tDIfpO1lhKf h6uw== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=HPprocoH; 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 j2si2072890otr.255.2020.02.18.12.07.43; Tue, 18 Feb 2020 12:07:55 -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=HPprocoH; 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 S1728310AbgBRT6v (ORCPT + 99 others); Tue, 18 Feb 2020 14:58:51 -0500 Received: from mail.kernel.org ([198.145.29.99]:36740 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1728301AbgBRT6u (ORCPT ); Tue, 18 Feb 2020 14:58:50 -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 7331324125; Tue, 18 Feb 2020 19:58:49 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=default; t=1582055929; bh=VXS9ycr6wu/QTgmXZxZM+8/LTsMlAdSZjeqbUw8H8Gc=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=HPprocoHjYHRtz9u6MMLmmGbgdci87xp6HQnQXE68aE1tRaJdzP3LWFYzzFBRayKA amVOUTgh//cWn7JPUV+BQ21lOfqEoQre7+2tBT66f4LdWw/1/VSkvH/GQVvAwGGGYN judDIDR6/PxvLYjyQRJaPmTrGdHbdNi3CaA1uXcc= 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.4 35/66] drm/panfrost: Make sure the shrinker does not reclaim referenced BOs Date: Tue, 18 Feb 2020 20:55:02 +0100 Message-Id: <20200218190431.301556622@linuxfoundation.org> X-Mailer: git-send-email 2.25.1 In-Reply-To: <20200218190428.035153861@linuxfoundation.org> References: <20200218190428.035153861@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 @@ -270,8 +270,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); }