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

2018-10-01 Thread Daniel Vetter
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@lists.freedesktop.org
> https://lists.freedesktop.org/mailman/listinfo/dri-devel

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


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

2018-09-26 Thread Noralf Trønnes
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.

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@lists.freedesktop.org
https://lists.freedesktop.org/mailman/listinfo/dri-devel