diff options
-rw-r--r-- | drivers/gpu/drm/etnaviv/etnaviv_buffer.c | 13 | ||||
-rw-r--r-- | drivers/gpu/drm/etnaviv/etnaviv_cmdbuf.c | 5 | ||||
-rw-r--r-- | drivers/gpu/drm/etnaviv/etnaviv_cmdbuf.h | 2 | ||||
-rw-r--r-- | drivers/gpu/drm/etnaviv/etnaviv_dump.c | 5 | ||||
-rw-r--r-- | drivers/gpu/drm/etnaviv/etnaviv_gpu.c | 4 |
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 | ||
165 | u16 etnaviv_buffer_init(struct etnaviv_gpu *gpu) | 165 | u16 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 | |||
56 | u32 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 | ||
46 | u32 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"); |