Re: virtio gpu sparse warning

From: Gerd Hoffmann
Date: Mon Nov 28 2016 - 02:50:57 EST


On Do, 2016-11-24 at 04:57 +0200, Michael S. Tsirkin wrote:
> sparse produces these warnings:
>
> drivers/gpu/drm/virtio/virtgpu_fb.c:340:27: warning: incorrect type in
> assignment (different address spaces)
> drivers/gpu/drm/virtio/virtgpu_fb.c:340:27: expected char [noderef]
> <asn:2>*screen_base
> drivers/gpu/drm/virtio/virtgpu_fb.c:340:27: got void *vmap
>
> This is because the expected type is void __iomem *, while
> virtio gpu object is void *vmap.
>
> We could just cast the warning away but I'm not sure this
> is not a symptom of an actual problem. For example, might
> some code call iounmap on this address?

Nobody is ever going to unmap that, the kernel will simply use given
address to access the framebuffer.

Actually it looks like this (in include/linux/fb.h):

union {
char __iomem *screen_base; /* Virtual address */
char *screen_buffer;
};

and given that the virtio always uses normal ram as backing storage for
the framebuffer we should simply s/screen_base/screen_buffer/. I'll go
prepare a patch.

cheers,
Gerd