[PATCH] drm/exynos/fbdev: set smem_len for fbdev
Günther Noack
guenther at unix-ag.uni-kl.de
Sun Aug 24 14:18:27 PDT 2014
This patch works on my hardware. Xorg starts up fine with fbdev now.
Thanks for the fix!
--Günther
Daniel Kurtz <djkurtz at chromium.org> writes:
> Commit [0] stopped setting fix.smem_start and fix.smem_len when creating
> the fbdev.
>
> [0] 2f1eab8d8ab59e799f7d51d62410b398607a7bc3
> drm/exynos/fbdev: don't set fix.smem/mmio_{start,len}
>
> However, smem_len is used by some userland applications to calculate the
> size for mmap. In particular, it is used by xf86-video-fbdev:
>
> http://cgit.freedesktop.org/xorg/xserver/tree/hw/xfree86/fbdevhw/fbdevhw.c?id=xorg-server-1.15.99.903#n571
>
> So, let's restore setting the smem_len to unbreak things for these users.
>
> Note: we are still leaving smem_start set to 0.
>
> Reported-by: Siarhei Siamashka <siarhei.siamashka at gmail.com>
> Reported-by: Günther Noack <me at guenthernoack.de>
> Signed-off-by: Daniel Kurtz <djkurtz at chromium.org>
> ---
> I am able to compile test this change, but would appreciate help testing it
> on a system that uses xf86-video-fbdev.
>
> Thanks!
>
> drivers/gpu/drm/exynos/exynos_drm_fbdev.c | 1 +
> 1 file changed, 1 insertion(+)
>
> diff --git a/drivers/gpu/drm/exynos/exynos_drm_fbdev.c b/drivers/gpu/drm/exynos/exynos_drm_fbdev.c
> index 5a7cd8b..f865736 100644
> --- a/drivers/gpu/drm/exynos/exynos_drm_fbdev.c
> +++ b/drivers/gpu/drm/exynos/exynos_drm_fbdev.c
> @@ -125,6 +125,7 @@ static int exynos_drm_fbdev_update(struct drm_fb_helper *helper,
>
> fbi->screen_base = buffer->kvaddr;
> fbi->screen_size = size;
> + fbi->fix.smem_len = size;
>
> return 0;
> }
> --
> 2.1.0.rc2.206.gedb03e5
More information about the dri-devel
mailing list