[RFC 0/3] drm/gem: Add drm_gem_object_funcs
Noralf Trønnes
noralf at tronnes.org
Sat Sep 22 15:57:11 UTC 2018
Den 22.09.2018 12.04, skrev Daniel Vetter:
> On Fri, Sep 21, 2018 at 06:42:27PM +0200, Noralf Trønnes wrote:
>> Hi,
>>
>> I've found it odd that the GEM object has its callbacks on drm_driver
>> and not a vtable of its own. But something being odd isn't enough to
>> make a change (me thinks).
>>
>> After working on the GEM shmem helper I saw that a few drivers have
>> runtime support for 2 memory types for their buffers (shmem,vram,cma).
>> I have realised that if the shmem helper was self contained wrt the
>> callbacks, it would be easier for these types of drivers to use the
>> helper. All they needed to do was to determine the buffer type on GEM
>> object creation time and let the helper handle the rest of the
>> callbacks.
>>
>> No sure if this makes sense or if the approach is to simplistic. Hence
>> the RFC.
>>
>> I've added a patch to give an example of how this would look for the CMA
>> helper and vc4 (I'm not volunteering to refactor the CMA helper and
>> drivers).
> I very much like, the drm_driver dumping ground has been a sore spot for
> me for a long time, and the per-object callback structures look so much
> nicer in kms. That's why I also really liked moving all the vblank stuff
> from drm_driver to the drm_crtc_(helper_)funcs struct.
Cool, let's make this happen :-)
Noralf.
> Cheers, Daniel
>> Noralf.
>>
>> Noralf Trønnes (3):
>> drm/driver: Add defaults for .gem_prime_export/import callbacks
>> drm/gem: Add drm_gem_object_funcs
>> drm/cma: Use drm_gem_object_funcs
>>
>> Documentation/gpu/todo.rst | 7 ++
>> drivers/gpu/drm/drm_client.c | 12 ++-
>> drivers/gpu/drm/drm_fb_helper.c | 8 +-
>> drivers/gpu/drm/drm_gem.c | 108 +++++++++++++++++++++++++--
>> drivers/gpu/drm/drm_gem_cma_helper.c | 99 +++++++++----------------
>> drivers/gpu/drm/drm_prime.c | 50 +++++++------
>> drivers/gpu/drm/vc4/vc4_bo.c | 46 ++++++------
>> drivers/gpu/drm/vc4/vc4_drv.c | 26 +------
>> drivers/gpu/drm/vc4/vc4_drv.h | 6 +-
>> include/drm/drm_drv.h | 4 +
>> include/drm/drm_gem.h | 138 +++++++++++++++++++++++++++++++++++
>> include/drm/drm_gem_cma_helper.h | 17 +----
>> 12 files changed, 350 insertions(+), 171 deletions(-)
>>
>> --
>> 2.15.1
>>
>> _______________________________________________
>> dri-devel mailing list
>> dri-devel at lists.freedesktop.org
>> https://lists.freedesktop.org/mailman/listinfo/dri-devel
More information about the dri-devel
mailing list