Add a flag to indicate support for cec.

Signed-off-by: Guillaume Ranquet <granq...@baylibre.com>

diff --git a/drivers/gpu/drm/mediatek/mtk_hdmi_common.c 
b/drivers/gpu/drm/mediatek/mtk_hdmi_common.c
index bfcca6f8b839..86653ebaacfd 100644
--- a/drivers/gpu/drm/mediatek/mtk_hdmi_common.c
+++ b/drivers/gpu/drm/mediatek/mtk_hdmi_common.c
@@ -154,35 +154,38 @@ int mtk_hdmi_dt_parse_pdata(struct mtk_hdmi *hdmi, struct 
platform_device *pdev,
                return ret;
        }
 
-       /* The CEC module handles HDMI hotplug detection */
-       cec_np = of_get_compatible_child(np->parent, "mediatek,mt8173-cec");
-       if (!cec_np) {
-               dev_err(dev, "Failed to find CEC node\n");
-               return -EINVAL;
-       }
+       if (hdmi->conf->has_cec) {
+               /* The CEC module handles HDMI hotplug detection */
+               cec_np = of_get_compatible_child(np->parent, 
"mediatek,mt8173-cec");
+               if (!cec_np) {
+                       dev_err(dev, "Failed to find CEC node\n");
+                       return -EINVAL;
+               }
 
-       cec_pdev = of_find_device_by_node(cec_np);
-       if (!cec_pdev) {
-               dev_err(hdmi->dev, "Waiting for CEC device %pOF\n", cec_np);
+               cec_pdev = of_find_device_by_node(cec_np);
+               if (!cec_pdev) {
+                       dev_err(hdmi->dev, "Waiting for CEC device %pOF\n", 
cec_np);
+                       of_node_put(cec_np);
+                       return -EPROBE_DEFER;
+               }
                of_node_put(cec_np);
-               return -EPROBE_DEFER;
-       }
-       of_node_put(cec_np);
-       hdmi->cec_dev = &cec_pdev->dev;
-       /*
-        * The mediatek,syscon-hdmi property contains a phandle link to the
-        * MMSYS_CONFIG device and the register offset of the HDMI_SYS_CFG
-        * registers it contains.
-        */
-       regmap = syscon_regmap_lookup_by_phandle(np, "mediatek,syscon-hdmi");
-       ret = of_property_read_u32_index(np, "mediatek,syscon-hdmi", 1, 
&hdmi->sys_offset);
-       if (IS_ERR(regmap))
-               ret = PTR_ERR(regmap);
-       if (ret) {
-               dev_err(dev, "Failed to get system configuration registers: 
%d\n", ret);
-               goto put_device;
+               hdmi->cec_dev = &cec_pdev->dev;
+               /*
+                * The mediatek,syscon-hdmi property contains a phandle link to 
the
+                * MMSYS_CONFIG device and the register offset of the 
HDMI_SYS_CFG
+                * registers it contains.
+                */
+               regmap = syscon_regmap_lookup_by_phandle(np, 
"mediatek,syscon-hdmi");
+               ret = of_property_read_u32_index(np, "mediatek,syscon-hdmi", 1, 
&hdmi->sys_offset);
+               if (IS_ERR(regmap))
+                       ret = PTR_ERR(regmap);
+               if (ret) {
+                       dev_err(dev,
+                               "Failed to get system configuration registers: 
%d\n", ret);
+                       goto put_device;
+               }
+               hdmi->sys_regmap = regmap;
        }
-       hdmi->sys_regmap = regmap;
 
        mem = platform_get_resource(pdev, IORESOURCE_MEM, 0);
        if (!mem) {
@@ -230,7 +233,8 @@ int mtk_hdmi_dt_parse_pdata(struct mtk_hdmi *hdmi, struct 
platform_device *pdev,
 
        return 0;
 put_device:
-       put_device(hdmi->cec_dev);
+       if (hdmi->conf->has_cec)
+               put_device(hdmi->cec_dev);
        return ret;
 }
 
@@ -320,6 +324,7 @@ int mtk_drm_hdmi_remove(struct platform_device *pdev)
 
 static const struct mtk_hdmi_conf mtk_hdmi_conf_mt2701 = {
        .tz_disabled = true,
+       .has_cec = true,
        .bridge_funcs = &mtk_mt8183_hdmi_bridge_funcs,
        .mtk_hdmi_output_init = mtk_hdmi_output_init_mt8183,
        .mtk_hdmi_clk_disable = mtk_hdmi_clk_disable_audio_mt8183,
@@ -332,6 +337,7 @@ static const struct mtk_hdmi_conf mtk_hdmi_conf_mt2701 = {
 static const struct mtk_hdmi_conf mtk_hdmi_conf_mt8167 = {
        .max_mode_clock = 148500,
        .cea_modes_only = true,
+       .has_cec = true,
        .bridge_funcs = &mtk_mt8183_hdmi_bridge_funcs,
        .mtk_hdmi_output_init = mtk_hdmi_output_init_mt8183,
        .mtk_hdmi_clk_disable = mtk_hdmi_clk_disable_audio_mt8183,
diff --git a/drivers/gpu/drm/mediatek/mtk_hdmi_common.h 
b/drivers/gpu/drm/mediatek/mtk_hdmi_common.h
index 7452bea91f9e..921bde150e11 100644
--- a/drivers/gpu/drm/mediatek/mtk_hdmi_common.h
+++ b/drivers/gpu/drm/mediatek/mtk_hdmi_common.h
@@ -31,6 +31,7 @@
 struct mtk_hdmi_conf {
        bool tz_disabled;
        bool cea_modes_only;
+       bool has_cec;
        unsigned long max_mode_clock;
        const struct drm_bridge_funcs *bridge_funcs;
        void (*mtk_hdmi_output_init)(struct mtk_hdmi *hdmi);

-- 
b4 0.10.0-dev

Reply via email to