diff options
author | Lucas Stach <l.stach@pengutronix.de> | 2016-08-17 08:57:51 -0400 |
---|---|---|
committer | Lucas Stach <l.stach@pengutronix.de> | 2016-09-15 09:29:37 -0400 |
commit | e07c0db5e84a5f1a16af8567d5fdde2ca6d2c80e (patch) | |
tree | 781ad8eeff8ea21269672fdc6ab958f49afcb21e | |
parent | 47cf62b8e0cc19b7cf7d77f218cac0fac36289f0 (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.c | 16 | ||||
-rw-r--r-- | drivers/gpu/drm/etnaviv/etnaviv_gpu.c | 2 | ||||
-rw-r--r-- | drivers/gpu/drm/etnaviv/etnaviv_mmu.c | 6 | ||||
-rw-r--r-- | drivers/gpu/drm/etnaviv/etnaviv_mmu.h | 3 |
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 | ||
120 | static u32 gpu_va(struct etnaviv_gpu *gpu, struct etnaviv_cmdbuf *buf) | ||
121 | { | ||
122 | return buf->paddr - gpu->memory_base; | ||
123 | } | ||
124 | |||
125 | static void etnaviv_buffer_dump(struct etnaviv_gpu *gpu, | 120 | static 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 | ||
168 | u16 etnaviv_buffer_init(struct etnaviv_gpu *gpu) | 163 | u16 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 | ||
307 | u32 etnaviv_iommu_get_cmdbuf_va(struct etnaviv_gpu *gpu, | ||
308 | struct etnaviv_cmdbuf *buf) | ||
309 | { | ||
310 | return buf->paddr - gpu->memory_base; | ||
311 | } | ||
312 | |||
307 | size_t etnaviv_iommu_dump_size(struct etnaviv_iommu *iommu) | 313 | size_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); |
63 | void etnaviv_iommu_destroy(struct etnaviv_iommu *iommu); | 63 | void etnaviv_iommu_destroy(struct etnaviv_iommu *iommu); |
64 | 64 | ||
65 | u32 etnaviv_iommu_get_cmdbuf_va(struct etnaviv_gpu *gpu, | ||
66 | struct etnaviv_cmdbuf *buf); | ||
67 | |||
65 | size_t etnaviv_iommu_dump_size(struct etnaviv_iommu *iommu); | 68 | size_t etnaviv_iommu_dump_size(struct etnaviv_iommu *iommu); |
66 | void etnaviv_iommu_dump(struct etnaviv_iommu *iommu, void *buf); | 69 | void etnaviv_iommu_dump(struct etnaviv_iommu *iommu, void *buf); |
67 | 70 | ||