Message ID | CAOMqctT2dAQERos8bhrtVirF7ma4onq+UUS2ks-86LJ_mVDU6g@mail.gmail.com (mailing list archive) |
---|---|
State | New, archived |
Headers | show |
Hello Michal, On 01/29/2016 02:07 PM, Michal Suchanek wrote: > Hello, > > after commit a9fa852886fd5a7ccec3b7e9eff75f85072f009c > > display no longer works on the Snow board. The built-in panel is no > longer probed. > > The commit *supposedly* provides for backwards compatibility and at > first glance only new options for probing the panel are added. > > However, reverting the commit on top of 4.5-rc1 gives working display > again so there is probably some subtle non-obvious catch in the logic. > > Any ideas what might go wrong here? > Yes, I noticed the same and posted a fix some hours ago: https://lkml.org/lkml/2016/1/29/355 > Thanks > > Michal > Best regards,
On 29 January 2016 at 18:18, Javier Martinez Canillas <javier@osg.samsung.com> wrote: > Hello Michal, > > On 01/29/2016 02:07 PM, Michal Suchanek wrote: >> >> Hello, >> >> after commit a9fa852886fd5a7ccec3b7e9eff75f85072f009c >> >> display no longer works on the Snow board. The built-in panel is no >> longer probed. >> > Yes, I noticed the same and posted a fix some hours ago: > > https://lkml.org/lkml/2016/1/29/355 > Tested-by: Michal Suchanek <hramrach@gmail.com> on that patch. Thanks Michal
diff --git a/drivers/gpu/drm/exynos/exynos_dp_core.c b/drivers/gpu/drm/exynos/exynos_dp_core.c index 94f02a0..60260a0 100644 --- a/drivers/gpu/drm/exynos/exynos_dp_core.c +++ b/drivers/gpu/drm/exynos/exynos_dp_core.c @@ -1392,7 +1392,7 @@ static const struct component_ops exynos_dp_ops = { static int exynos_dp_probe(struct platform_device *pdev) { struct device *dev = &pdev->dev; - struct device_node *panel_node, *bridge_node, *endpoint; + struct device_node *panel_node = NULL, *bridge_node, *endpoint = NULL; struct exynos_dp_device *dp; int ret; @@ -1403,14 +1403,32 @@ static int exynos_dp_probe(struct platform_device *pdev) platform_set_drvdata(pdev, dp); + /* This is for the backward compatibility. */ panel_node = of_parse_phandle(dev->of_node, "panel", 0); if (panel_node) { dp->panel = of_drm_find_panel(panel_node); of_node_put(panel_node); if (!dp->panel) return -EPROBE_DEFER; + } else { + endpoint = of_graph_get_next_endpoint(dev->of_node, NULL); + if (endpoint) { + panel_node = of_graph_get_remote_port_parent(endpoint); + if (panel_node) { + dp->panel = of_drm_find_panel(panel_node); + of_node_put(panel_node); + if (!dp->panel) + return -EPROBE_DEFER; + } else { + DRM_ERROR("no port node for panel device.\n"); + return -EINVAL; + } + } } + if (endpoint) + goto out; + endpoint = of_graph_get_next_endpoint(dev->of_node, NULL); if (endpoint) { bridge_node = of_graph_get_remote_port_parent(endpoint); @@ -1423,6 +1441,7 @@ static int exynos_dp_probe(struct platform_device *pdev) return -EPROBE_DEFER; } +out: pm_runtime_enable(dev); ret = component_add(&pdev->dev, &exynos_dp_ops);