drm/msm/dp: Use the connector passed to dp_debug_get()
The debugfs code is provided an array of a single drm_connector. Then to access the connector, the list of all connectors of the DRM device is traversed and all non-DisplayPort connectors are skipped, to find the one and only DisplayPort connector. But as we move to support multiple DisplayPort controllers this will now find multiple connectors and has no way to distinguish them. Pass the single connector to dp_debug_get() and use this in the debugfs functions instead, both to simplify the code and the support the multiple instances. Reviewed-by: Abhinav Kumar <abhinavk@codeaurora.org> Reviewed-by: Stephen Boyd <swboyd@chromium.org> Signed-off-by: Bjorn Andersson <bjorn.andersson@linaro.org> Link: https://lore.kernel.org/r/20211015232213.1839472-1-bjorn.andersson@linaro.org Signed-off-by: Rob Clark <robdclark@chromium.org>
This commit is contained in:
parent
1c8e5748fa
commit
899b2608d8
|
@ -24,7 +24,7 @@ struct dp_debug_private {
|
|||
struct dp_usbpd *usbpd;
|
||||
struct dp_link *link;
|
||||
struct dp_panel *panel;
|
||||
struct drm_connector **connector;
|
||||
struct drm_connector *connector;
|
||||
struct device *dev;
|
||||
struct drm_device *drm_dev;
|
||||
|
||||
|
@ -205,59 +205,35 @@ static ssize_t dp_debug_read_info(struct file *file, char __user *user_buff,
|
|||
|
||||
static int dp_test_data_show(struct seq_file *m, void *data)
|
||||
{
|
||||
struct drm_device *dev;
|
||||
struct dp_debug_private *debug;
|
||||
struct drm_connector *connector;
|
||||
struct drm_connector_list_iter conn_iter;
|
||||
const struct dp_debug_private *debug = m->private;
|
||||
const struct drm_connector *connector = debug->connector;
|
||||
u32 bpc;
|
||||
|
||||
debug = m->private;
|
||||
dev = debug->drm_dev;
|
||||
drm_connector_list_iter_begin(dev, &conn_iter);
|
||||
drm_for_each_connector_iter(connector, &conn_iter) {
|
||||
|
||||
if (connector->connector_type !=
|
||||
DRM_MODE_CONNECTOR_DisplayPort)
|
||||
continue;
|
||||
|
||||
if (connector->status == connector_status_connected) {
|
||||
bpc = debug->link->test_video.test_bit_depth;
|
||||
seq_printf(m, "hdisplay: %d\n",
|
||||
debug->link->test_video.test_h_width);
|
||||
seq_printf(m, "vdisplay: %d\n",
|
||||
debug->link->test_video.test_v_height);
|
||||
seq_printf(m, "bpc: %u\n",
|
||||
dp_link_bit_depth_to_bpc(bpc));
|
||||
} else
|
||||
seq_puts(m, "0");
|
||||
if (connector->status == connector_status_connected) {
|
||||
bpc = debug->link->test_video.test_bit_depth;
|
||||
seq_printf(m, "hdisplay: %d\n",
|
||||
debug->link->test_video.test_h_width);
|
||||
seq_printf(m, "vdisplay: %d\n",
|
||||
debug->link->test_video.test_v_height);
|
||||
seq_printf(m, "bpc: %u\n",
|
||||
dp_link_bit_depth_to_bpc(bpc));
|
||||
} else {
|
||||
seq_puts(m, "0");
|
||||
}
|
||||
|
||||
drm_connector_list_iter_end(&conn_iter);
|
||||
|
||||
return 0;
|
||||
}
|
||||
DEFINE_SHOW_ATTRIBUTE(dp_test_data);
|
||||
|
||||
static int dp_test_type_show(struct seq_file *m, void *data)
|
||||
{
|
||||
struct dp_debug_private *debug = m->private;
|
||||
struct drm_device *dev = debug->drm_dev;
|
||||
struct drm_connector *connector;
|
||||
struct drm_connector_list_iter conn_iter;
|
||||
const struct dp_debug_private *debug = m->private;
|
||||
const struct drm_connector *connector = debug->connector;
|
||||
|
||||
drm_connector_list_iter_begin(dev, &conn_iter);
|
||||
drm_for_each_connector_iter(connector, &conn_iter) {
|
||||
|
||||
if (connector->connector_type !=
|
||||
DRM_MODE_CONNECTOR_DisplayPort)
|
||||
continue;
|
||||
|
||||
if (connector->status == connector_status_connected)
|
||||
seq_printf(m, "%02x", DP_TEST_LINK_VIDEO_PATTERN);
|
||||
else
|
||||
seq_puts(m, "0");
|
||||
}
|
||||
drm_connector_list_iter_end(&conn_iter);
|
||||
if (connector->status == connector_status_connected)
|
||||
seq_printf(m, "%02x", DP_TEST_LINK_VIDEO_PATTERN);
|
||||
else
|
||||
seq_puts(m, "0");
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
@ -269,14 +245,12 @@ static ssize_t dp_test_active_write(struct file *file,
|
|||
{
|
||||
char *input_buffer;
|
||||
int status = 0;
|
||||
struct dp_debug_private *debug;
|
||||
struct drm_device *dev;
|
||||
struct drm_connector *connector;
|
||||
struct drm_connector_list_iter conn_iter;
|
||||
const struct dp_debug_private *debug;
|
||||
const struct drm_connector *connector;
|
||||
int val = 0;
|
||||
|
||||
debug = ((struct seq_file *)file->private_data)->private;
|
||||
dev = debug->drm_dev;
|
||||
connector = debug->connector;
|
||||
|
||||
if (len == 0)
|
||||
return 0;
|
||||
|
@ -287,30 +261,22 @@ static ssize_t dp_test_active_write(struct file *file,
|
|||
|
||||
DRM_DEBUG_DRIVER("Copied %d bytes from user\n", (unsigned int)len);
|
||||
|
||||
drm_connector_list_iter_begin(dev, &conn_iter);
|
||||
drm_for_each_connector_iter(connector, &conn_iter) {
|
||||
if (connector->connector_type !=
|
||||
DRM_MODE_CONNECTOR_DisplayPort)
|
||||
continue;
|
||||
|
||||
if (connector->status == connector_status_connected) {
|
||||
status = kstrtoint(input_buffer, 10, &val);
|
||||
if (status < 0)
|
||||
break;
|
||||
DRM_DEBUG_DRIVER("Got %d for test active\n", val);
|
||||
/* To prevent erroneous activation of the compliance
|
||||
* testing code, only accept an actual value of 1 here
|
||||
*/
|
||||
if (val == 1)
|
||||
debug->panel->video_test = true;
|
||||
else
|
||||
debug->panel->video_test = false;
|
||||
if (connector->status == connector_status_connected) {
|
||||
status = kstrtoint(input_buffer, 10, &val);
|
||||
if (status < 0) {
|
||||
kfree(input_buffer);
|
||||
return status;
|
||||
}
|
||||
DRM_DEBUG_DRIVER("Got %d for test active\n", val);
|
||||
/* To prevent erroneous activation of the compliance
|
||||
* testing code, only accept an actual value of 1 here
|
||||
*/
|
||||
if (val == 1)
|
||||
debug->panel->video_test = true;
|
||||
else
|
||||
debug->panel->video_test = false;
|
||||
}
|
||||
drm_connector_list_iter_end(&conn_iter);
|
||||
kfree(input_buffer);
|
||||
if (status < 0)
|
||||
return status;
|
||||
|
||||
*offp += len;
|
||||
return len;
|
||||
|
@ -319,25 +285,16 @@ static ssize_t dp_test_active_write(struct file *file,
|
|||
static int dp_test_active_show(struct seq_file *m, void *data)
|
||||
{
|
||||
struct dp_debug_private *debug = m->private;
|
||||
struct drm_device *dev = debug->drm_dev;
|
||||
struct drm_connector *connector;
|
||||
struct drm_connector_list_iter conn_iter;
|
||||
struct drm_connector *connector = debug->connector;
|
||||
|
||||
drm_connector_list_iter_begin(dev, &conn_iter);
|
||||
drm_for_each_connector_iter(connector, &conn_iter) {
|
||||
if (connector->connector_type !=
|
||||
DRM_MODE_CONNECTOR_DisplayPort)
|
||||
continue;
|
||||
|
||||
if (connector->status == connector_status_connected) {
|
||||
if (debug->panel->video_test)
|
||||
seq_puts(m, "1");
|
||||
else
|
||||
seq_puts(m, "0");
|
||||
} else
|
||||
if (connector->status == connector_status_connected) {
|
||||
if (debug->panel->video_test)
|
||||
seq_puts(m, "1");
|
||||
else
|
||||
seq_puts(m, "0");
|
||||
} else {
|
||||
seq_puts(m, "0");
|
||||
}
|
||||
drm_connector_list_iter_end(&conn_iter);
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
@ -391,7 +348,7 @@ static int dp_debug_init(struct dp_debug *dp_debug, struct drm_minor *minor)
|
|||
|
||||
struct dp_debug *dp_debug_get(struct device *dev, struct dp_panel *panel,
|
||||
struct dp_usbpd *usbpd, struct dp_link *link,
|
||||
struct drm_connector **connector, struct drm_minor *minor)
|
||||
struct drm_connector *connector, struct drm_minor *minor)
|
||||
{
|
||||
int rc = 0;
|
||||
struct dp_debug_private *debug;
|
||||
|
|
|
@ -43,7 +43,7 @@ struct dp_debug {
|
|||
*/
|
||||
struct dp_debug *dp_debug_get(struct device *dev, struct dp_panel *panel,
|
||||
struct dp_usbpd *usbpd, struct dp_link *link,
|
||||
struct drm_connector **connector,
|
||||
struct drm_connector *connector,
|
||||
struct drm_minor *minor);
|
||||
|
||||
/**
|
||||
|
@ -60,7 +60,7 @@ void dp_debug_put(struct dp_debug *dp_debug);
|
|||
static inline
|
||||
struct dp_debug *dp_debug_get(struct device *dev, struct dp_panel *panel,
|
||||
struct dp_usbpd *usbpd, struct dp_link *link,
|
||||
struct drm_connector **connector, struct drm_minor *minor)
|
||||
struct drm_connector *connector, struct drm_minor *minor)
|
||||
{
|
||||
return ERR_PTR(-EINVAL);
|
||||
}
|
||||
|
|
|
@ -1429,7 +1429,7 @@ void msm_dp_debugfs_init(struct msm_dp *dp_display, struct drm_minor *minor)
|
|||
dev = &dp->pdev->dev;
|
||||
|
||||
dp->debug = dp_debug_get(dev, dp->panel, dp->usbpd,
|
||||
dp->link, &dp->dp_display.connector,
|
||||
dp->link, dp->dp_display.connector,
|
||||
minor);
|
||||
if (IS_ERR(dp->debug)) {
|
||||
rc = PTR_ERR(dp->debug);
|
||||
|
|
Loading…
Reference in New Issue