diff options
Diffstat (limited to 'common/recipes-kernel/linux/linux-yocto-4.19.8/0183-drm-amdgpu-Only-retrieve-GPU-address-of-GART-table-a.patch')
-rw-r--r-- | common/recipes-kernel/linux/linux-yocto-4.19.8/0183-drm-amdgpu-Only-retrieve-GPU-address-of-GART-table-a.patch | 94 |
1 files changed, 94 insertions, 0 deletions
diff --git a/common/recipes-kernel/linux/linux-yocto-4.19.8/0183-drm-amdgpu-Only-retrieve-GPU-address-of-GART-table-a.patch b/common/recipes-kernel/linux/linux-yocto-4.19.8/0183-drm-amdgpu-Only-retrieve-GPU-address-of-GART-table-a.patch new file mode 100644 index 00000000..a028de2e --- /dev/null +++ b/common/recipes-kernel/linux/linux-yocto-4.19.8/0183-drm-amdgpu-Only-retrieve-GPU-address-of-GART-table-a.patch @@ -0,0 +1,94 @@ +From 2e3a0c000e7f6da0aedd2fdefd2675803ff952cf Mon Sep 17 00:00:00 2001 +From: =?UTF-8?q?Michel=20D=C3=A4nzer?= <michel.daenzer@amd.com> +Date: Tue, 28 Aug 2018 11:26:17 +0200 +Subject: [PATCH 0183/2940] drm/amdgpu: Only retrieve GPU address of GART table + after pinning it +MIME-Version: 1.0 +Content-Type: text/plain; charset=UTF-8 +Content-Transfer-Encoding: 8bit + +Doing it earlier hits a WARN_ON_ONCE in amdgpu_bo_gpu_offset. + +Fixes: "drm/amdgpu: remove gart.table_addr" + +Reviewed-by: Christian König <christian.koenig@amd.com> +Signed-off-by: Michel Dänzer <michel.daenzer@amd.com> +Signed-off-by: Alex Deucher <alexander.deucher@amd.com> +--- + drivers/gpu/drm/amd/amdgpu/gmc_v6_0.c | 5 ++++- + drivers/gpu/drm/amd/amdgpu/gmc_v7_0.c | 5 ++++- + drivers/gpu/drm/amd/amdgpu/gmc_v8_0.c | 5 ++++- + 3 files changed, 12 insertions(+), 3 deletions(-) + +diff --git a/drivers/gpu/drm/amd/amdgpu/gmc_v6_0.c b/drivers/gpu/drm/amd/amdgpu/gmc_v6_0.c +index b2aee4c95720..bddf94a88b9b 100644 +--- a/drivers/gpu/drm/amd/amdgpu/gmc_v6_0.c ++++ b/drivers/gpu/drm/amd/amdgpu/gmc_v6_0.c +@@ -495,7 +495,7 @@ static void gmc_v6_0_set_prt(struct amdgpu_device *adev, bool enable) + + static int gmc_v6_0_gart_enable(struct amdgpu_device *adev) + { +- uint64_t table_addr = amdgpu_bo_gpu_offset(adev->gart.bo); ++ uint64_t table_addr; + int r, i; + u32 field; + +@@ -506,6 +506,9 @@ static int gmc_v6_0_gart_enable(struct amdgpu_device *adev) + r = amdgpu_gart_table_vram_pin(adev); + if (r) + return r; ++ ++ table_addr = amdgpu_bo_gpu_offset(adev->gart.bo); ++ + /* Setup TLB control */ + WREG32(mmMC_VM_MX_L1_TLB_CNTL, + (0xA << 7) | +diff --git a/drivers/gpu/drm/amd/amdgpu/gmc_v7_0.c b/drivers/gpu/drm/amd/amdgpu/gmc_v7_0.c +index 2c6ad2b624b6..e3c725ba3dae 100644 +--- a/drivers/gpu/drm/amd/amdgpu/gmc_v7_0.c ++++ b/drivers/gpu/drm/amd/amdgpu/gmc_v7_0.c +@@ -602,7 +602,7 @@ static void gmc_v7_0_set_prt(struct amdgpu_device *adev, bool enable) + */ + static int gmc_v7_0_gart_enable(struct amdgpu_device *adev) + { +- uint64_t table_addr = amdgpu_bo_gpu_offset(adev->gart.bo); ++ uint64_t table_addr; + int r, i; + u32 tmp, field; + +@@ -613,6 +613,9 @@ static int gmc_v7_0_gart_enable(struct amdgpu_device *adev) + r = amdgpu_gart_table_vram_pin(adev); + if (r) + return r; ++ ++ table_addr = amdgpu_bo_gpu_offset(adev->gart.bo); ++ + /* Setup TLB control */ + tmp = RREG32(mmMC_VM_MX_L1_TLB_CNTL); + tmp = REG_SET_FIELD(tmp, MC_VM_MX_L1_TLB_CNTL, ENABLE_L1_TLB, 1); +diff --git a/drivers/gpu/drm/amd/amdgpu/gmc_v8_0.c b/drivers/gpu/drm/amd/amdgpu/gmc_v8_0.c +index f16a50bbd374..d53c4022d81e 100644 +--- a/drivers/gpu/drm/amd/amdgpu/gmc_v8_0.c ++++ b/drivers/gpu/drm/amd/amdgpu/gmc_v8_0.c +@@ -812,7 +812,7 @@ static void gmc_v8_0_set_prt(struct amdgpu_device *adev, bool enable) + */ + static int gmc_v8_0_gart_enable(struct amdgpu_device *adev) + { +- uint64_t table_addr = amdgpu_bo_gpu_offset(adev->gart.bo); ++ uint64_t table_addr; + int r, i; + u32 tmp, field; + +@@ -823,6 +823,9 @@ static int gmc_v8_0_gart_enable(struct amdgpu_device *adev) + r = amdgpu_gart_table_vram_pin(adev); + if (r) + return r; ++ ++ table_addr = amdgpu_bo_gpu_offset(adev->gart.bo); ++ + /* Setup TLB control */ + tmp = RREG32(mmMC_VM_MX_L1_TLB_CNTL); + tmp = REG_SET_FIELD(tmp, MC_VM_MX_L1_TLB_CNTL, ENABLE_L1_TLB, 1); +-- +2.17.1 + |