aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorLucas Stach <l.stach@pengutronix.de>2016-08-17 08:57:51 -0400
committerLucas Stach <l.stach@pengutronix.de>2016-09-15 09:29:37 -0400
commite07c0db5e84a5f1a16af8567d5fdde2ca6d2c80e (patch)
tree781ad8eeff8ea21269672fdc6ab958f49afcb21e
parent47cf62b8e0cc19b7cf7d77f218cac0fac36289f0 (diff)
drm/etnaviv: move gpu_va() to etnaviv mmu
The GPU virtual address for the command buffers differs depending on the IOMMU version. Move the calculation of the iova into etnaviv mmu, to enable proper dispatch. Signed-off-by: Lucas Stach <l.stach@pengutronix.de>
-rw-r--r--drivers/gpu/drm/etnaviv/etnaviv_buffer.c16
-rw-r--r--drivers/gpu/drm/etnaviv/etnaviv_gpu.c2
-rw-r--r--drivers/gpu/drm/etnaviv/etnaviv_mmu.c6
-rw-r--r--drivers/gpu/drm/etnaviv/etnaviv_mmu.h3
4 files changed, 16 insertions, 11 deletions
diff --git a/drivers/gpu/drm/etnaviv/etnaviv_buffer.c b/drivers/gpu/drm/etnaviv/etnaviv_buffer.c
index d8d556457427..46d13f49883e 100644
--- a/drivers/gpu/drm/etnaviv/etnaviv_buffer.c
+++ b/drivers/gpu/drm/etnaviv/etnaviv_buffer.c
@@ -117,11 +117,6 @@ static void etnaviv_cmd_select_pipe(struct etnaviv_gpu *gpu,
117 VIVS_GL_PIPE_SELECT_PIPE(pipe)); 117 VIVS_GL_PIPE_SELECT_PIPE(pipe));
118} 118}
119 119
120static u32 gpu_va(struct etnaviv_gpu *gpu, struct etnaviv_cmdbuf *buf)
121{
122 return buf->paddr - gpu->memory_base;
123}
124
125static void etnaviv_buffer_dump(struct etnaviv_gpu *gpu, 120static void etnaviv_buffer_dump(struct etnaviv_gpu *gpu,
126 struct etnaviv_cmdbuf *buf, u32 off, u32 len) 121 struct etnaviv_cmdbuf *buf, u32 off, u32 len)
127{ 122{
@@ -129,7 +124,7 @@ static void etnaviv_buffer_dump(struct etnaviv_gpu *gpu,
129 u32 *ptr = buf->vaddr + off; 124 u32 *ptr = buf->vaddr + off;
130 125
131 dev_info(gpu->dev, "virt %p phys 0x%08x free 0x%08x\n", 126 dev_info(gpu->dev, "virt %p phys 0x%08x free 0x%08x\n",
132 ptr, gpu_va(gpu, buf) + off, size - len * 4 - off); 127 ptr, etnaviv_iommu_get_cmdbuf_va(gpu, buf) + off, size - len * 4 - off);
133 128
134 print_hex_dump(KERN_INFO, "cmd ", DUMP_PREFIX_OFFSET, 16, 4, 129 print_hex_dump(KERN_INFO, "cmd ", DUMP_PREFIX_OFFSET, 16, 4,
135 ptr, len * 4, 0); 130 ptr, len * 4, 0);
@@ -162,7 +157,7 @@ static u32 etnaviv_buffer_reserve(struct etnaviv_gpu *gpu,
162 if (buffer->user_size + cmd_dwords * sizeof(u64) > buffer->size) 157 if (buffer->user_size + cmd_dwords * sizeof(u64) > buffer->size)
163 buffer->user_size = 0; 158 buffer->user_size = 0;
164 159
165 return gpu_va(gpu, buffer) + buffer->user_size; 160 return etnaviv_iommu_get_cmdbuf_va(gpu, buffer) + buffer->user_size;
166} 161}
167 162
168u16 etnaviv_buffer_init(struct etnaviv_gpu *gpu) 163u16 etnaviv_buffer_init(struct etnaviv_gpu *gpu)
@@ -173,7 +168,8 @@ u16 etnaviv_buffer_init(struct etnaviv_gpu *gpu)
173 buffer->user_size = 0; 168 buffer->user_size = 0;
174 169
175 CMD_WAIT(buffer); 170 CMD_WAIT(buffer);
176 CMD_LINK(buffer, 2, gpu_va(gpu, buffer) + buffer->user_size - 4); 171 CMD_LINK(buffer, 2, etnaviv_iommu_get_cmdbuf_va(gpu, buffer) +
172 buffer->user_size - 4);
177 173
178 return buffer->user_size / 8; 174 return buffer->user_size / 8;
179} 175}
@@ -231,7 +227,7 @@ void etnaviv_buffer_queue(struct etnaviv_gpu *gpu, unsigned int event,
231 if (drm_debug & DRM_UT_DRIVER) 227 if (drm_debug & DRM_UT_DRIVER)
232 etnaviv_buffer_dump(gpu, buffer, 0, 0x50); 228 etnaviv_buffer_dump(gpu, buffer, 0, 0x50);
233 229
234 link_target = gpu_va(gpu, cmdbuf); 230 link_target = etnaviv_iommu_get_cmdbuf_va(gpu, cmdbuf);
235 link_dwords = cmdbuf->size / 8; 231 link_dwords = cmdbuf->size / 8;
236 232
237 /* 233 /*
@@ -301,7 +297,7 @@ void etnaviv_buffer_queue(struct etnaviv_gpu *gpu, unsigned int event,
301 297
302 if (drm_debug & DRM_UT_DRIVER) 298 if (drm_debug & DRM_UT_DRIVER)
303 pr_info("stream link to 0x%08x @ 0x%08x %p\n", 299 pr_info("stream link to 0x%08x @ 0x%08x %p\n",
304 return_target, gpu_va(gpu, cmdbuf), cmdbuf->vaddr); 300 return_target, etnaviv_iommu_get_cmdbuf_va(gpu, cmdbuf), cmdbuf->vaddr);
305 301
306 if (drm_debug & DRM_UT_DRIVER) { 302 if (drm_debug & DRM_UT_DRIVER) {
307 print_hex_dump(KERN_INFO, "cmd ", DUMP_PREFIX_OFFSET, 16, 4, 303 print_hex_dump(KERN_INFO, "cmd ", DUMP_PREFIX_OFFSET, 16, 4,
diff --git a/drivers/gpu/drm/etnaviv/etnaviv_gpu.c b/drivers/gpu/drm/etnaviv/etnaviv_gpu.c
index 9ecb23b1089b..6309d27045a6 100644
--- a/drivers/gpu/drm/etnaviv/etnaviv_gpu.c
+++ b/drivers/gpu/drm/etnaviv/etnaviv_gpu.c
@@ -574,7 +574,7 @@ static void etnaviv_gpu_hw_init(struct etnaviv_gpu *gpu)
574 574
575 gpu_write(gpu, VIVS_HI_INTR_ENBL, ~0U); 575 gpu_write(gpu, VIVS_HI_INTR_ENBL, ~0U);
576 gpu_write(gpu, VIVS_FE_COMMAND_ADDRESS, 576 gpu_write(gpu, VIVS_FE_COMMAND_ADDRESS,
577 gpu->buffer->paddr - gpu->memory_base); 577 etnaviv_iommu_get_cmdbuf_va(gpu, gpu->buffer));
578 gpu_write(gpu, VIVS_FE_COMMAND_CONTROL, 578 gpu_write(gpu, VIVS_FE_COMMAND_CONTROL,
579 VIVS_FE_COMMAND_CONTROL_ENABLE | 579 VIVS_FE_COMMAND_CONTROL_ENABLE |
580 VIVS_FE_COMMAND_CONTROL_PREFETCH(prefetch)); 580 VIVS_FE_COMMAND_CONTROL_PREFETCH(prefetch));
diff --git a/drivers/gpu/drm/etnaviv/etnaviv_mmu.c b/drivers/gpu/drm/etnaviv/etnaviv_mmu.c
index e744c6d81a2d..d62125eb30d8 100644
--- a/drivers/gpu/drm/etnaviv/etnaviv_mmu.c
+++ b/drivers/gpu/drm/etnaviv/etnaviv_mmu.c
@@ -304,6 +304,12 @@ void etnaviv_iommu_restore(struct etnaviv_gpu *gpu)
304 dev_err(gpu->dev, "IOMMUv2 restore not implemented\n"); 304 dev_err(gpu->dev, "IOMMUv2 restore not implemented\n");
305} 305}
306 306
307u32 etnaviv_iommu_get_cmdbuf_va(struct etnaviv_gpu *gpu,
308 struct etnaviv_cmdbuf *buf)
309{
310 return buf->paddr - gpu->memory_base;
311}
312
307size_t etnaviv_iommu_dump_size(struct etnaviv_iommu *iommu) 313size_t etnaviv_iommu_dump_size(struct etnaviv_iommu *iommu)
308{ 314{
309 struct etnaviv_iommu_ops *ops; 315 struct etnaviv_iommu_ops *ops;
diff --git a/drivers/gpu/drm/etnaviv/etnaviv_mmu.h b/drivers/gpu/drm/etnaviv/etnaviv_mmu.h
index 70ff1e46717d..0d34325a318a 100644
--- a/drivers/gpu/drm/etnaviv/etnaviv_mmu.h
+++ b/drivers/gpu/drm/etnaviv/etnaviv_mmu.h
@@ -62,6 +62,9 @@ void etnaviv_iommu_unmap_gem(struct etnaviv_iommu *mmu,
62 struct etnaviv_vram_mapping *mapping); 62 struct etnaviv_vram_mapping *mapping);
63void etnaviv_iommu_destroy(struct etnaviv_iommu *iommu); 63void etnaviv_iommu_destroy(struct etnaviv_iommu *iommu);
64 64
65u32 etnaviv_iommu_get_cmdbuf_va(struct etnaviv_gpu *gpu,
66 struct etnaviv_cmdbuf *buf);
67
65size_t etnaviv_iommu_dump_size(struct etnaviv_iommu *iommu); 68size_t etnaviv_iommu_dump_size(struct etnaviv_iommu *iommu);
66void etnaviv_iommu_dump(struct etnaviv_iommu *iommu, void *buf); 69void etnaviv_iommu_dump(struct etnaviv_iommu *iommu, void *buf);
67 70