2017년 02월 01일 16:34에 Andrzej Hajda 이(가) 쓴 글: > On 01.02.2017 08:31, Inki Dae wrote: >> >> 2017년 01월 20일 15:52에 Andrzej Hajda 이(가) 쓴 글: >>> In some platforms there is attached another device to the end of HDMI. >>> The patch adds support for it. >> Andrzej, can you clarify what bridge device can be attached and actually is now attached to the end of HDMI? >> And I wonder if we have the device tree file which defines the bridge device in mainline. Seems we have no the device tree file. >> >> If nothing, then this patch should be merged with real use case. > > SiI8620 MHL bridge in tm2/tm2e. Did you post dt patch to add the properties related to SiI8620 MHL bridge device? I see below patch series, [PATCH 00/24] drm/bridge/sii8620: add Ultra HD modes support but I couldn't find dt patch for it. And specifying SiI8620 MHL bridge device as description would be needed. Thanks. > > Regards > Andrzej > >> >> Thanks. >> >>> Signed-off-by: Andrzej Hajda <a.hajda@xxxxxxxxxxx> >>> --- >>> drivers/gpu/drm/exynos/exynos_hdmi.c | 56 +++++++++++++++++++++++++++++------- >>> 1 file changed, 46 insertions(+), 10 deletions(-) >>> >>> diff --git a/drivers/gpu/drm/exynos/exynos_hdmi.c b/drivers/gpu/drm/exynos/exynos_hdmi.c >>> index a73b192..41fb894 100644 >>> --- a/drivers/gpu/drm/exynos/exynos_hdmi.c >>> +++ b/drivers/gpu/drm/exynos/exynos_hdmi.c >>> @@ -35,6 +35,7 @@ >>> #include <linux/io.h> >>> #include <linux/of_address.h> >>> #include <linux/of_device.h> >>> +#include <linux/of_graph.h> >>> #include <linux/hdmi.h> >>> #include <linux/component.h> >>> #include <linux/mfd/syscon.h> >>> @@ -133,6 +134,7 @@ struct hdmi_context { >>> struct regulator_bulk_data regul_bulk[ARRAY_SIZE(supply)]; >>> struct regulator *reg_hdmi_en; >>> struct exynos_drm_clk phy_clk; >>> + struct drm_bridge *bridge; >>> }; >>> >>> static inline struct hdmi_context *encoder_to_hdmi(struct drm_encoder *e) >>> @@ -922,7 +924,15 @@ static int hdmi_create_connector(struct drm_encoder *encoder) >>> drm_connector_register(connector); >>> drm_mode_connector_attach_encoder(connector, encoder); >>> >>> - return 0; >>> + if (hdata->bridge) { >>> + encoder->bridge = hdata->bridge; >>> + hdata->bridge->encoder = encoder; >>> + ret = drm_bridge_attach(encoder->dev, hdata->bridge); >>> + if (ret) >>> + DRM_ERROR("Failed to attach bridge\n"); >>> + } >>> + >>> + return ret; >>> } >>> >>> static bool hdmi_mode_fixup(struct drm_encoder *encoder, >>> @@ -1591,6 +1601,31 @@ static void hdmiphy_clk_enable(struct exynos_drm_clk *clk, bool enable) >>> hdmiphy_disable(hdata); >>> } >>> >>> +static int hdmi_bridge_init(struct hdmi_context *hdata) >>> +{ >>> + struct device *dev = hdata->dev; >>> + struct device_node *ep, *np; >>> + >>> + ep = of_graph_get_endpoint_by_regs(dev->of_node, 1, -1); >>> + if (!ep) >>> + return 0; >>> + >>> + np = of_graph_get_remote_port_parent(ep); >>> + of_node_put(ep); >>> + if (!np) { >>> + DRM_ERROR("failed to get remote port parent"); >>> + return -EINVAL; >>> + } >>> + >>> + hdata->bridge = of_drm_find_bridge(np); >>> + of_node_put(np); >>> + >>> + if (!hdata->bridge) >>> + return -EPROBE_DEFER; >>> + >>> + return 0; >>> +} >>> + >>> static int hdmi_resources_init(struct hdmi_context *hdata) >>> { >>> struct device *dev = hdata->dev; >>> @@ -1630,17 +1665,18 @@ static int hdmi_resources_init(struct hdmi_context *hdata) >>> >>> hdata->reg_hdmi_en = devm_regulator_get_optional(dev, "hdmi-en"); >>> >>> - if (PTR_ERR(hdata->reg_hdmi_en) == -ENODEV) >>> - return 0; >>> + if (PTR_ERR(hdata->reg_hdmi_en) != -ENODEV) { >>> + if (IS_ERR(hdata->reg_hdmi_en)) >>> + return PTR_ERR(hdata->reg_hdmi_en); >>> >>> - if (IS_ERR(hdata->reg_hdmi_en)) >>> - return PTR_ERR(hdata->reg_hdmi_en); >>> - >>> - ret = regulator_enable(hdata->reg_hdmi_en); >>> - if (ret) >>> - DRM_ERROR("failed to enable hdmi-en regulator\n"); >>> + ret = regulator_enable(hdata->reg_hdmi_en); >>> + if (ret) { >>> + DRM_ERROR("failed to enable hdmi-en regulator\n"); >>> + return ret; >>> + } >>> + } >>> >>> - return ret; >>> + return hdmi_bridge_init(hdata); >>> } >>> >>> static struct of_device_id hdmi_match_types[] = { >>> >> > > -- > To unsubscribe from this list: send the line "unsubscribe linux-samsung-soc" in > the body of a message to majordomo@xxxxxxxxxxxxxxx > More majordomo info at http://vger.kernel.org/majordomo-info.html > > -- To unsubscribe from this list: send the line "unsubscribe linux-samsung-soc" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html