diff options
Diffstat (limited to 'meta-amd-bsp/recipes-kernel/linux/linux-yocto-4.19.8/2242-drm-amdgpu-add-JPEG2.0-decode-ring-test.patch')
-rw-r--r-- | meta-amd-bsp/recipes-kernel/linux/linux-yocto-4.19.8/2242-drm-amdgpu-add-JPEG2.0-decode-ring-test.patch | 71 |
1 files changed, 71 insertions, 0 deletions
diff --git a/meta-amd-bsp/recipes-kernel/linux/linux-yocto-4.19.8/2242-drm-amdgpu-add-JPEG2.0-decode-ring-test.patch b/meta-amd-bsp/recipes-kernel/linux/linux-yocto-4.19.8/2242-drm-amdgpu-add-JPEG2.0-decode-ring-test.patch new file mode 100644 index 00000000..345d4f22 --- /dev/null +++ b/meta-amd-bsp/recipes-kernel/linux/linux-yocto-4.19.8/2242-drm-amdgpu-add-JPEG2.0-decode-ring-test.patch @@ -0,0 +1,71 @@ +From b650113c75e15e9b76a27e6c0dfcfd54b70b27a5 Mon Sep 17 00:00:00 2001 +From: Leo Liu <leo.liu@amd.com> +Date: Mon, 3 Dec 2018 11:42:28 -0500 +Subject: [PATCH 2242/2940] drm/amdgpu: add JPEG2.0 decode ring test + +Use register from JPEG tile, the UVD tile reg won't work for JPEG + +Signed-off-by: Leo Liu <leo.liu@amd.com> +Reviewed-by: Alex Deucher <alexander.deucher@amd.com> +Signed-off-by: Alex Deucher <alexander.deucher@amd.com> +--- + drivers/gpu/drm/amd/amdgpu/amdgpu_vcn.c | 8 +++----- + drivers/gpu/drm/amd/amdgpu/amdgpu_vcn.h | 1 + + drivers/gpu/drm/amd/amdgpu/vcn_v1_0.c | 2 ++ + 3 files changed, 6 insertions(+), 5 deletions(-) + +diff --git a/drivers/gpu/drm/amd/amdgpu/amdgpu_vcn.c b/drivers/gpu/drm/amd/amdgpu/amdgpu_vcn.c +index 1d575e2e701b..ef2b7a9356ef 100644 +--- a/drivers/gpu/drm/amd/amdgpu/amdgpu_vcn.c ++++ b/drivers/gpu/drm/amd/amdgpu/amdgpu_vcn.c +@@ -631,19 +631,17 @@ int amdgpu_vcn_jpeg_ring_test_ring(struct amdgpu_ring *ring) + unsigned i; + int r; + +- WREG32(SOC15_REG_OFFSET(UVD, 0, mmUVD_SCRATCH9), 0xCAFEDEAD); ++ WREG32(adev->vcn.external.jpeg_pitch, 0xCAFEDEAD); + r = amdgpu_ring_alloc(ring, 3); +- + if (r) + return r; + +- amdgpu_ring_write(ring, +- PACKETJ(SOC15_REG_OFFSET(UVD, 0, mmUVD_SCRATCH9), 0, 0, 0)); ++ amdgpu_ring_write(ring, PACKET0(adev->vcn.internal.jpeg_pitch, 0)); + amdgpu_ring_write(ring, 0xDEADBEEF); + amdgpu_ring_commit(ring); + + for (i = 0; i < adev->usec_timeout; i++) { +- tmp = RREG32(SOC15_REG_OFFSET(UVD, 0, mmUVD_SCRATCH9)); ++ tmp = RREG32(adev->vcn.external.jpeg_pitch); + if (tmp == 0xDEADBEEF) + break; + DRM_UDELAY(1); +diff --git a/drivers/gpu/drm/amd/amdgpu/amdgpu_vcn.h b/drivers/gpu/drm/amd/amdgpu/amdgpu_vcn.h +index b14655a0e1db..cc94841f2f06 100644 +--- a/drivers/gpu/drm/amd/amdgpu/amdgpu_vcn.h ++++ b/drivers/gpu/drm/amd/amdgpu/amdgpu_vcn.h +@@ -93,6 +93,7 @@ struct amdgpu_vcn_reg{ + unsigned cmd; + unsigned nop; + unsigned scratch9; ++ unsigned jpeg_pitch; + }; + + struct amdgpu_vcn { +diff --git a/drivers/gpu/drm/amd/amdgpu/vcn_v1_0.c b/drivers/gpu/drm/amd/amdgpu/vcn_v1_0.c +index 2a2c40cf32c8..855b1f9609e4 100644 +--- a/drivers/gpu/drm/amd/amdgpu/vcn_v1_0.c ++++ b/drivers/gpu/drm/amd/amdgpu/vcn_v1_0.c +@@ -154,6 +154,8 @@ static int vcn_v1_0_sw_init(void *handle) + return r; + + adev->vcn.pause_dpg_mode = vcn_v1_0_pause_dpg_mode; ++ adev->vcn.internal.jpeg_pitch = adev->vcn.external.jpeg_pitch = ++ SOC15_REG_OFFSET(UVD, 0, mmUVD_JPEG_PITCH); + + return 0; + } +-- +2.17.1 + |