[PATCH 0/6] drm/debugfs: Make the debugfs structure more generic
Maíra Canal
mcanal at igalia.com
Mon Jan 16 10:28:10 UTC 2023
This series is the first step to introduce a debugfs structure to KMS objects
and it is inspired by the feedback provided in [1]. Thanks, Jani and Daniel for
all the feedback provided!
This first step is making the current API more generic and preparing it to
receive the KMS objects in the future. Moreover, this will help to avoid
copypasting when expanding the API.
Make the debug structure more generic by:
- Passing the right pointer to the functions as an explicit parameter. So, the
show function signature should be
int show(struct seq_file *m, struct drm_device *dev, void *data)
Note that with this approach, the show callback doesn't need to use the struct
drm_debugfs_entry anymore.
- Switch the pointer in struct drm_debugfs_entry to void *, so that, in the
future, the struct drm_debugfs_entry can receive different types of DRM
objects (struct drm_device, struct drm_connector, struct drm_crtc...).
- Switch the show callback pointer to void * and cast it in the show callback
wrapper. This way in the future we can create different callback wrappers and
cast each one to the proper function signature.
- Add a struct wrapper for debugfs_list and debugfs_mutex, and also create
helpers to init the list, destroy the list, register the list's files and add
files to the list.
[1] https://lore.kernel.org/dri-devel/20230111173748.752659-1-mcanal@igalia.com/T/
Any feedback is welcomed!
Best Regards,
- Maíra Canal
Maíra Canal (6):
drm/debugfs: Introduce wrapper for debugfs list
drm/debugfs: Make drm_device use the struct drm_debugfs_list
drm/debugfs: Create wrapper to add files to debugfs list
drm/debugfs: Create wrapper to register debugfs
drm/debugfs: Make the struct drm_debugfs_entry independent of DRM
device
drm/debugfs: Make the show callback pass the pointer to the right
object
drivers/gpu/drm/arm/hdlcd_drv.c | 8 +--
drivers/gpu/drm/drm_atomic.c | 4 +-
drivers/gpu/drm/drm_client.c | 5 +-
drivers/gpu/drm/drm_debugfs.c | 74 ++++++++++++++++-----------
drivers/gpu/drm/drm_drv.c | 7 +--
drivers/gpu/drm/drm_framebuffer.c | 4 +-
drivers/gpu/drm/drm_gem_vram_helper.c | 2 +-
drivers/gpu/drm/drm_internal.h | 11 ++++
drivers/gpu/drm/gud/gud_drv.c | 5 +-
drivers/gpu/drm/v3d/v3d_debugfs.c | 16 ++----
drivers/gpu/drm/vc4/vc4_bo.c | 4 +-
drivers/gpu/drm/vc4/vc4_debugfs.c | 6 +--
drivers/gpu/drm/vc4/vc4_hdmi.c | 6 +--
drivers/gpu/drm/vc4/vc4_hvs.c | 8 +--
drivers/gpu/drm/vc4/vc4_v3d.c | 4 +-
drivers/gpu/drm/vkms/vkms_drv.c | 4 +-
include/drm/drm_debugfs.h | 34 +++++++++---
include/drm/drm_device.h | 10 +---
18 files changed, 110 insertions(+), 102 deletions(-)
--
2.39.0
More information about the dri-devel
mailing list