@@ -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);
@@ -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
@@ -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)
{
}
@@ -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:
*
@@ -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*),
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@igalia.com> --- 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(+)