Commit c4715837 authored by Laurent Pinchart's avatar Laurent Pinchart Committed by Sam Ravnborg

drm: panel: simple: Drop drive/sample bus flags for LVDS panels

The DRM bus flags reporting on which clock edge the pixel data and sync
signals are sampled or driven don't make sense for LVDS panels, as the
bus then uses sub-clock timings to send data. Drop those flags and add a
warning in the probe function to make sure the mistake won't be
repeated.
Signed-off-by: default avatarLaurent Pinchart <laurent.pinchart+renesas@ideasonboard.com>
Signed-off-by: default avatarSam Ravnborg <sam@ravnborg.org>
Link: https://patchwork.freedesktop.org/patch/msgid/20200629233320.8774-4-laurent.pinchart+renesas@ideasonboard.com
parent 34ca6b53
...@@ -549,6 +549,14 @@ static int panel_simple_probe(struct device *dev, const struct panel_desc *desc) ...@@ -549,6 +549,14 @@ static int panel_simple_probe(struct device *dev, const struct panel_desc *desc)
panel_simple_parse_panel_timing_node(dev, panel, &dt); panel_simple_parse_panel_timing_node(dev, panel, &dt);
} }
if (desc->connector_type == DRM_MODE_CONNECTOR_LVDS)
/* Catch common mistakes for LVDS panels. */
WARN_ON(desc->bus_flags &
~(DRM_BUS_FLAG_DE_LOW |
DRM_BUS_FLAG_DE_HIGH |
DRM_BUS_FLAG_DATA_MSB_TO_LSB |
DRM_BUS_FLAG_DATA_LSB_TO_MSB));
drm_panel_init(&panel->base, dev, &panel_simple_funcs, drm_panel_init(&panel->base, dev, &panel_simple_funcs,
desc->connector_type); desc->connector_type);
...@@ -688,7 +696,7 @@ static const struct panel_desc auo_b101aw03 = { ...@@ -688,7 +696,7 @@ static const struct panel_desc auo_b101aw03 = {
.height = 125, .height = 125,
}, },
.bus_format = MEDIA_BUS_FMT_RGB666_1X7X3_SPWG, .bus_format = MEDIA_BUS_FMT_RGB666_1X7X3_SPWG,
.bus_flags = DRM_BUS_FLAG_DE_HIGH | DRM_BUS_FLAG_PIXDATA_DRIVE_POSEDGE, .bus_flags = DRM_BUS_FLAG_DE_HIGH,
.connector_type = DRM_MODE_CONNECTOR_LVDS, .connector_type = DRM_MODE_CONNECTOR_LVDS,
}; };
...@@ -1398,7 +1406,7 @@ static const struct panel_desc chunghwa_claa070wp03xg = { ...@@ -1398,7 +1406,7 @@ static const struct panel_desc chunghwa_claa070wp03xg = {
.height = 150, .height = 150,
}, },
.bus_format = MEDIA_BUS_FMT_RGB666_1X7X3_SPWG, .bus_format = MEDIA_BUS_FMT_RGB666_1X7X3_SPWG,
.bus_flags = DRM_BUS_FLAG_DE_HIGH | DRM_BUS_FLAG_PIXDATA_DRIVE_POSEDGE, .bus_flags = DRM_BUS_FLAG_DE_HIGH,
.connector_type = DRM_MODE_CONNECTOR_LVDS, .connector_type = DRM_MODE_CONNECTOR_LVDS,
}; };
...@@ -1423,7 +1431,7 @@ static const struct panel_desc chunghwa_claa101wa01a = { ...@@ -1423,7 +1431,7 @@ static const struct panel_desc chunghwa_claa101wa01a = {
.height = 120, .height = 120,
}, },
.bus_format = MEDIA_BUS_FMT_RGB666_1X7X3_SPWG, .bus_format = MEDIA_BUS_FMT_RGB666_1X7X3_SPWG,
.bus_flags = DRM_BUS_FLAG_DE_HIGH | DRM_BUS_FLAG_PIXDATA_DRIVE_POSEDGE, .bus_flags = DRM_BUS_FLAG_DE_HIGH,
.connector_type = DRM_MODE_CONNECTOR_LVDS, .connector_type = DRM_MODE_CONNECTOR_LVDS,
}; };
...@@ -1448,7 +1456,7 @@ static const struct panel_desc chunghwa_claa101wb01 = { ...@@ -1448,7 +1456,7 @@ static const struct panel_desc chunghwa_claa101wb01 = {
.height = 125, .height = 125,
}, },
.bus_format = MEDIA_BUS_FMT_RGB666_1X7X3_SPWG, .bus_format = MEDIA_BUS_FMT_RGB666_1X7X3_SPWG,
.bus_flags = DRM_BUS_FLAG_DE_HIGH | DRM_BUS_FLAG_PIXDATA_DRIVE_POSEDGE, .bus_flags = DRM_BUS_FLAG_DE_HIGH,
.connector_type = DRM_MODE_CONNECTOR_LVDS, .connector_type = DRM_MODE_CONNECTOR_LVDS,
}; };
...@@ -2123,7 +2131,7 @@ static const struct panel_desc innolux_n156bge_l21 = { ...@@ -2123,7 +2131,7 @@ static const struct panel_desc innolux_n156bge_l21 = {
.height = 193, .height = 193,
}, },
.bus_format = MEDIA_BUS_FMT_RGB666_1X7X3_SPWG, .bus_format = MEDIA_BUS_FMT_RGB666_1X7X3_SPWG,
.bus_flags = DRM_BUS_FLAG_DE_HIGH | DRM_BUS_FLAG_PIXDATA_DRIVE_POSEDGE, .bus_flags = DRM_BUS_FLAG_DE_HIGH,
.connector_type = DRM_MODE_CONNECTOR_LVDS, .connector_type = DRM_MODE_CONNECTOR_LVDS,
}; };
...@@ -2256,7 +2264,7 @@ static const struct panel_desc koe_tx26d202vm0bwa = { ...@@ -2256,7 +2264,7 @@ static const struct panel_desc koe_tx26d202vm0bwa = {
.disable = 1000, .disable = 1000,
}, },
.bus_format = MEDIA_BUS_FMT_RGB888_1X7X4_SPWG, .bus_format = MEDIA_BUS_FMT_RGB888_1X7X4_SPWG,
.bus_flags = DRM_BUS_FLAG_DE_HIGH | DRM_BUS_FLAG_PIXDATA_DRIVE_POSEDGE, .bus_flags = DRM_BUS_FLAG_DE_HIGH,
.connector_type = DRM_MODE_CONNECTOR_LVDS, .connector_type = DRM_MODE_CONNECTOR_LVDS,
}; };
...@@ -2497,9 +2505,7 @@ static const struct panel_desc logictechno_lt170410_2whc = { ...@@ -2497,9 +2505,7 @@ static const struct panel_desc logictechno_lt170410_2whc = {
.height = 136, .height = 136,
}, },
.bus_format = MEDIA_BUS_FMT_RGB888_1X7X4_SPWG, .bus_format = MEDIA_BUS_FMT_RGB888_1X7X4_SPWG,
.bus_flags = DRM_BUS_FLAG_DE_HIGH | .bus_flags = DRM_BUS_FLAG_DE_HIGH,
DRM_BUS_FLAG_PIXDATA_SAMPLE_NEGEDGE |
DRM_BUS_FLAG_SYNC_SAMPLE_NEGEDGE,
.connector_type = DRM_MODE_CONNECTOR_LVDS, .connector_type = DRM_MODE_CONNECTOR_LVDS,
}; };
...@@ -3072,7 +3078,7 @@ static const struct panel_desc samsung_ltn101nt05 = { ...@@ -3072,7 +3078,7 @@ static const struct panel_desc samsung_ltn101nt05 = {
.height = 125, .height = 125,
}, },
.bus_format = MEDIA_BUS_FMT_RGB666_1X7X3_SPWG, .bus_format = MEDIA_BUS_FMT_RGB666_1X7X3_SPWG,
.bus_flags = DRM_BUS_FLAG_DE_HIGH | DRM_BUS_FLAG_PIXDATA_DRIVE_POSEDGE, .bus_flags = DRM_BUS_FLAG_DE_HIGH,
.connector_type = DRM_MODE_CONNECTOR_LVDS, .connector_type = DRM_MODE_CONNECTOR_LVDS,
}; };
...@@ -3512,7 +3518,7 @@ static const struct panel_desc toshiba_lt089ac29000 = { ...@@ -3512,7 +3518,7 @@ static const struct panel_desc toshiba_lt089ac29000 = {
.height = 116, .height = 116,
}, },
.bus_format = MEDIA_BUS_FMT_RGB888_1X7X4_JEIDA, .bus_format = MEDIA_BUS_FMT_RGB888_1X7X4_JEIDA,
.bus_flags = DRM_BUS_FLAG_DE_HIGH | DRM_BUS_FLAG_PIXDATA_DRIVE_POSEDGE, .bus_flags = DRM_BUS_FLAG_DE_HIGH,
.connector_type = DRM_MODE_CONNECTOR_LVDS, .connector_type = DRM_MODE_CONNECTOR_LVDS,
}; };
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment