diff mbox series

drm: mediatek: Modify dpi power on/off sequence.

Message ID 1662386033-4463-1-git-send-email-xinlei.lee@mediatek.com (mailing list archive)
State New, archived
Headers show
Series drm: mediatek: Modify dpi power on/off sequence. | expand

Commit Message

Xinlei Lee (李昕磊) Sept. 5, 2022, 1:53 p.m. UTC
From: Xinlei Lee <xinlei.lee@mediatek.com>

Modify dpi power on/off sequence so that the first gpio operation will take effect.

Fixes: 6bd4763fd532 ("drm/mediatek: set dpi pin mode to gpio low to avoid leakage
current")

Signed-off-by: Xinlei Lee <xinlei.lee@mediatek.com>

---
Base on the branch of Linux-next/master.
Because dpi power_on/off is protected by dpi->refcount, the first time
it cannot be powered on and off successfully, it will cause leakage.
---
---
 drivers/gpu/drm/mediatek/mtk_dpi.c | 12 ++++++------
 1 file changed, 6 insertions(+), 6 deletions(-)

Comments

Xinlei Lee (李昕磊) Oct. 12, 2022, 7:48 a.m. UTC | #1
On Mon, 2022-09-05 at 21:53 +0800, xinlei.lee@mediatek.com wrote:
> From: Xinlei Lee <xinlei.lee@mediatek.com>
> 
> Modify dpi power on/off sequence so that the first gpio operation
> will take effect.
> 
> Fixes: 6bd4763fd532 ("drm/mediatek: set dpi pin mode to gpio low to
> avoid leakage
> current")
> 
> Signed-off-by: Xinlei Lee <xinlei.lee@mediatek.com>
> 
> ---
> Base on the branch of Linux-next/master.
> Because dpi power_on/off is protected by dpi->refcount, the first
> time
> it cannot be powered on and off successfully, it will cause leakage.
> ---
> ---
>  drivers/gpu/drm/mediatek/mtk_dpi.c | 12 ++++++------
>  1 file changed, 6 insertions(+), 6 deletions(-)
> 
> diff --git a/drivers/gpu/drm/mediatek/mtk_dpi.c
> b/drivers/gpu/drm/mediatek/mtk_dpi.c
> index 630a4e301ef6..2ce1a39ce3bf 100644
> --- a/drivers/gpu/drm/mediatek/mtk_dpi.c
> +++ b/drivers/gpu/drm/mediatek/mtk_dpi.c
> @@ -462,9 +462,6 @@ static void mtk_dpi_power_off(struct mtk_dpi
> *dpi)
>  	if (--dpi->refcount != 0)
>  		return;
>  
> -	if (dpi->pinctrl && dpi->pins_gpio)
> -		pinctrl_select_state(dpi->pinctrl, dpi->pins_gpio);
> -
>  	mtk_dpi_disable(dpi);
>  	clk_disable_unprepare(dpi->pixel_clk);
>  	clk_disable_unprepare(dpi->engine_clk);
> @@ -489,9 +486,6 @@ static int mtk_dpi_power_on(struct mtk_dpi *dpi)
>  		goto err_pixel;
>  	}
>  
> -	if (dpi->pinctrl && dpi->pins_dpi)
> -		pinctrl_select_state(dpi->pinctrl, dpi->pins_dpi);
> -
>  	return 0;
>  
>  err_pixel:
> @@ -721,6 +715,9 @@ static void mtk_dpi_bridge_disable(struct
> drm_bridge *bridge)
>  {
>  	struct mtk_dpi *dpi = bridge_to_dpi(bridge);
>  
> +	if (dpi->pinctrl && dpi->pins_gpio)
> +		pinctrl_select_state(dpi->pinctrl, dpi->pins_gpio);
> +
>  	mtk_dpi_power_off(dpi);
>  }
>  
> @@ -728,6 +725,9 @@ static void mtk_dpi_bridge_enable(struct
> drm_bridge *bridge)
>  {
>  	struct mtk_dpi *dpi = bridge_to_dpi(bridge);
>  
> +	if (dpi->pinctrl && dpi->pins_dpi)
> +		pinctrl_select_state(dpi->pinctrl, dpi->pins_dpi);
> +
>  	mtk_dpi_power_on(dpi);
>  	mtk_dpi_set_display_mode(dpi, &dpi->mode);
>  	mtk_dpi_enable(dpi);

Hi CK,

Gentle ping for this patch, if there is anything I need to modify,
please kindly let me know.

Best Regards!
xinlei
CK Hu (胡俊光) Nov. 8, 2022, 7:44 a.m. UTC | #2
Hi, Xinlei:

On Wed, 2022-10-12 at 15:48 +0800, xinlei.lee wrote:
> On Mon, 2022-09-05 at 21:53 +0800, xinlei.lee@mediatek.com wrote:
> > From: Xinlei Lee <xinlei.lee@mediatek.com>
> > 
> > Modify dpi power on/off sequence so that the first gpio operation
> > will take effect.
> > 
> > Fixes: 6bd4763fd532 ("drm/mediatek: set dpi pin mode to gpio low to
> > avoid leakage
> > current")
> > 
> > Signed-off-by: Xinlei Lee <xinlei.lee@mediatek.com>
> > 
> > ---
> > Base on the branch of Linux-next/master.
> > Because dpi power_on/off is protected by dpi->refcount, the first
> > time
> > it cannot be powered on and off successfully, it will cause
> > leakage.
> > ---
> > ---
> >  drivers/gpu/drm/mediatek/mtk_dpi.c | 12 ++++++------
> >  1 file changed, 6 insertions(+), 6 deletions(-)
> > 
> > diff --git a/drivers/gpu/drm/mediatek/mtk_dpi.c
> > b/drivers/gpu/drm/mediatek/mtk_dpi.c
> > index 630a4e301ef6..2ce1a39ce3bf 100644
> > --- a/drivers/gpu/drm/mediatek/mtk_dpi.c
> > +++ b/drivers/gpu/drm/mediatek/mtk_dpi.c
> > @@ -462,9 +462,6 @@ static void mtk_dpi_power_off(struct mtk_dpi
> > *dpi)
> >  	if (--dpi->refcount != 0)
> >  		return;
> >  
> > -	if (dpi->pinctrl && dpi->pins_gpio)
> > -		pinctrl_select_state(dpi->pinctrl, dpi->pins_gpio);
> > -
> >  	mtk_dpi_disable(dpi);
> >  	clk_disable_unprepare(dpi->pixel_clk);
> >  	clk_disable_unprepare(dpi->engine_clk);
> > @@ -489,9 +486,6 @@ static int mtk_dpi_power_on(struct mtk_dpi
> > *dpi)
> >  		goto err_pixel;
> >  	}
> >  
> > -	if (dpi->pinctrl && dpi->pins_dpi)
> > -		pinctrl_select_state(dpi->pinctrl, dpi->pins_dpi);
> > -
> >  	return 0;
> >  
> >  err_pixel:
> > @@ -721,6 +715,9 @@ static void mtk_dpi_bridge_disable(struct
> > drm_bridge *bridge)
> >  {
> >  	struct mtk_dpi *dpi = bridge_to_dpi(bridge);
> >  
> > +	if (dpi->pinctrl && dpi->pins_gpio)
> > +		pinctrl_select_state(dpi->pinctrl, dpi->pins_gpio);

I think this should be placed after mtk_dpi_power_off().

> > +
> >  	mtk_dpi_power_off(dpi);
> >  }
> >  
> > @@ -728,6 +725,9 @@ static void mtk_dpi_bridge_enable(struct
> > drm_bridge *bridge)
> >  {
> >  	struct mtk_dpi *dpi = bridge_to_dpi(bridge);
> >  
> > +	if (dpi->pinctrl && dpi->pins_dpi)
> > +		pinctrl_select_state(dpi->pinctrl, dpi->pins_dpi);
> > +
> >  	mtk_dpi_power_on(dpi);
> >  	mtk_dpi_set_display_mode(dpi, &dpi->mode);
> >  	mtk_dpi_enable(dpi);
> 
> Hi CK,
> 
> Gentle ping for this patch, if there is anything I need to modify,
> please kindly let me know.
> 
> Best Regards!
> xinlei
>
Xinlei Lee (李昕磊) Nov. 9, 2022, 2:27 a.m. UTC | #3
On Tue, 2022-11-08 at 07:44 +0000, CK Hu (胡俊光) wrote:
> Hi, Xinlei:
> 
> On Wed, 2022-10-12 at 15:48 +0800, xinlei.lee wrote:
> > On Mon, 2022-09-05 at 21:53 +0800, xinlei.lee@mediatek.com wrote:
> > > From: Xinlei Lee <xinlei.lee@mediatek.com>
> > > 
> > > Modify dpi power on/off sequence so that the first gpio operation
> > > will take effect.
> > > 
> > > Fixes: 6bd4763fd532 ("drm/mediatek: set dpi pin mode to gpio low
> > > to
> > > avoid leakage
> > > current")
> > > 
> > > Signed-off-by: Xinlei Lee <xinlei.lee@mediatek.com>
> > > 
> > > ---
> > > Base on the branch of Linux-next/master.
> > > Because dpi power_on/off is protected by dpi->refcount, the first
> > > time
> > > it cannot be powered on and off successfully, it will cause
> > > leakage.
> > > ---
> > > ---
> > >  drivers/gpu/drm/mediatek/mtk_dpi.c | 12 ++++++------
> > >  1 file changed, 6 insertions(+), 6 deletions(-)
> > > 
> > > diff --git a/drivers/gpu/drm/mediatek/mtk_dpi.c
> > > b/drivers/gpu/drm/mediatek/mtk_dpi.c
> > > index 630a4e301ef6..2ce1a39ce3bf 100644
> > > --- a/drivers/gpu/drm/mediatek/mtk_dpi.c
> > > +++ b/drivers/gpu/drm/mediatek/mtk_dpi.c
> > > @@ -462,9 +462,6 @@ static void mtk_dpi_power_off(struct mtk_dpi
> > > *dpi)
> > >  	if (--dpi->refcount != 0)
> > >  		return;
> > >  
> > > -	if (dpi->pinctrl && dpi->pins_gpio)
> > > -		pinctrl_select_state(dpi->pinctrl, dpi->pins_gpio);
> > > -
> > >  	mtk_dpi_disable(dpi);
> > >  	clk_disable_unprepare(dpi->pixel_clk);
> > >  	clk_disable_unprepare(dpi->engine_clk);
> > > @@ -489,9 +486,6 @@ static int mtk_dpi_power_on(struct mtk_dpi
> > > *dpi)
> > >  		goto err_pixel;
> > >  	}
> > >  
> > > -	if (dpi->pinctrl && dpi->pins_dpi)
> > > -		pinctrl_select_state(dpi->pinctrl, dpi->pins_dpi);
> > > -
> > >  	return 0;
> > >  
> > >  err_pixel:
> > > @@ -721,6 +715,9 @@ static void mtk_dpi_bridge_disable(struct
> > > drm_bridge *bridge)
> > >  {
> > >  	struct mtk_dpi *dpi = bridge_to_dpi(bridge);
> > >  
> > > +	if (dpi->pinctrl && dpi->pins_gpio)
> > > +		pinctrl_select_state(dpi->pinctrl, dpi->pins_gpio);
> 
> I think this should be placed after mtk_dpi_power_off().
> 
> > > +
> > >  	mtk_dpi_power_off(dpi);
> > >  }
> > >  
> > > @@ -728,6 +725,9 @@ static void mtk_dpi_bridge_enable(struct
> > > drm_bridge *bridge)
> > >  {
> > >  	struct mtk_dpi *dpi = bridge_to_dpi(bridge);
> > >  
> > > +	if (dpi->pinctrl && dpi->pins_dpi)
> > > +		pinctrl_select_state(dpi->pinctrl, dpi->pins_dpi);
> > > +
> > >  	mtk_dpi_power_on(dpi);
> > >  	mtk_dpi_set_display_mode(dpi, &dpi->mode);
> > >  	mtk_dpi_enable(dpi);
> > 
> > Hi CK,
> > 
> > Gentle ping for this patch, if there is anything I need to modify,
> > please kindly let me know.
> > 
> > Best Regards!
> > xinlei
> > 

Hi CK:

Yes, this pacth is mainly to remove the control of the pin from 
dpi_power_on/off, because dpi_power_on/off is protected by refcount.

I will modify the position of the pull-down gpio in the next version.

Best Regards!
xinlei
diff mbox series

Patch

diff --git a/drivers/gpu/drm/mediatek/mtk_dpi.c b/drivers/gpu/drm/mediatek/mtk_dpi.c
index 630a4e301ef6..2ce1a39ce3bf 100644
--- a/drivers/gpu/drm/mediatek/mtk_dpi.c
+++ b/drivers/gpu/drm/mediatek/mtk_dpi.c
@@ -462,9 +462,6 @@  static void mtk_dpi_power_off(struct mtk_dpi *dpi)
 	if (--dpi->refcount != 0)
 		return;
 
-	if (dpi->pinctrl && dpi->pins_gpio)
-		pinctrl_select_state(dpi->pinctrl, dpi->pins_gpio);
-
 	mtk_dpi_disable(dpi);
 	clk_disable_unprepare(dpi->pixel_clk);
 	clk_disable_unprepare(dpi->engine_clk);
@@ -489,9 +486,6 @@  static int mtk_dpi_power_on(struct mtk_dpi *dpi)
 		goto err_pixel;
 	}
 
-	if (dpi->pinctrl && dpi->pins_dpi)
-		pinctrl_select_state(dpi->pinctrl, dpi->pins_dpi);
-
 	return 0;
 
 err_pixel:
@@ -721,6 +715,9 @@  static void mtk_dpi_bridge_disable(struct drm_bridge *bridge)
 {
 	struct mtk_dpi *dpi = bridge_to_dpi(bridge);
 
+	if (dpi->pinctrl && dpi->pins_gpio)
+		pinctrl_select_state(dpi->pinctrl, dpi->pins_gpio);
+
 	mtk_dpi_power_off(dpi);
 }
 
@@ -728,6 +725,9 @@  static void mtk_dpi_bridge_enable(struct drm_bridge *bridge)
 {
 	struct mtk_dpi *dpi = bridge_to_dpi(bridge);
 
+	if (dpi->pinctrl && dpi->pins_dpi)
+		pinctrl_select_state(dpi->pinctrl, dpi->pins_dpi);
+
 	mtk_dpi_power_on(dpi);
 	mtk_dpi_set_display_mode(dpi, &dpi->mode);
 	mtk_dpi_enable(dpi);