[RFC][PATCH v2 0/4] Support GEM object mappings from I/O memory

Thomas Zimmermann tzimmermann at suse.de
Fri Aug 14 06:51:25 UTC 2020


cc'ing TTM maintainers for comments. We might want to use the I/O
pointer structure with TTM at some point.

Am 06.08.20 um 10:52 schrieb Thomas Zimmermann:
> DRM's fbdev console uses regular load and store operations to update
> framebuffer memory. The bochs driver on sparc64 requires the use of
> I/O-specific load and store operations. We have a workaround, but need
> a long-term solution to the problem. Previous attempts to resolve the
> issue returned an extra is_iomem flag from vmap(), or added a separate
> vmap_iomem() callback to GEM objects.
> 
> This patchset is yet another iteration with a different idea. Instead
> of a raw pointer, vmap() interfaces now return a structure that contains
> the buffer address in system or I/O memory, plus a flag that signals
> which location the address is in.
> 
> Patch #1 updates the vboxvideo driver to match the latest VRAM helpers.
> This simplifies the other patches and should be merged in any case.
> 
> Patch #2 adds struct drm_gem_membuf, which contains the pointer and flag,
> and converts the generic GEM interfaces to use it.
> 
> Patch #3 converts vmap/vunmap in GEM object functions and updates most
> GEM backends. A few drivers are still missing, but the patch should be
> acceptable for an RFC.
> 
> Patch #4 changes fbdev helpers to access framebuffer memory either with
> system or I/O memcpy functions.
> 
> Thomas Zimmermann (4):
>   drm/vboxvideo: Use drm_gem_vram_vmap() interfaces
>   drm/gem: Update client API to use struct drm_gem_membuf
>   drm/gem: Use struct drm_gem_membuf in vmap op and convert GEM backends
>   drm/fb_helper: Access framebuffer as I/O memory, if required
> 
>  drivers/gpu/drm/ast/ast_cursor.c       |  29 ++-
>  drivers/gpu/drm/ast/ast_drv.h          |   2 +-
>  drivers/gpu/drm/bochs/bochs_kms.c      |   1 -
>  drivers/gpu/drm/drm_client.c           |  25 ++-
>  drivers/gpu/drm/drm_fb_helper.c        | 246 ++++++++++++++++++++++---
>  drivers/gpu/drm/drm_gem.c              |  28 +--
>  drivers/gpu/drm/drm_gem_cma_helper.c   |  15 +-
>  drivers/gpu/drm/drm_gem_shmem_helper.c |  31 ++--
>  drivers/gpu/drm/drm_gem_vram_helper.c  | 142 +++++---------
>  drivers/gpu/drm/drm_internal.h         |   5 +-
>  drivers/gpu/drm/drm_prime.c            |  16 +-
>  drivers/gpu/drm/mgag200/mgag200_mode.c |  11 +-
>  drivers/gpu/drm/qxl/qxl_display.c      |  12 +-
>  drivers/gpu/drm/qxl/qxl_draw.c         |  14 +-
>  drivers/gpu/drm/qxl/qxl_drv.h          |   6 +-
>  drivers/gpu/drm/qxl/qxl_object.c       |  19 +-
>  drivers/gpu/drm/qxl/qxl_object.h       |   2 +-
>  drivers/gpu/drm/qxl/qxl_prime.c        |  12 +-
>  drivers/gpu/drm/tiny/cirrus.c          |  15 +-
>  drivers/gpu/drm/tiny/gm12u320.c        |  12 +-
>  drivers/gpu/drm/udl/udl_modeset.c      |  10 +-
>  drivers/gpu/drm/vboxvideo/vbox_mode.c  |  17 +-
>  include/drm/drm_client.h               |   7 +-
>  include/drm/drm_device.h               |  26 +++
>  include/drm/drm_gem.h                  |   5 +-
>  include/drm/drm_gem_cma_helper.h       |   4 +-
>  include/drm/drm_gem_shmem_helper.h     |   4 +-
>  include/drm/drm_gem_vram_helper.h      |   9 +-
>  include/drm/drm_mode_config.h          |  12 --
>  29 files changed, 464 insertions(+), 273 deletions(-)
> 
> --
> 2.28.0
> 

-- 
Thomas Zimmermann
Graphics Driver Developer
SUSE Software Solutions Germany GmbH
Maxfeldstr. 5, 90409 Nürnberg, Germany
(HRB 36809, AG Nürnberg)
Geschäftsführer: Felix Imendörffer

-------------- next part --------------
A non-text attachment was scrubbed...
Name: signature.asc
Type: application/pgp-signature
Size: 516 bytes
Desc: OpenPGP digital signature
URL: <https://lists.freedesktop.org/archives/dri-devel/attachments/20200814/f5fce5a5/attachment.sig>


More information about the dri-devel mailing list