aboutsummaryrefslogtreecommitdiffstats
path: root/meta-amd-bsp/recipes-kernel/linux/linux-yocto-4.14.71/2943-drm-amdgpu-allow-get_vm_pde-to-change-flags-as-well.patch
diff options
context:
space:
mode:
Diffstat (limited to 'meta-amd-bsp/recipes-kernel/linux/linux-yocto-4.14.71/2943-drm-amdgpu-allow-get_vm_pde-to-change-flags-as-well.patch')
-rw-r--r--meta-amd-bsp/recipes-kernel/linux/linux-yocto-4.14.71/2943-drm-amdgpu-allow-get_vm_pde-to-change-flags-as-well.patch312
1 files changed, 312 insertions, 0 deletions
diff --git a/meta-amd-bsp/recipes-kernel/linux/linux-yocto-4.14.71/2943-drm-amdgpu-allow-get_vm_pde-to-change-flags-as-well.patch b/meta-amd-bsp/recipes-kernel/linux/linux-yocto-4.14.71/2943-drm-amdgpu-allow-get_vm_pde-to-change-flags-as-well.patch
new file mode 100644
index 00000000..12ffb68b
--- /dev/null
+++ b/meta-amd-bsp/recipes-kernel/linux/linux-yocto-4.14.71/2943-drm-amdgpu-allow-get_vm_pde-to-change-flags-as-well.patch
@@ -0,0 +1,312 @@
+From 7f3107f67bc4ba2ebd9ad15def7ca44b5a49a7bd Mon Sep 17 00:00:00 2001
+From: =?UTF-8?q?Christian=20K=C3=B6nig?= <christian.koenig@amd.com>
+Date: Wed, 29 Nov 2017 13:27:26 +0100
+Subject: [PATCH 2943/4131] drm/amdgpu: allow get_vm_pde to change flags as
+ well
+MIME-Version: 1.0
+Content-Type: text/plain; charset=UTF-8
+Content-Transfer-Encoding: 8bit
+
+And also provide the level for which we need a PDE.
+
+Signed-off-by: Christian König <christian.koenig@amd.com>
+Reviewed-by: Chunming Zhou <david1.zhou@amd.com>
+---
+ drivers/gpu/drm/amd/amdgpu/amdgpu.h | 5 +++--
+ drivers/gpu/drm/amd/amdgpu/amdgpu_vm.c | 20 +++++++++++++-------
+ drivers/gpu/drm/amd/amdgpu/gfx_v9_0.c | 5 +++--
+ drivers/gpu/drm/amd/amdgpu/gmc_v6_0.c | 6 +++---
+ drivers/gpu/drm/amd/amdgpu/gmc_v7_0.c | 6 +++---
+ drivers/gpu/drm/amd/amdgpu/gmc_v8_0.c | 6 +++---
+ drivers/gpu/drm/amd/amdgpu/gmc_v9_0.c | 10 ++++++----
+ drivers/gpu/drm/amd/amdgpu/sdma_v4_0.c | 5 +++--
+ drivers/gpu/drm/amd/amdgpu/uvd_v7_0.c | 12 +++++++-----
+ drivers/gpu/drm/amd/amdgpu/vce_v4_0.c | 5 +++--
+ drivers/gpu/drm/amd/amdgpu/vcn_v1_0.c | 12 +++++++-----
+ 11 files changed, 54 insertions(+), 38 deletions(-)
+
+diff --git a/drivers/gpu/drm/amd/amdgpu/amdgpu.h b/drivers/gpu/drm/amd/amdgpu/amdgpu.h
+index ad3aba3..92a0f07 100755
+--- a/drivers/gpu/drm/amd/amdgpu/amdgpu.h
++++ b/drivers/gpu/drm/amd/amdgpu/amdgpu.h
+@@ -349,7 +349,8 @@ struct amdgpu_gart_funcs {
+ uint64_t (*get_vm_pte_flags)(struct amdgpu_device *adev,
+ uint32_t flags);
+ /* get the pde for a given mc addr */
+- u64 (*get_vm_pde)(struct amdgpu_device *adev, u64 addr);
++ void (*get_vm_pde)(struct amdgpu_device *adev, int level,
++ u64 *dst, u64 *flags);
+ uint32_t (*get_invalidate_req)(unsigned int vm_id);
+ };
+
+@@ -1901,7 +1902,7 @@ amdgpu_get_sdma_instance(struct amdgpu_ring *ring)
+ #define amdgpu_asic_get_config_memsize(adev) (adev)->asic_funcs->get_config_memsize((adev))
+ #define amdgpu_gart_flush_gpu_tlb(adev, vmid) (adev)->gart.gart_funcs->flush_gpu_tlb((adev), (vmid))
+ #define amdgpu_gart_set_pte_pde(adev, pt, idx, addr, flags) (adev)->gart.gart_funcs->set_pte_pde((adev), (pt), (idx), (addr), (flags))
+-#define amdgpu_gart_get_vm_pde(adev, addr) (adev)->gart.gart_funcs->get_vm_pde((adev), (addr))
++#define amdgpu_gart_get_vm_pde(adev, level, dst, flags) (adev)->gart.gart_funcs->get_vm_pde((adev), (level), (dst), (flags))
+ #define amdgpu_vm_copy_pte(adev, ib, pe, src, count) ((adev)->vm_manager.vm_pte_funcs->copy_pte((ib), (pe), (src), (count)))
+ #define amdgpu_vm_write_pte(adev, ib, pe, value, count, incr) ((adev)->vm_manager.vm_pte_funcs->write_pte((ib), (pe), (value), (count), (incr)))
+ #define amdgpu_vm_set_pte_pde(adev, ib, pe, addr, count, incr, flags) ((adev)->vm_manager.vm_pte_funcs->set_pte_pde((ib), (pe), (addr), (count), (incr), (flags)))
+diff --git a/drivers/gpu/drm/amd/amdgpu/amdgpu_vm.c b/drivers/gpu/drm/amd/amdgpu/amdgpu_vm.c
+index 0110627..2e2cdbe 100644
+--- a/drivers/gpu/drm/amd/amdgpu/amdgpu_vm.c
++++ b/drivers/gpu/drm/amd/amdgpu/amdgpu_vm.c
+@@ -1079,9 +1079,10 @@ static void amdgpu_vm_update_pde(struct amdgpu_pte_update_params *params,
+ struct amdgpu_vm_pt *parent,
+ struct amdgpu_vm_pt *entry)
+ {
+- struct amdgpu_bo *bo = entry->base.bo, *shadow = NULL;
++ struct amdgpu_bo *bo = entry->base.bo, *shadow = NULL, *pbo;
+ uint64_t pd_addr, shadow_addr = 0;
+- uint64_t pde, pt;
++ uint64_t pde, pt, flags;
++ unsigned level;
+
+ /* Don't update huge pages here */
+ if (entry->huge)
+@@ -1096,15 +1097,19 @@ static void amdgpu_vm_update_pde(struct amdgpu_pte_update_params *params,
+ shadow_addr = amdgpu_bo_gpu_offset(shadow);
+ }
+
++ for (level = 0, pbo = parent->base.bo->parent; pbo; ++level)
++ pbo = pbo->parent;
++
+ pt = amdgpu_bo_gpu_offset(bo);
+- pt = amdgpu_gart_get_vm_pde(params->adev, pt);
++ flags = AMDGPU_PTE_VALID;
++ amdgpu_gart_get_vm_pde(params->adev, level, &pt, &flags);
+ if (shadow) {
+ pde = shadow_addr + (entry - parent->entries) * 8;
+- params->func(params, pde, pt, 1, 0, AMDGPU_PTE_VALID);
++ params->func(params, pde, pt, 1, 0, flags);
+ }
+
+ pde = pd_addr + (entry - parent->entries) * 8;
+- params->func(params, pde, pt, 1, 0, AMDGPU_PTE_VALID);
++ params->func(params, pde, pt, 1, 0, flags);
+ }
+
+ /*
+@@ -1314,7 +1319,6 @@ static void amdgpu_vm_handle_huge_pages(struct amdgpu_pte_update_params *p,
+ !(flags & AMDGPU_PTE_VALID)) {
+
+ dst = amdgpu_bo_gpu_offset(entry->base.bo);
+- dst = amdgpu_gart_get_vm_pde(p->adev, dst);
+ flags = AMDGPU_PTE_VALID;
+ } else {
+ /* Set the huge page flag to stop scanning at this PDE */
+@@ -1323,9 +1327,11 @@ static void amdgpu_vm_handle_huge_pages(struct amdgpu_pte_update_params *p,
+
+ if (!entry->huge && !(flags & AMDGPU_PDE_PTE))
+ return;
+-
+ entry->huge = !!(flags & AMDGPU_PDE_PTE);
+
++ amdgpu_gart_get_vm_pde(p->adev, p->adev->vm_manager.num_level - 1,
++ &dst, &flags);
++
+ if (use_cpu_update) {
+ /* In case a huge page is replaced with a system
+ * memory mapping, p->pages_addr != NULL and
+diff --git a/drivers/gpu/drm/amd/amdgpu/gfx_v9_0.c b/drivers/gpu/drm/amd/amdgpu/gfx_v9_0.c
+index 466c823..99db21e 100644
+--- a/drivers/gpu/drm/amd/amdgpu/gfx_v9_0.c
++++ b/drivers/gpu/drm/amd/amdgpu/gfx_v9_0.c
+@@ -3692,10 +3692,11 @@ static void gfx_v9_0_ring_emit_vm_flush(struct amdgpu_ring *ring,
+ struct amdgpu_vmhub *hub = &ring->adev->vmhub[ring->funcs->vmhub];
+ int usepfp = (ring->funcs->type == AMDGPU_RING_TYPE_GFX);
+ uint32_t req = ring->adev->gart.gart_funcs->get_invalidate_req(vm_id);
++ uint64_t flags = AMDGPU_PTE_VALID;
+ unsigned eng = ring->vm_inv_eng;
+
+- pd_addr = amdgpu_gart_get_vm_pde(ring->adev, pd_addr);
+- pd_addr |= AMDGPU_PTE_VALID;
++ amdgpu_gart_get_vm_pde(ring->adev, -1, &pd_addr, &flags);
++ pd_addr |= flags;
+
+ gfx_v9_0_write_data_to_reg(ring, usepfp, true,
+ hub->ctx0_ptb_addr_lo32 + (2 * vm_id),
+diff --git a/drivers/gpu/drm/amd/amdgpu/gmc_v6_0.c b/drivers/gpu/drm/amd/amdgpu/gmc_v6_0.c
+index 105ebe9..edf42a4 100644
+--- a/drivers/gpu/drm/amd/amdgpu/gmc_v6_0.c
++++ b/drivers/gpu/drm/amd/amdgpu/gmc_v6_0.c
+@@ -397,10 +397,10 @@ static uint64_t gmc_v6_0_get_vm_pte_flags(struct amdgpu_device *adev,
+ return pte_flag;
+ }
+
+-static uint64_t gmc_v6_0_get_vm_pde(struct amdgpu_device *adev, uint64_t addr)
++static void gmc_v6_0_get_vm_pde(struct amdgpu_device *adev, int level,
++ uint64_t *addr, uint64_t *flags)
+ {
+- BUG_ON(addr & 0xFFFFFF0000000FFFULL);
+- return addr;
++ BUG_ON(*addr & 0xFFFFFF0000000FFFULL);
+ }
+
+ static void gmc_v6_0_set_fault_enable_default(struct amdgpu_device *adev,
+diff --git a/drivers/gpu/drm/amd/amdgpu/gmc_v7_0.c b/drivers/gpu/drm/amd/amdgpu/gmc_v7_0.c
+index ff5c7a4..05cf66b 100644
+--- a/drivers/gpu/drm/amd/amdgpu/gmc_v7_0.c
++++ b/drivers/gpu/drm/amd/amdgpu/gmc_v7_0.c
+@@ -483,10 +483,10 @@ static uint64_t gmc_v7_0_get_vm_pte_flags(struct amdgpu_device *adev,
+ return pte_flag;
+ }
+
+-static uint64_t gmc_v7_0_get_vm_pde(struct amdgpu_device *adev, uint64_t addr)
++static void gmc_v7_0_get_vm_pde(struct amdgpu_device *adev, int level,
++ uint64_t *addr, uint64_t *flags)
+ {
+- BUG_ON(addr & 0xFFFFFF0000000FFFULL);
+- return addr;
++ BUG_ON(*addr & 0xFFFFFF0000000FFFULL);
+ }
+
+ /**
+diff --git a/drivers/gpu/drm/amd/amdgpu/gmc_v8_0.c b/drivers/gpu/drm/amd/amdgpu/gmc_v8_0.c
+index 24c4d47..c09721b 100644
+--- a/drivers/gpu/drm/amd/amdgpu/gmc_v8_0.c
++++ b/drivers/gpu/drm/amd/amdgpu/gmc_v8_0.c
+@@ -684,10 +684,10 @@ static uint64_t gmc_v8_0_get_vm_pte_flags(struct amdgpu_device *adev,
+ return pte_flag;
+ }
+
+-static uint64_t gmc_v8_0_get_vm_pde(struct amdgpu_device *adev, uint64_t addr)
++static void gmc_v8_0_get_vm_pde(struct amdgpu_device *adev, int level,
++ uint64_t *addr, uint64_t *flags)
+ {
+- BUG_ON(addr & 0xFFFFFF0000000FFFULL);
+- return addr;
++ BUG_ON(*addr & 0xFFFFFF0000000FFFULL);
+ }
+
+ /**
+diff --git a/drivers/gpu/drm/amd/amdgpu/gmc_v9_0.c b/drivers/gpu/drm/amd/amdgpu/gmc_v9_0.c
+index 62a493b..e4fb965 100644
+--- a/drivers/gpu/drm/amd/amdgpu/gmc_v9_0.c
++++ b/drivers/gpu/drm/amd/amdgpu/gmc_v9_0.c
+@@ -474,11 +474,13 @@ static uint64_t gmc_v9_0_get_vm_pte_flags(struct amdgpu_device *adev,
+ return pte_flag;
+ }
+
+-static u64 gmc_v9_0_get_vm_pde(struct amdgpu_device *adev, u64 addr)
++static void gmc_v9_0_get_vm_pde(struct amdgpu_device *adev, int level,
++ uint64_t *addr, uint64_t *flags)
+ {
+- addr = adev->vm_manager.vram_base_offset + addr - adev->mc.vram_start;
+- BUG_ON(addr & 0xFFFF00000000003FULL);
+- return addr;
++ if (!(*flags & AMDGPU_PDE_PTE))
++ *addr = adev->vm_manager.vram_base_offset + *addr -
++ adev->mc.vram_start;
++ BUG_ON(*addr & 0xFFFF00000000003FULL);
+ }
+
+ static const struct amdgpu_gart_funcs gmc_v9_0_gart_funcs = {
+diff --git a/drivers/gpu/drm/amd/amdgpu/sdma_v4_0.c b/drivers/gpu/drm/amd/amdgpu/sdma_v4_0.c
+index 13050f4..5777c2f 100644
+--- a/drivers/gpu/drm/amd/amdgpu/sdma_v4_0.c
++++ b/drivers/gpu/drm/amd/amdgpu/sdma_v4_0.c
+@@ -1146,10 +1146,11 @@ static void sdma_v4_0_ring_emit_vm_flush(struct amdgpu_ring *ring,
+ {
+ struct amdgpu_vmhub *hub = &ring->adev->vmhub[ring->funcs->vmhub];
+ uint32_t req = ring->adev->gart.gart_funcs->get_invalidate_req(vm_id);
++ uint64_t flags = AMDGPU_PTE_VALID;
+ unsigned eng = ring->vm_inv_eng;
+
+- pd_addr = amdgpu_gart_get_vm_pde(ring->adev, pd_addr);
+- pd_addr |= AMDGPU_PTE_VALID;
++ amdgpu_gart_get_vm_pde(ring->adev, -1, &pd_addr, &flags);
++ pd_addr |= flags;
+
+ amdgpu_ring_write(ring, SDMA_PKT_HEADER_OP(SDMA_OP_SRBM_WRITE) |
+ SDMA_PKT_SRBM_WRITE_HEADER_BYTE_EN(0xf));
+diff --git a/drivers/gpu/drm/amd/amdgpu/uvd_v7_0.c b/drivers/gpu/drm/amd/amdgpu/uvd_v7_0.c
+index 23b4462..4ec4447 100644
+--- a/drivers/gpu/drm/amd/amdgpu/uvd_v7_0.c
++++ b/drivers/gpu/drm/amd/amdgpu/uvd_v7_0.c
+@@ -1295,11 +1295,12 @@ static void uvd_v7_0_ring_emit_vm_flush(struct amdgpu_ring *ring,
+ {
+ struct amdgpu_vmhub *hub = &ring->adev->vmhub[ring->funcs->vmhub];
+ uint32_t req = ring->adev->gart.gart_funcs->get_invalidate_req(vm_id);
+- uint32_t data0, data1, mask;
++ uint64_t flags = AMDGPU_PTE_VALID;
+ unsigned eng = ring->vm_inv_eng;
++ uint32_t data0, data1, mask;
+
+- pd_addr = amdgpu_gart_get_vm_pde(ring->adev, pd_addr);
+- pd_addr |= AMDGPU_PTE_VALID;
++ amdgpu_gart_get_vm_pde(ring->adev, -1, &pd_addr, &flags);
++ pd_addr |= flags;
+
+ data0 = (hub->ctx0_ptb_addr_hi32 + vm_id * 2) << 2;
+ data1 = upper_32_bits(pd_addr);
+@@ -1346,10 +1347,11 @@ static void uvd_v7_0_enc_ring_emit_vm_flush(struct amdgpu_ring *ring,
+ {
+ struct amdgpu_vmhub *hub = &ring->adev->vmhub[ring->funcs->vmhub];
+ uint32_t req = ring->adev->gart.gart_funcs->get_invalidate_req(vm_id);
++ uint64_t flags = AMDGPU_PTE_VALID;
+ unsigned eng = ring->vm_inv_eng;
+
+- pd_addr = amdgpu_gart_get_vm_pde(ring->adev, pd_addr);
+- pd_addr |= AMDGPU_PTE_VALID;
++ amdgpu_gart_get_vm_pde(ring->adev, -1, &pd_addr, &flags);
++ pd_addr |= flags;
+
+ amdgpu_ring_write(ring, HEVC_ENC_CMD_REG_WRITE);
+ amdgpu_ring_write(ring, (hub->ctx0_ptb_addr_hi32 + vm_id * 2) << 2);
+diff --git a/drivers/gpu/drm/amd/amdgpu/vce_v4_0.c b/drivers/gpu/drm/amd/amdgpu/vce_v4_0.c
+index 55f0186..0071a5c 100755
+--- a/drivers/gpu/drm/amd/amdgpu/vce_v4_0.c
++++ b/drivers/gpu/drm/amd/amdgpu/vce_v4_0.c
+@@ -969,10 +969,11 @@ static void vce_v4_0_emit_vm_flush(struct amdgpu_ring *ring,
+ {
+ struct amdgpu_vmhub *hub = &ring->adev->vmhub[ring->funcs->vmhub];
+ uint32_t req = ring->adev->gart.gart_funcs->get_invalidate_req(vm_id);
++ uint64_t flags = AMDGPU_PTE_VALID;
+ unsigned eng = ring->vm_inv_eng;
+
+- pd_addr = amdgpu_gart_get_vm_pde(ring->adev, pd_addr);
+- pd_addr |= AMDGPU_PTE_VALID;
++ amdgpu_gart_get_vm_pde(ring->adev, -1, &pd_addr, &flags);
++ pd_addr |= flags;
+
+ amdgpu_ring_write(ring, VCE_CMD_REG_WRITE);
+ amdgpu_ring_write(ring, (hub->ctx0_ptb_addr_hi32 + vm_id * 2) << 2);
+diff --git a/drivers/gpu/drm/amd/amdgpu/vcn_v1_0.c b/drivers/gpu/drm/amd/amdgpu/vcn_v1_0.c
+index a02dbf5..c76e51c 100644
+--- a/drivers/gpu/drm/amd/amdgpu/vcn_v1_0.c
++++ b/drivers/gpu/drm/amd/amdgpu/vcn_v1_0.c
+@@ -914,11 +914,12 @@ static void vcn_v1_0_dec_ring_emit_vm_flush(struct amdgpu_ring *ring,
+ {
+ struct amdgpu_vmhub *hub = &ring->adev->vmhub[ring->funcs->vmhub];
+ uint32_t req = ring->adev->gart.gart_funcs->get_invalidate_req(vm_id);
+- uint32_t data0, data1, mask;
++ uint64_t flags = AMDGPU_PTE_VALID;
+ unsigned eng = ring->vm_inv_eng;
++ uint32_t data0, data1, mask;
+
+- pd_addr = amdgpu_gart_get_vm_pde(ring->adev, pd_addr);
+- pd_addr |= AMDGPU_PTE_VALID;
++ amdgpu_gart_get_vm_pde(ring->adev, -1, &pd_addr, &flags);
++ pd_addr |= flags;
+
+ data0 = (hub->ctx0_ptb_addr_hi32 + vm_id * 2) << 2;
+ data1 = upper_32_bits(pd_addr);
+@@ -1046,10 +1047,11 @@ static void vcn_v1_0_enc_ring_emit_vm_flush(struct amdgpu_ring *ring,
+ {
+ struct amdgpu_vmhub *hub = &ring->adev->vmhub[ring->funcs->vmhub];
+ uint32_t req = ring->adev->gart.gart_funcs->get_invalidate_req(vm_id);
++ uint64_t flags = AMDGPU_PTE_VALID;
+ unsigned eng = ring->vm_inv_eng;
+
+- pd_addr = amdgpu_gart_get_vm_pde(ring->adev, pd_addr);
+- pd_addr |= AMDGPU_PTE_VALID;
++ amdgpu_gart_get_vm_pde(ring->adev, -1, &pd_addr, &flags);
++ pd_addr |= flags;
+
+ amdgpu_ring_write(ring, VCN_ENC_CMD_REG_WRITE);
+ amdgpu_ring_write(ring,
+--
+2.7.4
+