drm/fb-helper: Map DRM client buffer only when required
authorThomas Zimmermann <tzimmermann@suse.de>
Wed, 3 Jul 2019 07:58:24 +0000 (09:58 +0200)
committerThomas Zimmermann <tzimmermann@suse.de>
Tue, 9 Jul 2019 08:24:39 +0000 (10:24 +0200)
commitcf1ca9aeb930df074bb5bbcde55f935fec04e529
tree485b01b1eebd4d49c0854ed2f8d365f5282f561e
parent15dd0fc833407a513da162451ac3459650beecb6
drm/fb-helper: Map DRM client buffer only when required

This patch changes DRM clients to not map the buffer by default. The
buffer, like any buffer object, should be mapped and unmapped when
needed.

An unmapped buffer object can be evicted to system memory and does
not consume video ram until displayed. This allows to use generic fbdev
emulation with drivers for low-memory devices, such as ast and mgag200.

This change affects the generic framebuffer console. HW-based consoles
map their console buffer once and keep it mapped. Userspace can mmap this
buffer into its address space. The shadow-buffered framebuffer console
only needs the buffer object to be mapped during updates. While not being
updated from the shadow buffer, the buffer object can remain unmapped.
Userspace will always mmap the shadow buffer.

v2:
* change DRM client to not map buffer by default
* manually map client buffer for fbdev with HW framebuffer

Signed-off-by: Thomas Zimmermann <tzimmermann@suse.de>
Reviewed-by: Noralf Trønnes <noralf@tronnes.org>
Link: https://patchwork.freedesktop.org/patch/315830/
drivers/gpu/drm/drm_client.c
drivers/gpu/drm/drm_fb_helper.c