diff mbox series

drm/panel: ili9341: fix optional regulator handling

Message ID 20220317225537.826302-1-daniel@zonque.org (mailing list archive)
State New, archived
Headers show
Series drm/panel: ili9341: fix optional regulator handling | expand

Commit Message

Daniel Mack March 17, 2022, 10:55 p.m. UTC
If the optional regulator lookup fails, reset the pointer to NULL.
Other functions such as mipi_dbi_poweron_reset_conditional() only do
a NULL pointer check and will otherwise dereference the error pointer.

Fixes: 5a04227326b04c15 ("drm/panel: Add ilitek ili9341 panel driver")
Signed-off-by: Daniel Mack <daniel@zonque.org>
---
 drivers/gpu/drm/panel/panel-ilitek-ili9341.c | 4 +++-
 1 file changed, 3 insertions(+), 1 deletion(-)

Comments

Daniel Vetter March 18, 2022, 10:09 a.m. UTC | #1
On Thu, Mar 17, 2022 at 11:55:37PM +0100, Daniel Mack wrote:
> If the optional regulator lookup fails, reset the pointer to NULL.
> Other functions such as mipi_dbi_poweron_reset_conditional() only do
> a NULL pointer check and will otherwise dereference the error pointer.
> 
> Fixes: 5a04227326b04c15 ("drm/panel: Add ilitek ili9341 panel driver")
> Signed-off-by: Daniel Mack <daniel@zonque.org>

Merged into drm-misc-fixes and added cc: stable.
-Daniel
> ---
>  drivers/gpu/drm/panel/panel-ilitek-ili9341.c | 4 +++-
>  1 file changed, 3 insertions(+), 1 deletion(-)
> 
> diff --git a/drivers/gpu/drm/panel/panel-ilitek-ili9341.c b/drivers/gpu/drm/panel/panel-ilitek-ili9341.c
> index 2c3378a259b1..e1542451ef9d 100644
> --- a/drivers/gpu/drm/panel/panel-ilitek-ili9341.c
> +++ b/drivers/gpu/drm/panel/panel-ilitek-ili9341.c
> @@ -612,8 +612,10 @@ static int ili9341_dbi_probe(struct spi_device *spi, struct gpio_desc *dc,
>  	int ret;
>  
>  	vcc = devm_regulator_get_optional(dev, "vcc");
> -	if (IS_ERR(vcc))
> +	if (IS_ERR(vcc)) {
>  		dev_err(dev, "get optional vcc failed\n");
> +		vcc = NULL;
> +	}
>  
>  	dbidev = devm_drm_dev_alloc(dev, &ili9341_dbi_driver,
>  				    struct mipi_dbi_dev, drm);
> -- 
> 2.35.1
>
diff mbox series

Patch

diff --git a/drivers/gpu/drm/panel/panel-ilitek-ili9341.c b/drivers/gpu/drm/panel/panel-ilitek-ili9341.c
index 2c3378a259b1..e1542451ef9d 100644
--- a/drivers/gpu/drm/panel/panel-ilitek-ili9341.c
+++ b/drivers/gpu/drm/panel/panel-ilitek-ili9341.c
@@ -612,8 +612,10 @@  static int ili9341_dbi_probe(struct spi_device *spi, struct gpio_desc *dc,
 	int ret;
 
 	vcc = devm_regulator_get_optional(dev, "vcc");
-	if (IS_ERR(vcc))
+	if (IS_ERR(vcc)) {
 		dev_err(dev, "get optional vcc failed\n");
+		vcc = NULL;
+	}
 
 	dbidev = devm_drm_dev_alloc(dev, &ili9341_dbi_driver,
 				    struct mipi_dbi_dev, drm);