aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--drivers/gpu/drm/etnaviv/etnaviv_buffer.c13
-rw-r--r--drivers/gpu/drm/etnaviv/etnaviv_cmdbuf.c5
-rw-r--r--drivers/gpu/drm/etnaviv/etnaviv_cmdbuf.h2
-rw-r--r--drivers/gpu/drm/etnaviv/etnaviv_dump.c5
-rw-r--r--drivers/gpu/drm/etnaviv/etnaviv_gpu.c4
5 files changed, 18 insertions, 11 deletions
diff --git a/drivers/gpu/drm/etnaviv/etnaviv_buffer.c b/drivers/gpu/drm/etnaviv/etnaviv_buffer.c
index 9813b9b33553..ed9588f36bc9 100644
--- a/drivers/gpu/drm/etnaviv/etnaviv_buffer.c
+++ b/drivers/gpu/drm/etnaviv/etnaviv_buffer.c
@@ -126,7 +126,7 @@ static void etnaviv_buffer_dump(struct etnaviv_gpu *gpu,
126 u32 *ptr = buf->vaddr + off; 126 u32 *ptr = buf->vaddr + off;
127 127
128 dev_info(gpu->dev, "virt %p phys 0x%08x free 0x%08x\n", 128 dev_info(gpu->dev, "virt %p phys 0x%08x free 0x%08x\n",
129 ptr, etnaviv_iommu_get_cmdbuf_va(gpu, buf) + off, size - len * 4 - off); 129 ptr, etnaviv_cmdbuf_get_va(buf) + off, size - len * 4 - off);
130 130
131 print_hex_dump(KERN_INFO, "cmd ", DUMP_PREFIX_OFFSET, 16, 4, 131 print_hex_dump(KERN_INFO, "cmd ", DUMP_PREFIX_OFFSET, 16, 4,
132 ptr, len * 4, 0); 132 ptr, len * 4, 0);
@@ -159,7 +159,7 @@ static u32 etnaviv_buffer_reserve(struct etnaviv_gpu *gpu,
159 if (buffer->user_size + cmd_dwords * sizeof(u64) > buffer->size) 159 if (buffer->user_size + cmd_dwords * sizeof(u64) > buffer->size)
160 buffer->user_size = 0; 160 buffer->user_size = 0;
161 161
162 return etnaviv_iommu_get_cmdbuf_va(gpu, buffer) + buffer->user_size; 162 return etnaviv_cmdbuf_get_va(buffer) + buffer->user_size;
163} 163}
164 164
165u16 etnaviv_buffer_init(struct etnaviv_gpu *gpu) 165u16 etnaviv_buffer_init(struct etnaviv_gpu *gpu)
@@ -170,7 +170,7 @@ u16 etnaviv_buffer_init(struct etnaviv_gpu *gpu)
170 buffer->user_size = 0; 170 buffer->user_size = 0;
171 171
172 CMD_WAIT(buffer); 172 CMD_WAIT(buffer);
173 CMD_LINK(buffer, 2, etnaviv_iommu_get_cmdbuf_va(gpu, buffer) + 173 CMD_LINK(buffer, 2, etnaviv_cmdbuf_get_va(buffer) +
174 buffer->user_size - 4); 174 buffer->user_size - 4);
175 175
176 return buffer->user_size / 8; 176 return buffer->user_size / 8;
@@ -262,7 +262,7 @@ void etnaviv_buffer_queue(struct etnaviv_gpu *gpu, unsigned int event,
262 if (drm_debug & DRM_UT_DRIVER) 262 if (drm_debug & DRM_UT_DRIVER)
263 etnaviv_buffer_dump(gpu, buffer, 0, 0x50); 263 etnaviv_buffer_dump(gpu, buffer, 0, 0x50);
264 264
265 link_target = etnaviv_iommu_get_cmdbuf_va(gpu, cmdbuf); 265 link_target = etnaviv_cmdbuf_get_va(cmdbuf);
266 link_dwords = cmdbuf->size / 8; 266 link_dwords = cmdbuf->size / 8;
267 267
268 /* 268 /*
@@ -356,12 +356,13 @@ void etnaviv_buffer_queue(struct etnaviv_gpu *gpu, unsigned int event,
356 CMD_LOAD_STATE(buffer, VIVS_GL_EVENT, VIVS_GL_EVENT_EVENT_ID(event) | 356 CMD_LOAD_STATE(buffer, VIVS_GL_EVENT, VIVS_GL_EVENT_EVENT_ID(event) |
357 VIVS_GL_EVENT_FROM_PE); 357 VIVS_GL_EVENT_FROM_PE);
358 CMD_WAIT(buffer); 358 CMD_WAIT(buffer);
359 CMD_LINK(buffer, 2, etnaviv_iommu_get_cmdbuf_va(gpu, buffer) + 359 CMD_LINK(buffer, 2, etnaviv_cmdbuf_get_va(buffer) +
360 buffer->user_size - 4); 360 buffer->user_size - 4);
361 361
362 if (drm_debug & DRM_UT_DRIVER) 362 if (drm_debug & DRM_UT_DRIVER)
363 pr_info("stream link to 0x%08x @ 0x%08x %p\n", 363 pr_info("stream link to 0x%08x @ 0x%08x %p\n",
364 return_target, etnaviv_iommu_get_cmdbuf_va(gpu, cmdbuf), cmdbuf->vaddr); 364 return_target, etnaviv_cmdbuf_get_va(cmdbuf),
365 cmdbuf->vaddr);
365 366
366 if (drm_debug & DRM_UT_DRIVER) { 367 if (drm_debug & DRM_UT_DRIVER) {
367 print_hex_dump(KERN_INFO, "cmd ", DUMP_PREFIX_OFFSET, 16, 4, 368 print_hex_dump(KERN_INFO, "cmd ", DUMP_PREFIX_OFFSET, 16, 4,
diff --git a/drivers/gpu/drm/etnaviv/etnaviv_cmdbuf.c b/drivers/gpu/drm/etnaviv/etnaviv_cmdbuf.c
index 08f01ce63ff6..155b1fddca8e 100644
--- a/drivers/gpu/drm/etnaviv/etnaviv_cmdbuf.c
+++ b/drivers/gpu/drm/etnaviv/etnaviv_cmdbuf.c
@@ -52,3 +52,8 @@ void etnaviv_cmdbuf_free(struct etnaviv_cmdbuf *cmdbuf)
52 cmdbuf->paddr); 52 cmdbuf->paddr);
53 kfree(cmdbuf); 53 kfree(cmdbuf);
54} 54}
55
56u32 etnaviv_cmdbuf_get_va(struct etnaviv_cmdbuf *buf)
57{
58 return etnaviv_iommu_get_cmdbuf_va(buf->gpu, buf);
59}
diff --git a/drivers/gpu/drm/etnaviv/etnaviv_cmdbuf.h b/drivers/gpu/drm/etnaviv/etnaviv_cmdbuf.h
index 883f03960f95..6d64685cd3e7 100644
--- a/drivers/gpu/drm/etnaviv/etnaviv_cmdbuf.h
+++ b/drivers/gpu/drm/etnaviv/etnaviv_cmdbuf.h
@@ -43,4 +43,6 @@ struct etnaviv_cmdbuf {
43 struct etnaviv_vram_mapping *bo_map[0]; 43 struct etnaviv_vram_mapping *bo_map[0];
44}; 44};
45 45
46u32 etnaviv_cmdbuf_get_va(struct etnaviv_cmdbuf *buf);
47
46#endif /* __ETNAVIV_CMDBUF_H__ */ 48#endif /* __ETNAVIV_CMDBUF_H__ */
diff --git a/drivers/gpu/drm/etnaviv/etnaviv_dump.c b/drivers/gpu/drm/etnaviv/etnaviv_dump.c
index 6a2ff6b77f2a..d019b5e311cc 100644
--- a/drivers/gpu/drm/etnaviv/etnaviv_dump.c
+++ b/drivers/gpu/drm/etnaviv/etnaviv_dump.c
@@ -178,12 +178,11 @@ void etnaviv_core_dump(struct etnaviv_gpu *gpu)
178 etnaviv_core_dump_mmu(&iter, gpu, mmu_size); 178 etnaviv_core_dump_mmu(&iter, gpu, mmu_size);
179 etnaviv_core_dump_mem(&iter, ETDUMP_BUF_RING, gpu->buffer->vaddr, 179 etnaviv_core_dump_mem(&iter, ETDUMP_BUF_RING, gpu->buffer->vaddr,
180 gpu->buffer->size, 180 gpu->buffer->size,
181 etnaviv_iommu_get_cmdbuf_va(gpu, gpu->buffer)); 181 etnaviv_cmdbuf_get_va(gpu->buffer));
182 182
183 list_for_each_entry(cmd, &gpu->active_cmd_list, node) 183 list_for_each_entry(cmd, &gpu->active_cmd_list, node)
184 etnaviv_core_dump_mem(&iter, ETDUMP_BUF_CMD, cmd->vaddr, 184 etnaviv_core_dump_mem(&iter, ETDUMP_BUF_CMD, cmd->vaddr,
185 cmd->size, 185 cmd->size, etnaviv_cmdbuf_get_va(cmd));
186 etnaviv_iommu_get_cmdbuf_va(gpu, cmd));
187 186
188 /* Reserve space for the bomap */ 187 /* Reserve space for the bomap */
189 if (n_bomap_pages) { 188 if (n_bomap_pages) {
diff --git a/drivers/gpu/drm/etnaviv/etnaviv_gpu.c b/drivers/gpu/drm/etnaviv/etnaviv_gpu.c
index ee8aacc28944..3a689c3fbe5b 100644
--- a/drivers/gpu/drm/etnaviv/etnaviv_gpu.c
+++ b/drivers/gpu/drm/etnaviv/etnaviv_gpu.c
@@ -629,7 +629,7 @@ static void etnaviv_gpu_hw_init(struct etnaviv_gpu *gpu)
629 prefetch = etnaviv_buffer_init(gpu); 629 prefetch = etnaviv_buffer_init(gpu);
630 630
631 gpu_write(gpu, VIVS_HI_INTR_ENBL, ~0U); 631 gpu_write(gpu, VIVS_HI_INTR_ENBL, ~0U);
632 etnaviv_gpu_start_fe(gpu, etnaviv_iommu_get_cmdbuf_va(gpu, gpu->buffer), 632 etnaviv_gpu_start_fe(gpu, etnaviv_cmdbuf_get_va(gpu->buffer),
633 prefetch); 633 prefetch);
634} 634}
635 635
@@ -703,7 +703,7 @@ int etnaviv_gpu_init(struct etnaviv_gpu *gpu)
703 } 703 }
704 704
705 if (gpu->mmu->version == ETNAVIV_IOMMU_V1 && 705 if (gpu->mmu->version == ETNAVIV_IOMMU_V1 &&
706 gpu->buffer->paddr - gpu->memory_base > 0x80000000) { 706 etnaviv_cmdbuf_get_va(gpu->buffer) > 0x80000000) {
707 ret = -EINVAL; 707 ret = -EINVAL;
708 dev_err(gpu->dev, 708 dev_err(gpu->dev,
709 "command buffer outside valid memory window\n"); 709 "command buffer outside valid memory window\n");