From: Cristian Ciocaltea <[email protected]>

The name of the enable_gpio member in struct rockchip_hdmi_qp is too
generic, as initially "borrowed" from downstream BSP code. Moreover,
this hasn't been really in use so far, since there is neither a DT
providing an "enable-gpios" property to any of the "hdmi" nodes, nor a
binding documenting it.

The actual purpose of this GPIO line is to control the voltage bias for
the HDMI TX data lines when switching between TMDS and FRL operating
modes.

A previous patch introduced the "frl-enable-gpios" property of the
RK3588 HDMI TX Controller binding, hence pass the updated string to
devm_gpiod_get_optional(), rename the struct member accordingly and set
it to a low level.

Signed-off-by: Cristian Ciocaltea <[email protected]>
Signed-off-by: Laurent Pinchart <[email protected]>
---
Changes since v2:

- Rename tmds-enable to frl-enable
- Acquire the GPIO with GPIOD_OUT_LOW
---
 drivers/gpu/drm/rockchip/dw_hdmi_qp-rockchip.c | 14 +++++++-------
 1 file changed, 7 insertions(+), 7 deletions(-)

diff --git a/drivers/gpu/drm/rockchip/dw_hdmi_qp-rockchip.c 
b/drivers/gpu/drm/rockchip/dw_hdmi_qp-rockchip.c
index 931343b072ad..36363136a695 100644
--- a/drivers/gpu/drm/rockchip/dw_hdmi_qp-rockchip.c
+++ b/drivers/gpu/drm/rockchip/dw_hdmi_qp-rockchip.c
@@ -92,7 +92,7 @@ struct rockchip_hdmi_qp {
        struct rockchip_encoder encoder;
        struct dw_hdmi_qp *hdmi;
        struct phy *phy;
-       struct gpio_desc *enable_gpio;
+       struct gpio_desc *frl_enable_gpio;
        struct delayed_work hpd_work;
        int port_id;
        const struct rockchip_hdmi_qp_ctrl_ops *ctrl_ops;
@@ -118,7 +118,7 @@ static void dw_hdmi_qp_rockchip_encoder_enable(struct 
drm_encoder *encoder)
        unsigned long long rate;
 
        /* Unconditionally switch to TMDS as FRL is not yet supported */
-       gpiod_set_value(hdmi->enable_gpio, 1);
+       gpiod_set_value(hdmi->frl_enable_gpio, 0);
 
        if (crtc && crtc->state) {
                rate = drm_hdmi_compute_mode_clock(&crtc->state->adjusted_mode,
@@ -515,11 +515,11 @@ static int dw_hdmi_qp_rockchip_bind(struct device *dev, 
struct device *master,
        plat_data.ref_clk_rate = clk_get_rate(ref_clk);
        clk_put(ref_clk);
 
-       hdmi->enable_gpio = devm_gpiod_get_optional(hdmi->dev, "enable",
-                                                   GPIOD_OUT_HIGH);
-       if (IS_ERR(hdmi->enable_gpio))
-               return dev_err_probe(hdmi->dev, PTR_ERR(hdmi->enable_gpio),
-                                    "Failed to request enable GPIO\n");
+       hdmi->frl_enable_gpio = devm_gpiod_get_optional(hdmi->dev, "frl-enable",
+                                                       GPIOD_OUT_LOW);
+       if (IS_ERR(hdmi->frl_enable_gpio))
+               return dev_err_probe(hdmi->dev, PTR_ERR(hdmi->frl_enable_gpio),
+                                    "Failed to request FRL enable GPIO\n");
 
        hdmi->phy = devm_of_phy_get_by_index(dev, dev->of_node, 0);
        if (IS_ERR(hdmi->phy))
-- 
Regards,

Laurent Pinchart

Reply via email to