Commit bd29823e authored by Jagan Teki's avatar Jagan Teki Committed by Robert Foss

Revert "drm: exynos: dsi: Convert to bridge driver"

This reverts commit 92e794fa.

It is merged by accident, the actual patch series on this bridge
conversion is still under review.

Revert this as it breaks the exynos DSI.
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/20220111184347.502471-1-jagan@amarulasolutions.comReviewed-by: default avatarRobert Foss <robert.foss@linaro.org>
parent 9d319934
...@@ -257,7 +257,6 @@ struct exynos_dsi { ...@@ -257,7 +257,6 @@ struct exynos_dsi {
struct drm_connector connector; struct drm_connector connector;
struct drm_panel *panel; struct drm_panel *panel;
struct list_head bridge_chain; struct list_head bridge_chain;
struct drm_bridge bridge;
struct drm_bridge *out_bridge; struct drm_bridge *out_bridge;
struct device *dev; struct device *dev;
struct drm_display_mode mode; struct drm_display_mode mode;
...@@ -289,9 +288,9 @@ struct exynos_dsi { ...@@ -289,9 +288,9 @@ struct exynos_dsi {
#define host_to_dsi(host) container_of(host, struct exynos_dsi, dsi_host) #define host_to_dsi(host) container_of(host, struct exynos_dsi, dsi_host)
#define connector_to_dsi(c) container_of(c, struct exynos_dsi, connector) #define connector_to_dsi(c) container_of(c, struct exynos_dsi, connector)
static inline struct exynos_dsi *bridge_to_dsi(struct drm_bridge *b) static inline struct exynos_dsi *encoder_to_dsi(struct drm_encoder *e)
{ {
return container_of(b, struct exynos_dsi, bridge); return container_of(e, struct exynos_dsi, encoder);
} }
enum reg_idx { enum reg_idx {
...@@ -1376,10 +1375,9 @@ static void exynos_dsi_unregister_te_irq(struct exynos_dsi *dsi) ...@@ -1376,10 +1375,9 @@ static void exynos_dsi_unregister_te_irq(struct exynos_dsi *dsi)
} }
} }
static void exynos_dsi_atomic_enable(struct drm_bridge *bridge, static void exynos_dsi_enable(struct drm_encoder *encoder)
struct drm_bridge_state *old_bridge_state)
{ {
struct exynos_dsi *dsi = bridge_to_dsi(bridge); struct exynos_dsi *dsi = encoder_to_dsi(encoder);
struct drm_bridge *iter; struct drm_bridge *iter;
int ret; int ret;
...@@ -1402,8 +1400,7 @@ static void exynos_dsi_atomic_enable(struct drm_bridge *bridge, ...@@ -1402,8 +1400,7 @@ static void exynos_dsi_atomic_enable(struct drm_bridge *bridge,
list_for_each_entry_reverse(iter, &dsi->bridge_chain, list_for_each_entry_reverse(iter, &dsi->bridge_chain,
chain_node) { chain_node) {
if (iter->funcs->pre_enable) if (iter->funcs->pre_enable)
iter->funcs->atomic_pre_enable(iter, iter->funcs->pre_enable(iter);
old_bridge_state);
} }
} }
...@@ -1417,7 +1414,7 @@ static void exynos_dsi_atomic_enable(struct drm_bridge *bridge, ...@@ -1417,7 +1414,7 @@ static void exynos_dsi_atomic_enable(struct drm_bridge *bridge,
} else { } else {
list_for_each_entry(iter, &dsi->bridge_chain, chain_node) { list_for_each_entry(iter, &dsi->bridge_chain, chain_node) {
if (iter->funcs->enable) if (iter->funcs->enable)
iter->funcs->atomic_enable(iter, old_bridge_state); iter->funcs->enable(iter);
} }
} }
...@@ -1433,10 +1430,9 @@ static void exynos_dsi_atomic_enable(struct drm_bridge *bridge, ...@@ -1433,10 +1430,9 @@ static void exynos_dsi_atomic_enable(struct drm_bridge *bridge,
pm_runtime_put(dsi->dev); pm_runtime_put(dsi->dev);
} }
static void exynos_dsi_atomic_disable(struct drm_bridge *bridge, static void exynos_dsi_disable(struct drm_encoder *encoder)
struct drm_bridge_state *old_bridge_state)
{ {
struct exynos_dsi *dsi = bridge_to_dsi(bridge); struct exynos_dsi *dsi = encoder_to_dsi(encoder);
struct drm_bridge *iter; struct drm_bridge *iter;
if (!(dsi->state & DSIM_STATE_ENABLED)) if (!(dsi->state & DSIM_STATE_ENABLED))
...@@ -1448,7 +1444,7 @@ static void exynos_dsi_atomic_disable(struct drm_bridge *bridge, ...@@ -1448,7 +1444,7 @@ static void exynos_dsi_atomic_disable(struct drm_bridge *bridge,
list_for_each_entry_reverse(iter, &dsi->bridge_chain, chain_node) { list_for_each_entry_reverse(iter, &dsi->bridge_chain, chain_node) {
if (iter->funcs->disable) if (iter->funcs->disable)
iter->funcs->atomic_disable(iter, old_bridge_state); iter->funcs->disable(iter);
} }
exynos_dsi_set_display_enable(dsi, false); exynos_dsi_set_display_enable(dsi, false);
...@@ -1456,13 +1452,22 @@ static void exynos_dsi_atomic_disable(struct drm_bridge *bridge, ...@@ -1456,13 +1452,22 @@ static void exynos_dsi_atomic_disable(struct drm_bridge *bridge,
list_for_each_entry(iter, &dsi->bridge_chain, chain_node) { list_for_each_entry(iter, &dsi->bridge_chain, chain_node) {
if (iter->funcs->post_disable) if (iter->funcs->post_disable)
iter->funcs->atomic_post_disable(iter, old_bridge_state); iter->funcs->post_disable(iter);
} }
dsi->state &= ~DSIM_STATE_ENABLED; dsi->state &= ~DSIM_STATE_ENABLED;
pm_runtime_put_sync(dsi->dev); pm_runtime_put_sync(dsi->dev);
} }
static void exynos_dsi_mode_set(struct drm_encoder *encoder,
struct drm_display_mode *mode,
struct drm_display_mode *adjusted_mode)
{
struct exynos_dsi *dsi = encoder_to_dsi(encoder);
drm_mode_copy(&dsi->mode, adjusted_mode);
}
static enum drm_connector_status static enum drm_connector_status
exynos_dsi_detect(struct drm_connector *connector, bool force) exynos_dsi_detect(struct drm_connector *connector, bool force)
{ {
...@@ -1499,9 +1504,9 @@ static const struct drm_connector_helper_funcs exynos_dsi_connector_helper_funcs ...@@ -1499,9 +1504,9 @@ static const struct drm_connector_helper_funcs exynos_dsi_connector_helper_funcs
.get_modes = exynos_dsi_get_modes, .get_modes = exynos_dsi_get_modes,
}; };
static int exynos_dsi_create_connector(struct exynos_dsi *dsi) static int exynos_dsi_create_connector(struct drm_encoder *encoder)
{ {
struct drm_encoder *encoder = &dsi->encoder; struct exynos_dsi *dsi = encoder_to_dsi(encoder);
struct drm_connector *connector = &dsi->connector; struct drm_connector *connector = &dsi->connector;
struct drm_device *drm = encoder->dev; struct drm_device *drm = encoder->dev;
int ret; int ret;
...@@ -1527,31 +1532,10 @@ static int exynos_dsi_create_connector(struct exynos_dsi *dsi) ...@@ -1527,31 +1532,10 @@ static int exynos_dsi_create_connector(struct exynos_dsi *dsi)
return 0; return 0;
} }
static void exynos_dsi_mode_set(struct drm_bridge *bridge, static const struct drm_encoder_helper_funcs exynos_dsi_encoder_helper_funcs = {
const struct drm_display_mode *mode, .enable = exynos_dsi_enable,
const struct drm_display_mode *adjusted_mode) .disable = exynos_dsi_disable,
{ .mode_set = exynos_dsi_mode_set,
struct exynos_dsi *dsi = bridge_to_dsi(bridge);
drm_mode_copy(&dsi->mode, adjusted_mode);
}
static int exynos_dsi_attach(struct drm_bridge *bridge,
enum drm_bridge_attach_flags flags)
{
struct exynos_dsi *dsi = bridge_to_dsi(bridge);
return drm_bridge_attach(bridge->encoder, dsi->out_bridge, NULL, 0);
}
static const struct drm_bridge_funcs exynos_dsi_bridge_funcs = {
.atomic_duplicate_state = drm_atomic_helper_bridge_duplicate_state,
.atomic_destroy_state = drm_atomic_helper_bridge_destroy_state,
.atomic_reset = drm_atomic_helper_bridge_reset,
.atomic_enable = exynos_dsi_atomic_enable,
.atomic_disable = exynos_dsi_atomic_disable,
.mode_set = exynos_dsi_mode_set,
.attach = exynos_dsi_attach,
}; };
MODULE_DEVICE_TABLE(of, exynos_dsi_of_match); MODULE_DEVICE_TABLE(of, exynos_dsi_of_match);
...@@ -1570,7 +1554,7 @@ static int exynos_dsi_host_attach(struct mipi_dsi_host *host, ...@@ -1570,7 +1554,7 @@ static int exynos_dsi_host_attach(struct mipi_dsi_host *host,
dsi->out_bridge = out_bridge; dsi->out_bridge = out_bridge;
list_splice_init(&encoder->bridge_chain, &dsi->bridge_chain); list_splice_init(&encoder->bridge_chain, &dsi->bridge_chain);
} else { } else {
int ret = exynos_dsi_create_connector(dsi); int ret = exynos_dsi_create_connector(encoder);
if (ret) { if (ret) {
DRM_DEV_ERROR(dsi->dev, DRM_DEV_ERROR(dsi->dev,
...@@ -1623,7 +1607,7 @@ static int exynos_dsi_host_detach(struct mipi_dsi_host *host, ...@@ -1623,7 +1607,7 @@ static int exynos_dsi_host_detach(struct mipi_dsi_host *host,
if (dsi->panel) { if (dsi->panel) {
mutex_lock(&drm->mode_config.mutex); mutex_lock(&drm->mode_config.mutex);
exynos_dsi_atomic_disable(&dsi->bridge, NULL); exynos_dsi_disable(&dsi->encoder);
dsi->panel = NULL; dsi->panel = NULL;
dsi->connector.status = connector_status_disconnected; dsi->connector.status = connector_status_disconnected;
mutex_unlock(&drm->mode_config.mutex); mutex_unlock(&drm->mode_config.mutex);
...@@ -1729,16 +1713,12 @@ static int exynos_dsi_bind(struct device *dev, struct device *master, ...@@ -1729,16 +1713,12 @@ static int exynos_dsi_bind(struct device *dev, struct device *master,
drm_simple_encoder_init(drm_dev, encoder, DRM_MODE_ENCODER_TMDS); drm_simple_encoder_init(drm_dev, encoder, DRM_MODE_ENCODER_TMDS);
drm_encoder_helper_add(encoder, &exynos_dsi_encoder_helper_funcs);
ret = exynos_drm_set_possible_crtcs(encoder, EXYNOS_DISPLAY_TYPE_LCD); ret = exynos_drm_set_possible_crtcs(encoder, EXYNOS_DISPLAY_TYPE_LCD);
if (ret < 0) if (ret < 0)
return ret; return ret;
ret = drm_bridge_attach(&dsi->encoder, &dsi->bridge, NULL, 0);
if (ret) {
drm_encoder_cleanup(&dsi->encoder);
return ret;
}
in_bridge_node = of_graph_get_remote_node(dev->of_node, DSI_PORT_IN, 0); in_bridge_node = of_graph_get_remote_node(dev->of_node, DSI_PORT_IN, 0);
if (in_bridge_node) { if (in_bridge_node) {
in_bridge = of_drm_find_bridge(in_bridge_node); in_bridge = of_drm_find_bridge(in_bridge_node);
...@@ -1754,9 +1734,10 @@ static void exynos_dsi_unbind(struct device *dev, struct device *master, ...@@ -1754,9 +1734,10 @@ static void exynos_dsi_unbind(struct device *dev, struct device *master,
void *data) void *data)
{ {
struct exynos_dsi *dsi = dev_get_drvdata(dev); struct exynos_dsi *dsi = dev_get_drvdata(dev);
struct drm_encoder *encoder = &dsi->encoder;
exynos_dsi_disable(encoder);
exynos_dsi_atomic_disable(&dsi->bridge, NULL);
drm_encoder_cleanup(&dsi->encoder);
mipi_dsi_host_unregister(&dsi->dsi_host); mipi_dsi_host_unregister(&dsi->dsi_host);
} }
...@@ -1849,12 +1830,6 @@ static int exynos_dsi_probe(struct platform_device *pdev) ...@@ -1849,12 +1830,6 @@ static int exynos_dsi_probe(struct platform_device *pdev)
pm_runtime_enable(dev); pm_runtime_enable(dev);
dsi->bridge.funcs = &exynos_dsi_bridge_funcs;
dsi->bridge.of_node = dev->of_node;
dsi->bridge.type = DRM_MODE_CONNECTOR_DSI;
drm_bridge_add(&dsi->bridge);
ret = component_add(dev, &exynos_dsi_component_ops); ret = component_add(dev, &exynos_dsi_component_ops);
if (ret) if (ret)
goto err_disable_runtime; goto err_disable_runtime;
...@@ -1869,10 +1844,6 @@ static int exynos_dsi_probe(struct platform_device *pdev) ...@@ -1869,10 +1844,6 @@ static int exynos_dsi_probe(struct platform_device *pdev)
static int exynos_dsi_remove(struct platform_device *pdev) static int exynos_dsi_remove(struct platform_device *pdev)
{ {
struct exynos_dsi *dsi = platform_get_drvdata(pdev);
drm_bridge_remove(&dsi->bridge);
pm_runtime_disable(&pdev->dev); pm_runtime_disable(&pdev->dev);
component_del(&pdev->dev, &exynos_dsi_component_ops); component_del(&pdev->dev, &exynos_dsi_component_ops);
......
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