[PATCH v1 2/3] video: simple_panel: use regulator_set_enable_if_allowed

Jonas Karlman jonas at kwiboo.se
Sat Aug 12 12:08:27 CEST 2023


On 2023-08-12 11:59, Svyatoslav Ryhel wrote:
> With the commit 4fcba5d556b4 ("regulator: implement basic reference
> counter") the return value of regulator_set_enable may be EALREADY or
> EBUSY for fixed/gpio regulators and may be further expanded on all
> regulators.
> 
> Change to use the more relaxed regulator_set_enable_if_allowed to
> continue if regulator already was enabled or disabled.
> 
> Signed-off-by: Svyatoslav Ryhel <clamor95 at gmail.com>
> ---
>  drivers/video/simple_panel.c | 10 +++++-----
>  1 file changed, 5 insertions(+), 5 deletions(-)
> 
> diff --git a/drivers/video/simple_panel.c b/drivers/video/simple_panel.c
> index 6a6473eb0e..eb4eed217d 100644
> --- a/drivers/video/simple_panel.c
> +++ b/drivers/video/simple_panel.c
> @@ -114,11 +114,11 @@ static int simple_panel_probe(struct udevice *dev)
>  	const u32 dsi_data = dev_get_driver_data(dev);
>  	int ret;
>  
> -	if (CONFIG_IS_ENABLED(DM_REGULATOR) && priv->reg) {
> -		debug("%s: Enable regulator '%s'\n", __func__, priv->reg->name);
> -		ret = regulator_set_enable(priv->reg, true);
> -		if (ret)
> -			return ret;
> +	ret = regulator_set_enable_if_allowed(priv->reg, true);
> +	if (ret) {

Should be 'ret && ret != -ENOSYS' because you remove the
CONFIG_IS_ENABLED(DM_REGULATOR) check.

Regards,
Jonas

> +		debug("%s: failed to enable regulator '%s' %d\n",
> +		      __func__, priv->reg->name, ret);
> +		return ret;
>  	}
>  
>  	switch (dsi_data) {



More information about the U-Boot mailing list