aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/gpu/drm/msm/dsi/dsi_manager.c
diff options
context:
space:
mode:
authorLaurent Pinchart <laurent.pinchart+renesas@ideasonboard.com>2016-11-28 10:59:08 -0500
committerArchit Taneja <architt@codeaurora.org>2016-12-18 06:01:45 -0500
commit3bb80f249525c059572d4bc89ac77ac2e511bcbe (patch)
tree4c67445f057de2a7bbffbbe9ce004bbf1ebd0a4a /drivers/gpu/drm/msm/dsi/dsi_manager.c
parent2407d1dc04789bfb2f39d248644981d2233feb0e (diff)
drm: bridge: Link encoder and bridge in core code
Instead of linking encoders and bridges in every driver (and getting it wrong half of the time, as many drivers forget to set the drm_bridge encoder pointer), do so in core code. The drm_bridge_attach() function needs the encoder and optional previous bridge to perform that task, update all the callers. Signed-off-by: Laurent Pinchart <laurent.pinchart+renesas@ideasonboard.com> Acked-by: Stefan Agner <stefan@agner.ch> # For DCU Acked-by: Boris Brezillon <boris.brezillon@free-electrons.com> # For atmel-hlcdc Acked-by: Vincent Abriou <vincent.abriou@st.com> # For STI Acked-by: Maxime Ripard <maxime.ripard@free-electrons.com> # For sun4i Acked-by: Xinliang Liu <z.liuxinliang@hisilicon.com> # For hisilicon Acked-by: Jyri Sarha <jsarha@ti.com> # For tilcdc Reviewed-by: Daniel Vetter <daniel.vetter@ffwll.ch> Signed-off-by: Archit Taneja <architt@codeaurora.org> Link: http://patchwork.freedesktop.org/patch/msgid/1481709550-29226-4-git-send-email-laurent.pinchart+renesas@ideasonboard.com
Diffstat (limited to 'drivers/gpu/drm/msm/dsi/dsi_manager.c')
-rw-r--r--drivers/gpu/drm/msm/dsi/dsi_manager.c17
1 files changed, 11 insertions, 6 deletions
diff --git a/drivers/gpu/drm/msm/dsi/dsi_manager.c b/drivers/gpu/drm/msm/dsi/dsi_manager.c
index c8d1f19c9a6d..2bd8dad76105 100644
--- a/drivers/gpu/drm/msm/dsi/dsi_manager.c
+++ b/drivers/gpu/drm/msm/dsi/dsi_manager.c
@@ -579,6 +579,7 @@ struct drm_bridge *msm_dsi_manager_bridge_init(u8 id)
579 struct msm_dsi *msm_dsi = dsi_mgr_get_dsi(id); 579 struct msm_dsi *msm_dsi = dsi_mgr_get_dsi(id);
580 struct drm_bridge *bridge = NULL; 580 struct drm_bridge *bridge = NULL;
581 struct dsi_bridge *dsi_bridge; 581 struct dsi_bridge *dsi_bridge;
582 struct drm_encoder *encoder;
582 int ret; 583 int ret;
583 584
584 dsi_bridge = devm_kzalloc(msm_dsi->dev->dev, 585 dsi_bridge = devm_kzalloc(msm_dsi->dev->dev,
@@ -590,10 +591,18 @@ struct drm_bridge *msm_dsi_manager_bridge_init(u8 id)
590 591
591 dsi_bridge->id = id; 592 dsi_bridge->id = id;
592 593
594 /*
595 * HACK: we may not know the external DSI bridge device's mode
596 * flags here. We'll get to know them only when the device
597 * attaches to the dsi host. For now, assume the bridge supports
598 * DSI video mode
599 */
600 encoder = msm_dsi->encoders[MSM_DSI_VIDEO_ENCODER_ID];
601
593 bridge = &dsi_bridge->base; 602 bridge = &dsi_bridge->base;
594 bridge->funcs = &dsi_mgr_bridge_funcs; 603 bridge->funcs = &dsi_mgr_bridge_funcs;
595 604
596 ret = drm_bridge_attach(msm_dsi->dev, bridge); 605 ret = drm_bridge_attach(encoder, bridge, NULL);
597 if (ret) 606 if (ret)
598 goto fail; 607 goto fail;
599 608
@@ -628,11 +637,7 @@ struct drm_connector *msm_dsi_manager_ext_bridge_init(u8 id)
628 encoder = msm_dsi->encoders[MSM_DSI_VIDEO_ENCODER_ID]; 637 encoder = msm_dsi->encoders[MSM_DSI_VIDEO_ENCODER_ID];
629 638
630 /* link the internal dsi bridge to the external bridge */ 639 /* link the internal dsi bridge to the external bridge */
631 int_bridge->next = ext_bridge; 640 drm_bridge_attach(encoder, ext_bridge, int_bridge);
632 /* set the external bridge's encoder as dsi's encoder */
633 ext_bridge->encoder = encoder;
634
635 drm_bridge_attach(dev, ext_bridge);
636 641
637 /* 642 /*
638 * we need the drm_connector created by the external bridge 643 * we need the drm_connector created by the external bridge