diff options
author | Russell King <rmk+kernel@arm.linux.org.uk> | 2014-07-12 05:53:41 -0400 |
---|---|---|
committer | Dave Airlie <airlied@redhat.com> | 2014-07-21 21:33:30 -0400 |
commit | 2d31ca3ad7d5d44c8adc7f253c96ce33f3a2e931 (patch) | |
tree | 040434d282c7c4d8dee73643f4b8fbbbec97def1 | |
parent | 150cee9cfd749b1a9f4e995d63761891d46c56de (diff) |
drm: omapdrm: fix compiler errors
Regular randconfig nightly testing has detected problems with omapdrm.
omapdrm fails to build when the kernel is built to support 64-bit DMA
addresses and/or 64-bit physical addresses due to an assumption about
the width of these types.
Use %pad to print DMA addresses, rather than %x or %Zx (which is even
more wrong than %x). Avoid passing a uint32_t pointer into a function
which expects dma_addr_t pointer.
drivers/gpu/drm/omapdrm/omap_plane.c: In function 'omap_plane_pre_apply':
drivers/gpu/drm/omapdrm/omap_plane.c:145:2: error: format '%x' expects argument of type 'unsigned int', but argument 5 has type 'dma_addr_t' [-Werror=format]
drivers/gpu/drm/omapdrm/omap_plane.c:145:2: error: format '%x' expects argument of type 'unsigned int', but argument 6 has type 'dma_addr_t' [-Werror=format]
make[5]: *** [drivers/gpu/drm/omapdrm/omap_plane.o] Error 1
drivers/gpu/drm/omapdrm/omap_gem.c: In function 'omap_gem_get_paddr':
drivers/gpu/drm/omapdrm/omap_gem.c:794:4: error: format '%x' expects argument of type 'unsigned int', but argument 3 has type 'dma_addr_t' [-Werror=format]
drivers/gpu/drm/omapdrm/omap_gem.c: In function 'omap_gem_describe':
drivers/gpu/drm/omapdrm/omap_gem.c:991:4: error: format '%Zx' expects argument of type 'size_t', but argument 7 has type 'dma_addr_t' [-Werror=format]
drivers/gpu/drm/omapdrm/omap_gem.c: In function 'omap_gem_init':
drivers/gpu/drm/omapdrm/omap_gem.c:1470:4: error: format '%x' expects argument of type 'unsigned int', but argument 7 has type 'dma_addr_t' [-Werror=format]
make[5]: *** [drivers/gpu/drm/omapdrm/omap_gem.o] Error 1
drivers/gpu/drm/omapdrm/omap_dmm_tiler.c: In function 'dmm_txn_append':
drivers/gpu/drm/omapdrm/omap_dmm_tiler.c:226:2: error: passing argument 3 of 'alloc_dma' from incompatible pointer type [-Werror]
make[5]: *** [drivers/gpu/drm/omapdrm/omap_dmm_tiler.o] Error 1
make[5]: Target `__build' not remade because of errors.
make[4]: *** [drivers/gpu/drm/omapdrm] Error 2
Signed-off-by: Russell King <rmk+kernel@arm.linux.org.uk>
Signed-off-by: Dave Airlie <airlied@redhat.com>
-rw-r--r-- | drivers/gpu/drm/omapdrm/omap_dmm_tiler.c | 6 | ||||
-rw-r--r-- | drivers/gpu/drm/omapdrm/omap_gem.c | 10 | ||||
-rw-r--r-- | drivers/gpu/drm/omapdrm/omap_plane.c | 4 |
3 files changed, 11 insertions, 9 deletions
diff --git a/drivers/gpu/drm/omapdrm/omap_dmm_tiler.c b/drivers/gpu/drm/omapdrm/omap_dmm_tiler.c index f926b4caf449..56c60552abba 100644 --- a/drivers/gpu/drm/omapdrm/omap_dmm_tiler.c +++ b/drivers/gpu/drm/omapdrm/omap_dmm_tiler.c | |||
@@ -199,7 +199,7 @@ static struct dmm_txn *dmm_txn_init(struct dmm *dmm, struct tcm *tcm) | |||
199 | static void dmm_txn_append(struct dmm_txn *txn, struct pat_area *area, | 199 | static void dmm_txn_append(struct dmm_txn *txn, struct pat_area *area, |
200 | struct page **pages, uint32_t npages, uint32_t roll) | 200 | struct page **pages, uint32_t npages, uint32_t roll) |
201 | { | 201 | { |
202 | dma_addr_t pat_pa = 0; | 202 | dma_addr_t pat_pa = 0, data_pa = 0; |
203 | uint32_t *data; | 203 | uint32_t *data; |
204 | struct pat *pat; | 204 | struct pat *pat; |
205 | struct refill_engine *engine = txn->engine_handle; | 205 | struct refill_engine *engine = txn->engine_handle; |
@@ -223,7 +223,9 @@ static void dmm_txn_append(struct dmm_txn *txn, struct pat_area *area, | |||
223 | .lut_id = engine->tcm->lut_id, | 223 | .lut_id = engine->tcm->lut_id, |
224 | }; | 224 | }; |
225 | 225 | ||
226 | data = alloc_dma(txn, 4*i, &pat->data_pa); | 226 | data = alloc_dma(txn, 4*i, &data_pa); |
227 | /* FIXME: what if data_pa is more than 32-bit ? */ | ||
228 | pat->data_pa = data_pa; | ||
227 | 229 | ||
228 | while (i--) { | 230 | while (i--) { |
229 | int n = i + roll; | 231 | int n = i + roll; |
diff --git a/drivers/gpu/drm/omapdrm/omap_gem.c b/drivers/gpu/drm/omapdrm/omap_gem.c index 5c3670017a4a..e4849413ee80 100644 --- a/drivers/gpu/drm/omapdrm/omap_gem.c +++ b/drivers/gpu/drm/omapdrm/omap_gem.c | |||
@@ -787,7 +787,7 @@ int omap_gem_get_paddr(struct drm_gem_object *obj, | |||
787 | omap_obj->paddr = tiler_ssptr(block); | 787 | omap_obj->paddr = tiler_ssptr(block); |
788 | omap_obj->block = block; | 788 | omap_obj->block = block; |
789 | 789 | ||
790 | DBG("got paddr: %08x", omap_obj->paddr); | 790 | DBG("got paddr: %pad", &omap_obj->paddr); |
791 | } | 791 | } |
792 | 792 | ||
793 | omap_obj->paddr_cnt++; | 793 | omap_obj->paddr_cnt++; |
@@ -981,9 +981,9 @@ void omap_gem_describe(struct drm_gem_object *obj, struct seq_file *m) | |||
981 | 981 | ||
982 | off = drm_vma_node_start(&obj->vma_node); | 982 | off = drm_vma_node_start(&obj->vma_node); |
983 | 983 | ||
984 | seq_printf(m, "%08x: %2d (%2d) %08llx %08Zx (%2d) %p %4d", | 984 | seq_printf(m, "%08x: %2d (%2d) %08llx %pad (%2d) %p %4d", |
985 | omap_obj->flags, obj->name, obj->refcount.refcount.counter, | 985 | omap_obj->flags, obj->name, obj->refcount.refcount.counter, |
986 | off, omap_obj->paddr, omap_obj->paddr_cnt, | 986 | off, &omap_obj->paddr, omap_obj->paddr_cnt, |
987 | omap_obj->vaddr, omap_obj->roll); | 987 | omap_obj->vaddr, omap_obj->roll); |
988 | 988 | ||
989 | if (omap_obj->flags & OMAP_BO_TILED) { | 989 | if (omap_obj->flags & OMAP_BO_TILED) { |
@@ -1464,8 +1464,8 @@ void omap_gem_init(struct drm_device *dev) | |||
1464 | entry->paddr = tiler_ssptr(block); | 1464 | entry->paddr = tiler_ssptr(block); |
1465 | entry->block = block; | 1465 | entry->block = block; |
1466 | 1466 | ||
1467 | DBG("%d:%d: %dx%d: paddr=%08x stride=%d", i, j, w, h, | 1467 | DBG("%d:%d: %dx%d: paddr=%pad stride=%d", i, j, w, h, |
1468 | entry->paddr, | 1468 | &entry->paddr, |
1469 | usergart[i].stride_pfn << PAGE_SHIFT); | 1469 | usergart[i].stride_pfn << PAGE_SHIFT); |
1470 | } | 1470 | } |
1471 | } | 1471 | } |
diff --git a/drivers/gpu/drm/omapdrm/omap_plane.c b/drivers/gpu/drm/omapdrm/omap_plane.c index 3cf31ee59aac..6af3398b5278 100644 --- a/drivers/gpu/drm/omapdrm/omap_plane.c +++ b/drivers/gpu/drm/omapdrm/omap_plane.c | |||
@@ -142,8 +142,8 @@ static void omap_plane_pre_apply(struct omap_drm_apply *apply) | |||
142 | DBG("%dx%d -> %dx%d (%d)", info->width, info->height, | 142 | DBG("%dx%d -> %dx%d (%d)", info->width, info->height, |
143 | info->out_width, info->out_height, | 143 | info->out_width, info->out_height, |
144 | info->screen_width); | 144 | info->screen_width); |
145 | DBG("%d,%d %08x %08x", info->pos_x, info->pos_y, | 145 | DBG("%d,%d %pad %pad", info->pos_x, info->pos_y, |
146 | info->paddr, info->p_uv_addr); | 146 | &info->paddr, &info->p_uv_addr); |
147 | 147 | ||
148 | /* TODO: */ | 148 | /* TODO: */ |
149 | ilace = false; | 149 | ilace = false; |