[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-Id: <20180605135407.20214-3-benjamin.gaignard@linaro.org>
Date: Tue, 5 Jun 2018 15:54:02 +0200
From: Benjamin Gaignard <benjamin.gaignard@...aro.org>
To: gustavo@...ovan.org, maarten.lankhorst@...ux.intel.com,
seanpaul@...omium.org, airlied@...ux.ie, vincent.abriou@...com
Cc: dri-devel@...ts.freedesktop.org, linux-kernel@...r.kernel.org,
Benjamin Gaignard <benjamin.gaignard@...aro.org>
Subject: [PATCH v1 2/7] drm: add hook to print encoder status
Even if encoders don't have state it could be useful to get information
from them when dumping of the other elements state.
Add an optional hook in drm_encoder_funcs structure and call it after crtc
print state.
Signed-off-by: Benjamin Gaignard <benjamin.gaignard@...aro.org>
---
drivers/gpu/drm/drm_atomic.c | 15 +++++++++++++++
include/drm/drm_encoder.h | 12 ++++++++++++
2 files changed, 27 insertions(+)
diff --git a/drivers/gpu/drm/drm_atomic.c b/drivers/gpu/drm/drm_atomic.c
index cd1d677617c8..6a9f5be01172 100644
--- a/drivers/gpu/drm/drm_atomic.c
+++ b/drivers/gpu/drm/drm_atomic.c
@@ -28,6 +28,7 @@
#include <drm/drmP.h>
#include <drm/drm_atomic.h>
+#include <drm/drm_encoder.h>
#include <drm/drm_mode.h>
#include <drm/drm_print.h>
#include <linux/sync_file.h>
@@ -1799,6 +1800,15 @@ int drm_atomic_nonblocking_commit(struct drm_atomic_state *state)
}
EXPORT_SYMBOL(drm_atomic_nonblocking_commit);
+static void drm_atomic_encoder_print(struct drm_printer *p,
+ struct drm_encoder *encoder)
+{
+ drm_printf(p, "encoder[%u]: %s\n", encoder->base.id, encoder->name);
+
+ if (encoder->funcs->atomic_print)
+ encoder->funcs->atomic_print(p, encoder);
+}
+
static void drm_atomic_print_state(const struct drm_atomic_state *state)
{
struct drm_printer p = drm_info_printer(state->dev->dev);
@@ -1828,6 +1838,7 @@ static void __drm_state_dump(struct drm_device *dev, struct drm_printer *p,
struct drm_mode_config *config = &dev->mode_config;
struct drm_plane *plane;
struct drm_crtc *crtc;
+ struct drm_encoder *encoder;
struct drm_connector *connector;
struct drm_connector_list_iter conn_iter;
@@ -1850,6 +1861,10 @@ static void __drm_state_dump(struct drm_device *dev, struct drm_printer *p,
drm_modeset_unlock(&crtc->mutex);
}
+ drm_for_each_encoder(encoder, dev) {
+ drm_atomic_encoder_print(p, encoder);
+ }
+
drm_connector_list_iter_begin(dev, &conn_iter);
if (take_locks)
drm_modeset_lock(&dev->mode_config.connection_mutex, NULL);
diff --git a/include/drm/drm_encoder.h b/include/drm/drm_encoder.h
index fb299696c7c4..b847dad817b0 100644
--- a/include/drm/drm_encoder.h
+++ b/include/drm/drm_encoder.h
@@ -80,6 +80,18 @@ struct drm_encoder_funcs {
* before data structures are torndown.
*/
void (*early_unregister)(struct drm_encoder *encoder);
+
+ /**
+ * @atomic_print
+ *
+ * If driver could implement this optional hook for printing
+ * additional driver specific information.
+ *
+ * Do not call this directly, use drm_atomic_encoder_print()
+ * instead.
+ */
+ void (*atomic_print)(struct drm_printer *p,
+ struct drm_encoder *encoder);
};
/**
--
2.15.0
Powered by blists - more mailing lists