diff options
Diffstat (limited to 'meta-amd-bsp/recipes-kernel/linux/linux-yocto-4.19.8/2704-drm-amdgpu-Expose-_setup_vm_pt_regs-for-kfd-to-use.patch')
-rw-r--r-- | meta-amd-bsp/recipes-kernel/linux/linux-yocto-4.19.8/2704-drm-amdgpu-Expose-_setup_vm_pt_regs-for-kfd-to-use.patch | 115 |
1 files changed, 115 insertions, 0 deletions
diff --git a/meta-amd-bsp/recipes-kernel/linux/linux-yocto-4.19.8/2704-drm-amdgpu-Expose-_setup_vm_pt_regs-for-kfd-to-use.patch b/meta-amd-bsp/recipes-kernel/linux/linux-yocto-4.19.8/2704-drm-amdgpu-Expose-_setup_vm_pt_regs-for-kfd-to-use.patch new file mode 100644 index 00000000..e79c90b8 --- /dev/null +++ b/meta-amd-bsp/recipes-kernel/linux/linux-yocto-4.19.8/2704-drm-amdgpu-Expose-_setup_vm_pt_regs-for-kfd-to-use.patch @@ -0,0 +1,115 @@ +From 7bd0ed9370c69998b553f3b83c1f1d5177e3977e Mon Sep 17 00:00:00 2001 +From: Yong Zhao <Yong.Zhao@amd.com> +Date: Fri, 12 Oct 2018 15:22:46 -0400 +Subject: [PATCH 2704/2940] drm/amdgpu: Expose *_setup_vm_pt_regs for kfd to + use +MIME-Version: 1.0 +Content-Type: text/plain; charset=UTF-8 +Content-Transfer-Encoding: 8bit + +kfd has the same need to set the VM page table base register, so expose +them for kfd to use for better maintainability. + +Signed-off-by: Yong Zhao <Yong.Zhao@amd.com> +Reviewed-by: Alex Deucher <alexander.deucher@amd.com> +Reviewed-by: Felix Kuehling <Felix.Kuehling@amd.com> +Reviewed-by: Christian König <christian.koenig@amd.com> +Signed-off-by: Alex Deucher <alexander.deucher@amd.com> +--- + drivers/gpu/drm/amd/amdgpu/gfxhub_v1_0.c | 19 ++++++++++++------- + drivers/gpu/drm/amd/amdgpu/gmc_v9_0.h | 6 ++++++ + drivers/gpu/drm/amd/amdgpu/mmhub_v1_0.c | 19 ++++++++++++------- + 3 files changed, 30 insertions(+), 14 deletions(-) + +diff --git a/drivers/gpu/drm/amd/amdgpu/gfxhub_v1_0.c b/drivers/gpu/drm/amd/amdgpu/gfxhub_v1_0.c +index 20ddb1874bfb..9ffda0b3573e 100644 +--- a/drivers/gpu/drm/amd/amdgpu/gfxhub_v1_0.c ++++ b/drivers/gpu/drm/amd/amdgpu/gfxhub_v1_0.c +@@ -35,20 +35,25 @@ u64 gfxhub_v1_0_get_mc_fb_offset(struct amdgpu_device *adev) + return (u64)RREG32_SOC15(GC, 0, mmMC_VM_FB_OFFSET) << 24; + } + +-static void gfxhub_v1_0_init_gart_pt_regs(struct amdgpu_device *adev) ++void gfxhub_v1_0_setup_vm_pt_regs(struct amdgpu_device *adev, uint32_t vmid, ++ uint64_t page_table_base) + { +- uint64_t value = amdgpu_gmc_pd_addr(adev->gart.bo); ++ /* two registers distance between mmVM_CONTEXT0_* to mmVM_CONTEXT1_* */ ++ int offset = mmVM_CONTEXT1_PAGE_TABLE_BASE_ADDR_LO32 ++ - mmVM_CONTEXT0_PAGE_TABLE_BASE_ADDR_LO32; + +- WREG32_SOC15(GC, 0, mmVM_CONTEXT0_PAGE_TABLE_BASE_ADDR_LO32, +- lower_32_bits(value)); ++ WREG32_SOC15_OFFSET(GC, 0, mmVM_CONTEXT0_PAGE_TABLE_BASE_ADDR_LO32, ++ offset * vmid, lower_32_bits(page_table_base)); + +- WREG32_SOC15(GC, 0, mmVM_CONTEXT0_PAGE_TABLE_BASE_ADDR_HI32, +- upper_32_bits(value)); ++ WREG32_SOC15_OFFSET(GC, 0, mmVM_CONTEXT0_PAGE_TABLE_BASE_ADDR_HI32, ++ offset * vmid, upper_32_bits(page_table_base)); + } + + static void gfxhub_v1_0_init_gart_aperture_regs(struct amdgpu_device *adev) + { +- gfxhub_v1_0_init_gart_pt_regs(adev); ++ uint64_t pt_base = amdgpu_gmc_pd_addr(adev->gart.bo); ++ ++ gfxhub_v1_0_setup_vm_pt_regs(adev, 0, pt_base); + + WREG32_SOC15(GC, 0, mmVM_CONTEXT0_PAGE_TABLE_START_ADDR_LO32, + (u32)(adev->gmc.gart_start >> 12)); +diff --git a/drivers/gpu/drm/amd/amdgpu/gmc_v9_0.h b/drivers/gpu/drm/amd/amdgpu/gmc_v9_0.h +index 5c8deac65580..dc9a401fe997 100644 +--- a/drivers/gpu/drm/amd/amdgpu/gmc_v9_0.h ++++ b/drivers/gpu/drm/amd/amdgpu/gmc_v9_0.h +@@ -37,4 +37,10 @@ + extern const struct amd_ip_funcs gmc_v9_0_ip_funcs; + extern const struct amdgpu_ip_block_version gmc_v9_0_ip_block; + ++/* amdgpu_amdkfd*.c */ ++void gfxhub_v1_0_setup_vm_pt_regs(struct amdgpu_device *adev, uint32_t vmid, ++ uint64_t page_table_base); ++void mmhub_v1_0_setup_vm_pt_regs(struct amdgpu_device *adev, uint32_t vmid, ++ uint64_t page_table_base); ++ + #endif +diff --git a/drivers/gpu/drm/amd/amdgpu/mmhub_v1_0.c b/drivers/gpu/drm/amd/amdgpu/mmhub_v1_0.c +index 4cd2e3b7c82d..34bd6606ba94 100644 +--- a/drivers/gpu/drm/amd/amdgpu/mmhub_v1_0.c ++++ b/drivers/gpu/drm/amd/amdgpu/mmhub_v1_0.c +@@ -52,20 +52,25 @@ u64 mmhub_v1_0_get_fb_location(struct amdgpu_device *adev) + return base; + } + +-static void mmhub_v1_0_init_gart_pt_regs(struct amdgpu_device *adev) ++void mmhub_v1_0_setup_vm_pt_regs(struct amdgpu_device *adev, uint32_t vmid, ++ uint64_t page_table_base) + { +- uint64_t value = amdgpu_gmc_pd_addr(adev->gart.bo); ++ /* two registers distance between mmVM_CONTEXT0_* to mmVM_CONTEXT1_* */ ++ int offset = mmVM_CONTEXT1_PAGE_TABLE_BASE_ADDR_LO32 ++ - mmVM_CONTEXT0_PAGE_TABLE_BASE_ADDR_LO32; + +- WREG32_SOC15(MMHUB, 0, mmVM_CONTEXT0_PAGE_TABLE_BASE_ADDR_LO32, +- lower_32_bits(value)); ++ WREG32_SOC15_OFFSET(MMHUB, 0, mmVM_CONTEXT0_PAGE_TABLE_BASE_ADDR_LO32, ++ offset * vmid, lower_32_bits(page_table_base)); + +- WREG32_SOC15(MMHUB, 0, mmVM_CONTEXT0_PAGE_TABLE_BASE_ADDR_HI32, +- upper_32_bits(value)); ++ WREG32_SOC15_OFFSET(MMHUB, 0, mmVM_CONTEXT0_PAGE_TABLE_BASE_ADDR_HI32, ++ offset * vmid, upper_32_bits(page_table_base)); + } + + static void mmhub_v1_0_init_gart_aperture_regs(struct amdgpu_device *adev) + { +- mmhub_v1_0_init_gart_pt_regs(adev); ++ uint64_t pt_base = amdgpu_gmc_pd_addr(adev->gart.bo); ++ ++ mmhub_v1_0_setup_vm_pt_regs(adev, 0, pt_base); + + WREG32_SOC15(MMHUB, 0, mmVM_CONTEXT0_PAGE_TABLE_START_ADDR_LO32, + (u32)(adev->gmc.gart_start >> 12)); +-- +2.17.1 + |