All of lore.kernel.org
 help / color / mirror / Atom feed
* [PATCH] drm/amdgpu/gfx10: re-init clear state buffer after gpu reset
@ 2019-11-20  6:47 ` Xiaojie Yuan
  0 siblings, 0 replies; 26+ messages in thread
From: Xiaojie Yuan @ 2019-11-20  6:47 UTC (permalink / raw)
  To: amd-gfx-PD4FTy7X32lNgt0PjOBp9y5qC8QIuHrW
  Cc: gang.long-5C7GfCeVMHo, jack.xiao-5C7GfCeVMHo, Xiaojie Yuan,
	hawking.zhang-5C7GfCeVMHo

This patch fixes 2nd baco reset failure with gfxoff enabled on navi1x.

clear state buffer (resides in vram) is corrupted after 1st baco reset,
upon gfxoff exit, CPF gets garbage header in CSIB and hangs.

Signed-off-by: Xiaojie Yuan <xiaojie.yuan@amd.com>
---
 drivers/gpu/drm/amd/amdgpu/gfx_v10_0.c | 43 ++++++++++++++++++++++----
 1 file changed, 37 insertions(+), 6 deletions(-)

diff --git a/drivers/gpu/drm/amd/amdgpu/gfx_v10_0.c b/drivers/gpu/drm/amd/amdgpu/gfx_v10_0.c
index 9274bd4b6c68..8e24ea08ca39 100644
--- a/drivers/gpu/drm/amd/amdgpu/gfx_v10_0.c
+++ b/drivers/gpu/drm/amd/amdgpu/gfx_v10_0.c
@@ -1789,27 +1789,52 @@ static void gfx_v10_0_enable_gui_idle_interrupt(struct amdgpu_device *adev,
 	WREG32_SOC15(GC, 0, mmCP_INT_CNTL_RING0, tmp);
 }
 
-static void gfx_v10_0_init_csb(struct amdgpu_device *adev)
+static int gfx_v10_0_init_csb(struct amdgpu_device *adev)
 {
+	int r;
+
+	if (adev->in_gpu_reset) {
+		r = amdgpu_bo_reserve(adev->gfx.rlc.clear_state_obj, false);
+		if (r)
+			return r;
+
+		r = amdgpu_bo_kmap(adev->gfx.rlc.clear_state_obj,
+				   (void **)&adev->gfx.rlc.cs_ptr);
+		if (!r) {
+			adev->gfx.rlc.funcs->get_csb_buffer(adev,
+					adev->gfx.rlc.cs_ptr);
+			amdgpu_bo_kunmap(adev->gfx.rlc.clear_state_obj);
+		}
+
+		amdgpu_bo_unreserve(adev->gfx.rlc.clear_state_obj);
+		if (r)
+			return r;
+	}
+
 	/* csib */
 	WREG32_SOC15(GC, 0, mmRLC_CSIB_ADDR_HI,
 		     adev->gfx.rlc.clear_state_gpu_addr >> 32);
 	WREG32_SOC15(GC, 0, mmRLC_CSIB_ADDR_LO,
 		     adev->gfx.rlc.clear_state_gpu_addr & 0xfffffffc);
 	WREG32_SOC15(GC, 0, mmRLC_CSIB_LENGTH, adev->gfx.rlc.clear_state_size);
+
+	return 0;
 }
 
-static void gfx_v10_0_init_pg(struct amdgpu_device *adev)
+static int gfx_v10_0_init_pg(struct amdgpu_device *adev)
 {
 	int i;
+	int r;
 
-	gfx_v10_0_init_csb(adev);
+	r = gfx_v10_0_init_csb(adev);
+	if (r)
+		return r;
 
 	for (i = 0; i < adev->num_vmhubs; i++)
 		amdgpu_gmc_flush_gpu_tlb(adev, 0, i, 0);
 
 	/* TODO: init power gating */
-	return;
+	return 0;
 }
 
 void gfx_v10_0_rlc_stop(struct amdgpu_device *adev)
@@ -1911,7 +1936,10 @@ static int gfx_v10_0_rlc_resume(struct amdgpu_device *adev)
 		r = gfx_v10_0_wait_for_rlc_autoload_complete(adev);
 		if (r)
 			return r;
-		gfx_v10_0_init_pg(adev);
+
+		r = gfx_v10_0_init_pg(adev);
+		if (r)
+			return r;
 
 		/* enable RLC SRM */
 		gfx_v10_0_rlc_enable_srm(adev);
@@ -1937,7 +1965,10 @@ static int gfx_v10_0_rlc_resume(struct amdgpu_device *adev)
 				return r;
 		}
 
-		gfx_v10_0_init_pg(adev);
+		r = gfx_v10_0_init_pg(adev);
+		if (r)
+			return r;
+
 		adev->gfx.rlc.funcs->start(adev);
 
 		if (adev->firmware.load_type == AMDGPU_FW_LOAD_RLC_BACKDOOR_AUTO) {
-- 
2.20.1

_______________________________________________
amd-gfx mailing list
amd-gfx@lists.freedesktop.org
https://lists.freedesktop.org/mailman/listinfo/amd-gfx

^ permalink raw reply related	[flat|nested] 26+ messages in thread

end of thread, other threads:[~2019-11-21  2:26 UTC | newest]

Thread overview: 26+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2019-11-20  6:47 [PATCH] drm/amdgpu/gfx10: re-init clear state buffer after gpu reset Xiaojie Yuan
2019-11-20  6:47 ` Xiaojie Yuan
     [not found] ` <20191120064701.2765-1-xiaojie.yuan-5C7GfCeVMHo@public.gmane.org>
2019-11-20  8:43   ` Zhang, Hawking
2019-11-20  8:43     ` Zhang, Hawking
     [not found]     ` <DM5PR12MB1418A32EB8199ABFFCCAEC04FC4F0-2J9CzHegvk81aAVlcVN8UQdYzm3356FpvxpqHgZTriW3zl9H0oFU5g@public.gmane.org>
