[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-ID: <1480319444.20061.4.camel@redhat.com>
Date: Mon, 28 Nov 2016 08:50:44 +0100
From: Gerd Hoffmann <kraxel@...hat.com>
To: "Michael S. Tsirkin" <mst@...hat.com>
Cc: Jiri Slaby <jslaby@...e.cz>,
virtualization@...ts.linux-foundation.org,
Linux kernel mailing list <linux-kernel@...r.kernel.org>,
David Airlie <airlied@...ux.ie>,
dri-devel@...ts.freedesktop.org
Subject: Re: virtio gpu sparse warning
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
Powered by blists - more mailing lists