Introduce the ability to add DRM debugfs files to a list managed by the crtc and, during drm_crtc_register_all(), all added files will be created at once. Moreover, introduce some typesafety as struct drm_debugfs_crtc_entry holds a drm_crtc instead of a drm_device. So, the drivers can get a crtc object directly from the struct drm_debugfs_crtc_entry in the show() callback. Signed-off-by: Maíra Canal <mcanal@xxxxxxxxxx> --- drivers/gpu/drm/drm_crtc.c | 5 +++++ drivers/gpu/drm/drm_debugfs.c | 33 +++++++++++++++++++++++++++++++++ drivers/gpu/drm/drm_internal.h | 5 +++++ include/drm/drm_crtc.h | 15 +++++++++++++++ include/drm/drm_debugfs.h | 25 +++++++++++++++++++++++++ 5 files changed, 83 insertions(+) diff --git a/drivers/gpu/drm/drm_crtc.c b/drivers/gpu/drm/drm_crtc.c index df9bf3c9206e..2953eef3e88e 100644 --- a/drivers/gpu/drm/drm_crtc.c +++ b/drivers/gpu/drm/drm_crtc.c @@ -131,6 +131,8 @@ int drm_crtc_register_all(struct drm_device *dev) ret = crtc->funcs->late_register(crtc); if (ret) return ret; + + drm_debugfs_crtc_init(crtc); } return 0; @@ -268,7 +270,9 @@ static int __drm_crtc_init_with_planes(struct drm_device *dev, struct drm_crtc * crtc->funcs = funcs; INIT_LIST_HEAD(&crtc->commit_list); + INIT_LIST_HEAD(&crtc->debugfs_list); spin_lock_init(&crtc->commit_lock); + mutex_init(&crtc->debugfs_mutex); drm_modeset_lock_init(&crtc->mutex); ret = drm_mode_object_add(dev, &crtc->base, DRM_MODE_OBJECT_CRTC); @@ -508,6 +512,7 @@ void drm_crtc_cleanup(struct drm_crtc *crtc) crtc->gamma_store = NULL; drm_modeset_lock_fini(&crtc->mutex); + mutex_destroy(&crtc->debugfs_mutex); drm_mode_object_unregister(dev, &crtc->base); list_del(&crtc->head); diff --git a/drivers/gpu/drm/drm_debugfs.c b/drivers/gpu/drm/drm_debugfs.c index 6a763fe1b031..e1f71a03a581 100644 --- a/drivers/gpu/drm/drm_debugfs.c +++ b/drivers/gpu/drm/drm_debugfs.c @@ -261,6 +261,17 @@ int drm_debugfs_init(struct drm_minor *minor, int minor_id, return 0; } +void drm_debugfs_crtc_init(struct drm_crtc *crtc) +{ + struct drm_minor *minor = crtc->dev->primary; + struct drm_debugfs_crtc_entry *entry, *tmp; + + if (!minor) + return; + + drm_create_file_from_list(crtc); +} + void drm_debugfs_connector_init(struct drm_connector *connector) { struct drm_minor *minor = connector->dev->primary; @@ -392,6 +403,28 @@ void drm_debugfs_add_files(struct drm_device *dev, const struct drm_debugfs_info } EXPORT_SYMBOL(drm_debugfs_add_files); +/** + * drm_debugfs_crtc_add_file - Add a given file to the DRM crtc debugfs file list + * @crtc: DRM crtc object + * @name: debugfs file name + * @show: show callback + * @data: driver-private data, should not be device-specific + * Add a given file entry to the DRM crtc debugfs file list to be created on + * drm_debugfs_crtc_init(). + */ +void drm_debugfs_crtc_add_file(struct drm_crtc *crtc, const char *name, + int (*show)(struct seq_file*, void*), void *data) +{ + struct drm_debugfs_crtc_entry *entry = drmm_kzalloc(crtc->dev, sizeof(*entry), + GFP_KERNEL); + + if (!entry) + return; + + drm_debugfs_add_file_to_list(crtc); +} +EXPORT_SYMBOL(drm_debugfs_crtc_add_file); + /** * drm_debugfs_connector_add_file - Add a given file to the DRM connector debugfs file list * @connector: DRM connector object diff --git a/drivers/gpu/drm/drm_internal.h b/drivers/gpu/drm/drm_internal.h index 363936ee8628..9be697f7f8f9 100644 --- a/drivers/gpu/drm/drm_internal.h +++ b/drivers/gpu/drm/drm_internal.h @@ -185,6 +185,7 @@ int drm_gem_dumb_destroy(struct drm_file *file, struct drm_device *dev, #if defined(CONFIG_DEBUG_FS) int drm_debugfs_init(struct drm_minor *minor, int minor_id, struct dentry *root); +void drm_debugfs_crtc_init(struct drm_crtc *crtc); void drm_debugfs_connector_init(struct drm_connector *connector); void drm_debugfs_encoder_init(struct drm_encoder *encoder); void drm_debugfs_cleanup(struct drm_minor *minor); @@ -201,6 +202,10 @@ static inline int drm_debugfs_init(struct drm_minor *minor, int minor_id, return 0; } +static inline void drm_debugfs_crtc_init(struct drm_crtc *crtc) +{ +} + static inline void drm_debugfs_connector_init(struct drm_connector *connector) { } diff --git a/include/drm/drm_crtc.h b/include/drm/drm_crtc.h index 8e1cbc75143e..612928929646 100644 --- a/include/drm/drm_crtc.h +++ b/include/drm/drm_crtc.h @@ -1139,6 +1139,21 @@ struct drm_crtc { */ struct dentry *debugfs_entry; + /** + * @debugfs_mutex: + * + * Protects &debugfs_list access. + */ + struct mutex debugfs_mutex; + + /** + * @debugfs_list: + * + * List of debugfs files to be created by the DRM crtc. The files + * must be added during drm_crtc_register_all(). + */ + struct list_head debugfs_list; + /** * @crc: * diff --git a/include/drm/drm_debugfs.h b/include/drm/drm_debugfs.h index 677ed3fee5e1..47f23615139f 100644 --- a/include/drm/drm_debugfs.h +++ b/include/drm/drm_debugfs.h @@ -122,6 +122,23 @@ struct drm_debugfs_entry { struct list_head list; }; +/** + * struct drm_debugfs_crtc_entry - Per-crtc debugfs node structure + * + * This structure represents a debugfs file, as an instantiation of a &struct + * drm_debugfs_info on a &struct drm_crtc. + */ +struct drm_debugfs_crtc_entry { + /** @crtc: &struct drm_crtc for this node. */ + struct drm_crtc *crtc; + + /** @file: Template for this node. */ + struct drm_debugfs_info file; + + /** @list: Linked list of all crtc nodes. */ + struct list_head list; +}; + /** * struct drm_debugfs_connector_entry - Per-connector debugfs node structure * @@ -169,6 +186,9 @@ void drm_debugfs_add_file(struct drm_device *dev, const char *name, void drm_debugfs_add_files(struct drm_device *dev, const struct drm_debugfs_info *files, int count); +void drm_debugfs_crtc_add_file(struct drm_crtc *crtc, const char *name, + int (*show)(struct seq_file*, void*), void *data); + void drm_debugfs_connector_add_file(struct drm_connector *connector, const char *name, int (*show)(struct seq_file*, void*), void *data); @@ -196,6 +216,11 @@ static inline void drm_debugfs_add_files(struct drm_device *dev, int count) {} +static inline void drm_debugfs_crtc_add_file(struct drm_crtc *crtc, const char *name, + int (*show)(struct seq_file*, void*), + void *data) +{} + static inline void drm_debugfs_connector_add_file(struct drm_connector *connector, const char *name, int (*show)(struct seq_file*, void*), -- 2.39.0