2019-11-20  8:45       ` Zhang, Hawking
2019-11-20  8:45         ` Zhang, Hawking
     [not found]         ` <DM5PR12MB14185B32B9CB4356233E5903FC4F0-2J9CzHegvk81aAVlcVN8UQdYzm3356FpvxpqHgZTriW3zl9H0oFU5g@public.gmane.org>
2019-11-20  8:47           ` Christian König
2019-11-20  8:47             ` Christian König
     [not found]             ` <01af7844-2fbe-fd1a-5662-c8a9ec5812f0-Re5JQEeQqe8AvxtiuMwx3w@public.gmane.org>
2019-11-20  8:54               ` Zhang, Hawking
2019-11-20  8:54                 ` Zhang, Hawking
     [not found]                 ` <DM5PR12MB141866D265D123D18E289329FC4F0-2J9CzHegvk81aAVlcVN8UQdYzm3356FpvxpqHgZTriW3zl9H0oFU5g@public.gmane.org>
2019-11-20  8:57                   ` Christian König
2019-11-20  8:57                     ` Christian König
2019-11-20  9:00                   ` Yuan, Xiaojie
2019-11-20  9:00                     ` Yuan, Xiaojie
     [not found]                     ` <MN2PR12MB3087E12C851C8A4B9BD1E6BA894F0-rweVpJHSKTpSqPH+ASrJYAdYzm3356FpvxpqHgZTriW3zl9H0oFU5g@public.gmane.org>
2019-11-20  9:04                       ` Zhang, Hawking
2019-11-20  9:04                         ` Zhang, Hawking
     [not found]                         ` <DM5PR12MB14182D46CB31725D29877954FC4F0-2J9CzHegvk81aAVlcVN8UQdYzm3356FpvxpqHgZTriW3zl9H0oFU5g@public.gmane.org>
2019-11-20  9:09                           ` Yuan, Xiaojie
2019-11-20  9:09                             ` Yuan, Xiaojie
     [not found]                             ` <MN2PR12MB3087B08DD3C6F496F4F37C52894F0-rweVpJHSKTpSqPH+ASrJYAdYzm3356FpvxpqHgZTriW3zl9H0oFU5g@public.gmane.org>
2019-11-21  1:28                               ` Quan, Evan
2019-11-21  1:28                                 ` Quan, Evan
     [not found]                                 ` <MN2PR12MB3344E669C43F9B6577D60AA8E44E0-rweVpJHSKToDMgCC8P//OwdYzm3356FpvxpqHgZTriW3zl9H0oFU5g@public.gmane.org>
2019-11-21  2:26                                   ` Yuan, Xiaojie
2019-11-21  2:26                                     ` Yuan, Xiaojie
2019-11-20  8:56       ` Yuan, Xiaojie
2019-11-20  8:56         ` Yuan, Xiaojie
     [not found]         ` <MN2PR12MB308747C45983374E17E1BD17894F0-rweVpJHSKTpSqPH+ASrJYAdYzm3356FpvxpqHgZTriW3zl9H0oFU5g@public.gmane.org>
2019-11-20  9:03           ` Zhang, Hawking
2019-11-20  9:03             ` Zhang, Hawking

This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.