Re: [PATCH v4 0/4] drm: Add shmem GEM library

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



On Wed, Sep 26, 2018 at 04:59:29PM +0200, Noralf Trønnes wrote:
> This patchset adds a library for shmem backed GEM objects and makes use
> of it in tinydrm.
> 
> Thomas gave me some feedback that made me realise that the cachemodes
> pattern I had picked up from some other drivers didn't apply to shmem
> buffers in the way I though it did. So it's removed.
> 
> I recently did an RFC to see if it made sense to add a vtable to GEM
> objects. Daniel welcomed that so I've included it here.

I like this. Made some tiny comments, but proof's in the pudding so I'll
leave review to someone who knows tinydrm better. Or other driver
maintainers, if you extend the scope a bit. From a high level I think it's
ready, looks all reasonable (except maybe the prime_mmap stuff, that seems
like it can be improved a bit more still).
-Daniel

> 
> Noralf.
> 
> Changes since version 3:
> - Drop cache modes (Thomas Hellstrom)
> - Add a GEM object attached vtable
> 
> Changes since version 2:
> - Grammar (Sam Ravnborg)
> - s/drm_gem_shmem_put_pages_unlocked/drm_gem_shmem_put_pages_locked/
> (Sam Ravnborg)
> - Add debug ouput in error path (Sam Ravnborg)
> 
> Changes since version 1:
> - Fix missing argument in docs (kbuild test robot)
> - Fix: sparse: expression using sizeof(void) (kbuild test robot)
> - Rebasing gave a new checkpatch warning, so I changed to bitfields:
> CHECK: Avoid using bool structure members because of possible alignment
> issues - see: https://lkml.org/lkml/2017/11/21/384
> #834: FILE: include/drm/drm_gem_shmem_helper.h:84:
> +       bool pages_mark_dirty_on_put;
> #841: FILE: include/drm/drm_gem_shmem_helper.h:91:
> +       bool pages_mark_accessed_on_put;
> 
> Noralf Trønnes (4):
>   drm/driver: Add defaults for .gem_prime_export/import callbacks
>   drm/gem: Add drm_gem_object_funcs
>   drm: Add library for shmem backed GEM objects
>   drm/tinydrm: Switch from CMA to shmem buffers
> 
>  Documentation/gpu/drm-kms-helpers.rst          |  12 +
>  Documentation/gpu/todo.rst                     |   7 +
>  drivers/gpu/drm/Kconfig                        |   6 +
>  drivers/gpu/drm/Makefile                       |   1 +
>  drivers/gpu/drm/drm_client.c                   |  12 +-
>  drivers/gpu/drm/drm_fb_helper.c                |   8 +-
>  drivers/gpu/drm/drm_gem.c                      | 109 ++++-
>  drivers/gpu/drm/drm_gem_shmem_helper.c         | 586 +++++++++++++++++++++++++
>  drivers/gpu/drm/drm_prime.c                    |  50 ++-
>  drivers/gpu/drm/tinydrm/Kconfig                |   2 +-
>  drivers/gpu/drm/tinydrm/core/tinydrm-core.c    |  92 ++--
>  drivers/gpu/drm/tinydrm/core/tinydrm-helpers.c |   5 +
>  drivers/gpu/drm/tinydrm/ili9225.c              |  14 +-
>  drivers/gpu/drm/tinydrm/ili9341.c              |   6 +-
>  drivers/gpu/drm/tinydrm/mi0283qt.c             |   6 +-
>  drivers/gpu/drm/tinydrm/mipi-dbi.c             |  38 +-
>  drivers/gpu/drm/tinydrm/repaper.c              |  24 +-
>  drivers/gpu/drm/tinydrm/st7586.c               |  15 +-
>  drivers/gpu/drm/tinydrm/st7735r.c              |   6 +-
>  include/drm/drm_drv.h                          |   4 +
>  include/drm/drm_gem.h                          | 140 ++++++
>  include/drm/drm_gem_shmem_helper.h             | 153 +++++++
>  include/drm/tinydrm/tinydrm.h                  |  36 +-
>  23 files changed, 1139 insertions(+), 193 deletions(-)
>  create mode 100644 drivers/gpu/drm/drm_gem_shmem_helper.c
>  create mode 100644 include/drm/drm_gem_shmem_helper.h
> 
> -- 
> 2.15.1
> 
> _______________________________________________
> dri-devel mailing list
> dri-devel@xxxxxxxxxxxxxxxxxxxxx
> https://lists.freedesktop.org/mailman/listinfo/dri-devel

-- 
Daniel Vetter
Software Engineer, Intel Corporation
http://blog.ffwll.ch
_______________________________________________
dri-devel mailing list
dri-devel@xxxxxxxxxxxxxxxxxxxxx
https://lists.freedesktop.org/mailman/listinfo/dri-devel




[Index of Archives]     [Linux DRI Users]     [Linux Intel Graphics]     [Linux USB Devel]     [Video for Linux]     [Linux Audio Users]     [Yosemite News]     [Linux Kernel]     [Linux SCSI]     [XFree86]     [Linux USB Devel]     [Video for Linux]     [Linux Audio Users]     [Linux Kernel]     [Linux SCSI]     [XFree86]
  Powered by Linux