Received: by 2002:ac0:950c:0:0:0:0:0 with SMTP id f12csp2309670imc; Tue, 12 Mar 2019 11:06:09 -0700 (PDT) X-Google-Smtp-Source: APXvYqy5ftXiCGpya1mhFWGiE7bXFUxtdsziq9vA+yyz7rXB0XVIiedSCsMn0Es5OlXhfLsK93UK X-Received: by 2002:a62:1283:: with SMTP id 3mr40821480pfs.122.1552413969487; Tue, 12 Mar 2019 11:06:09 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1552413969; cv=none; d=google.com; s=arc-20160816; b=CiXfAh66Nk4xZIlQcAjYiuCpk346ad2yAm2cV8RP753dOz8+U07YLM0TIgJLymChPz 9jpV5luodYzbpkTCtJ0P/69RTSSA3A34Poul3zj23gds5X/53IZCeyK9dzoXoq+D0isH CDaIuzcuD9iDfGWD4un/DVwtsmb83VOTZQhm39x5YgyfqE+p1EGmkEJdzyZ+A1MOz3v/ 7/P3UpxjV8UYuuZJFlsh7TO5rFwzQTvK0nAx5ogJjnlPEZL8AJT0Hz8YLLiobYWZ7xEk GewMUoMjJqdspKgPVoErJZyIpKL2JXwuGa1MN6TGMGz9i2epTRq7K5ktaD+D/DxYM6MF SLVQ== 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=ArvGlJC7SN25SSFrtOE98uzIEHTHpoUTLzgT6ascirI=; b=qxEbtI2hm6pTsavOg+5ivlALk04vRfMXyrdV/GKkLXYolsKBPF5+6MbrzviALInLye nUvpI9bnypNq2f8jpVNy/NcbR2bGTFhZtCuBgk8ZIGtiCzrAya5HYOPcJhxVDBkimA2t /ox72R+4uav2YganptlpxTyEhrpz93YZiY9ZQwSgI/YjFOFkGo77eyuWMOPlgf+oIrpy zrq1QICt2Ok3C3Zcj6a6N/xqFyWYk3F1WVnD8FTOxtUUJM+3R7XhfjrzFu0UTwH0Oa2Q j8Kbr5wNBzFElFBPOGvgXyDrO3ErXfBG7Pod6BPXF72vboowGEiPngm0yJR+bg2pTjbb hmvQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=cQWPzeyA; 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 u3si8198943pgi.275.2019.03.12.11.05.53; Tue, 12 Mar 2019 11:06:09 -0700 (PDT) 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=cQWPzeyA; 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 S1728506AbfCLSDd (ORCPT + 99 others); Tue, 12 Mar 2019 14:03:33 -0400 Received: from mail.kernel.org ([198.145.29.99]:48892 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1727685AbfCLRMz (ORCPT ); Tue, 12 Mar 2019 13:12:55 -0400 Received: from localhost (unknown [104.133.8.98]) (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 9B4A4217D8; Tue, 12 Mar 2019 17:12:53 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=default; t=1552410773; bh=YAS7rbk2w4BoFsfE17iaQzeXeoOHn+dkr7vPk7J0dGU=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=cQWPzeyA+Qwhm2BmlthK9nvw63YlO+qIbKIc/DZ8K6WZItR2rfOT5CK+Ar70qb77b NSr3EuEy7Yg96HuI8mn68Ldndlc5HILeN8JR2OCYeonunyaI/tZlKinJVRQOiZau1X PoDX3ch4m921He9jWzKNUB72l3J3d99sH4Zh5HEw= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, Chris Wilson , Alex Deucher , =?UTF-8?q?Christian=20K=C3=B6nig?= , Sasha Levin Subject: [PATCH 4.20 103/171] drm/amdgpu: Transfer fences to dmabuf importer Date: Tue, 12 Mar 2019 10:08:03 -0700 Message-Id: <20190312170356.947364270@linuxfoundation.org> X-Mailer: git-send-email 2.21.0 In-Reply-To: <20190312170347.868927101@linuxfoundation.org> References: <20190312170347.868927101@linuxfoundation.org> User-Agent: quilt/0.65 X-stable: review X-Patchwork-Hint: ignore 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 4.20-stable review patch. If anyone has any objections, please let me know. ------------------ [ Upstream commit 6e11ea9de9576a644045ffdc2067c09bc2012eda ] amdgpu only uses shared-fences internally, but dmabuf importers rely on implicit write hazard tracking via the reservation_object.fence_excl. For example, the importer use the write hazard for timing a page flip to only occur after the exporter has finished flushing its write into the surface. As such, on exporting a dmabuf, we must either flush all outstanding fences (for we do not know which are writes and should have been exclusive) or alternatively create a new exclusive fence that is the composite of all the existing shared fences, and so will only be signaled when all earlier fences are signaled (ensuring that we can not be signaled before the completion of any earlier write). v2: reservation_object is already locked by amdgpu_bo_reserve() v3: Replace looping with get_fences_rcu and special case the promotion of a single shared fence directly to an exclusive fence, bypassing the fence array. v4: Drop the fence array ref after assigning to reservation_object Bugzilla: https://bugs.freedesktop.org/show_bug.cgi?id=107341 Testcase: igt/amd_prime/amd-to-i915 References: 8e94a46c1770 ("drm/amdgpu: Attach exclusive fence to prime exported bo's. (v5)") Signed-off-by: Chris Wilson Cc: Alex Deucher Cc: "Christian König" Reviewed-by: "Christian König" Signed-off-by: Alex Deucher Signed-off-by: Sasha Levin --- drivers/gpu/drm/amd/amdgpu/amdgpu_prime.c | 59 ++++++++++++++++++++--- 1 file changed, 51 insertions(+), 8 deletions(-) diff --git a/drivers/gpu/drm/amd/amdgpu/amdgpu_prime.c b/drivers/gpu/drm/amd/amdgpu/amdgpu_prime.c index e45e929aaab5..90a5970af4b7 100644 --- a/drivers/gpu/drm/amd/amdgpu/amdgpu_prime.c +++ b/drivers/gpu/drm/amd/amdgpu/amdgpu_prime.c @@ -38,6 +38,7 @@ #include "amdgpu_gem.h" #include #include +#include static const struct dma_buf_ops amdgpu_dmabuf_ops; @@ -189,6 +190,48 @@ amdgpu_gem_prime_import_sg_table(struct drm_device *dev, return ERR_PTR(ret); } +static int +__reservation_object_make_exclusive(struct reservation_object *obj) +{ + struct dma_fence **fences; + unsigned int count; + int r; + + if (!reservation_object_get_list(obj)) /* no shared fences to convert */ + return 0; + + r = reservation_object_get_fences_rcu(obj, NULL, &count, &fences); + if (r) + return r; + + if (count == 0) { + /* Now that was unexpected. */ + } else if (count == 1) { + reservation_object_add_excl_fence(obj, fences[0]); + dma_fence_put(fences[0]); + kfree(fences); + } else { + struct dma_fence_array *array; + + array = dma_fence_array_create(count, fences, + dma_fence_context_alloc(1), 0, + false); + if (!array) + goto err_fences_put; + + reservation_object_add_excl_fence(obj, &array->base); + dma_fence_put(&array->base); + } + + return 0; + +err_fences_put: + while (count--) + dma_fence_put(fences[count]); + kfree(fences); + return -ENOMEM; +} + /** * amdgpu_gem_map_attach - &dma_buf_ops.attach implementation * @dma_buf: Shared DMA buffer @@ -220,16 +263,16 @@ static int amdgpu_gem_map_attach(struct dma_buf *dma_buf, if (attach->dev->driver != adev->dev->driver) { /* - * Wait for all shared fences to complete before we switch to future - * use of exclusive fence on this prime shared bo. + * We only create shared fences for internal use, but importers + * of the dmabuf rely on exclusive fences for implicitly + * tracking write hazards. As any of the current fences may + * correspond to a write, we need to convert all existing + * fences on the reservation object into a single exclusive + * fence. */ - r = reservation_object_wait_timeout_rcu(bo->tbo.resv, - true, false, - MAX_SCHEDULE_TIMEOUT); - if (unlikely(r < 0)) { - DRM_DEBUG_PRIME("Fence wait failed: %li\n", r); + r = __reservation_object_make_exclusive(bo->tbo.resv); + if (r) goto error_unreserve; - } } /* pin buffer into GTT */ -- 2.19.1