Commit 65af9070 authored by Jagan Teki's avatar Jagan Teki Committed by Robert Foss

Revert "drm/bridge: dw-mipi-dsi: Find the possible DSI devices"

This reverts commit c206c7fa.

In order to avoid any probe ordering issues, the I2C based downstream
bridge drivers now register and attach the DSI devices at the probe
instead of doing it on drm_bridge_function.attach().

Examples of those commits are:

commit <6ef7ee48> ("drm/bridge: sn65dsi83: Register and attach our
DSI device at probe")
commit <d89078c3> ("drm/bridge: lt8912b: Register and attach our DSI
device at probe")
commit <864c49a3> ("drm/bridge: adv7511: Register and attach our DSI
device at probe")

dw-mipi-dsi has panel or bridge finding code based on previous downstream
bridges, so revert the same and make the panel or bridge funding in host
attach as before.
Signed-off-by: default avatarJagan Teki <jagan@amarulasolutions.com>
Signed-off-by: default avatarRobert Foss <robert.foss@linaro.org>
Link: https://patchwork.freedesktop.org/patch/msgid/20220331154503.66054-1-jagan@amarulasolutions.com
parent ee2f7c9d
...@@ -246,7 +246,6 @@ struct dw_mipi_dsi { ...@@ -246,7 +246,6 @@ struct dw_mipi_dsi {
struct clk *pclk; struct clk *pclk;
bool device_found;
unsigned int lane_mbps; /* per lane */ unsigned int lane_mbps; /* per lane */
u32 channel; u32 channel;
u32 lanes; u32 lanes;
...@@ -310,37 +309,13 @@ static inline u32 dsi_read(struct dw_mipi_dsi *dsi, u32 reg) ...@@ -310,37 +309,13 @@ static inline u32 dsi_read(struct dw_mipi_dsi *dsi, u32 reg)
return readl(dsi->base + reg); return readl(dsi->base + reg);
} }
static int dw_mipi_dsi_panel_or_bridge(struct dw_mipi_dsi *dsi,
struct device_node *node)
{
struct drm_bridge *bridge;
struct drm_panel *panel;
int ret;
ret = drm_of_find_panel_or_bridge(node, 1, 0, &panel, &bridge);
if (ret)
return ret;
if (panel) {
bridge = drm_panel_bridge_add_typed(panel,
DRM_MODE_CONNECTOR_DSI);
if (IS_ERR(bridge))
return PTR_ERR(bridge);
}
dsi->panel_bridge = bridge;
if (!dsi->panel_bridge)
return -EPROBE_DEFER;
return 0;
}
static int dw_mipi_dsi_host_attach(struct mipi_dsi_host *host, static int dw_mipi_dsi_host_attach(struct mipi_dsi_host *host,
struct mipi_dsi_device *device) struct mipi_dsi_device *device)
{ {
struct dw_mipi_dsi *dsi = host_to_dsi(host); struct dw_mipi_dsi *dsi = host_to_dsi(host);
const struct dw_mipi_dsi_plat_data *pdata = dsi->plat_data; const struct dw_mipi_dsi_plat_data *pdata = dsi->plat_data;
struct drm_bridge *bridge;
struct drm_panel *panel;
int ret; int ret;
if (device->lanes > dsi->plat_data->max_data_lanes) { if (device->lanes > dsi->plat_data->max_data_lanes) {
...@@ -354,14 +329,22 @@ static int dw_mipi_dsi_host_attach(struct mipi_dsi_host *host, ...@@ -354,14 +329,22 @@ static int dw_mipi_dsi_host_attach(struct mipi_dsi_host *host,
dsi->format = device->format; dsi->format = device->format;
dsi->mode_flags = device->mode_flags; dsi->mode_flags = device->mode_flags;
if (!dsi->device_found) { ret = drm_of_find_panel_or_bridge(host->dev->of_node, 1, 0,
ret = dw_mipi_dsi_panel_or_bridge(dsi, host->dev->of_node); &panel, &bridge);
if (ret) if (ret)
return ret; return ret;
dsi->device_found = true; if (panel) {
bridge = drm_panel_bridge_add_typed(panel,
DRM_MODE_CONNECTOR_DSI);
if (IS_ERR(bridge))
return PTR_ERR(bridge);
} }
dsi->panel_bridge = bridge;
drm_bridge_add(&dsi->bridge);
if (pdata->host_ops && pdata->host_ops->attach) { if (pdata->host_ops && pdata->host_ops->attach) {
ret = pdata->host_ops->attach(pdata->priv_data, device); ret = pdata->host_ops->attach(pdata->priv_data, device);
if (ret < 0) if (ret < 0)
...@@ -1021,16 +1004,6 @@ static int dw_mipi_dsi_bridge_attach(struct drm_bridge *bridge, ...@@ -1021,16 +1004,6 @@ static int dw_mipi_dsi_bridge_attach(struct drm_bridge *bridge,
/* Set the encoder type as caller does not know it */ /* Set the encoder type as caller does not know it */
bridge->encoder->encoder_type = DRM_MODE_ENCODER_DSI; bridge->encoder->encoder_type = DRM_MODE_ENCODER_DSI;
if (!dsi->device_found) {
int ret;
ret = dw_mipi_dsi_panel_or_bridge(dsi, dsi->dev->of_node);
if (ret)
return ret;
dsi->device_found = true;
}
/* Attach the panel-bridge to the dsi bridge */ /* Attach the panel-bridge to the dsi bridge */
return drm_bridge_attach(bridge->encoder, dsi->panel_bridge, bridge, return drm_bridge_attach(bridge->encoder, dsi->panel_bridge, bridge,
flags); flags);
...@@ -1217,7 +1190,6 @@ __dw_mipi_dsi_probe(struct platform_device *pdev, ...@@ -1217,7 +1190,6 @@ __dw_mipi_dsi_probe(struct platform_device *pdev,
#ifdef CONFIG_OF #ifdef CONFIG_OF
dsi->bridge.of_node = pdev->dev.of_node; dsi->bridge.of_node = pdev->dev.of_node;
#endif #endif
drm_bridge_add(&dsi->bridge);
return dsi; return dsi;
} }
......
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