[PATCH 3/5] usb: ehci-generic: Use regulator_set_enable_if_allowed

Marek Vasut marex at denx.de
Fri Aug 11 21:00:18 CEST 2023


On 7/19/23 23:20, Jonas Karlman 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.
> 
> Change to use the more relaxed regulator_set_enable_if_allowed to
> continue if regulator already was enabled or disabled.
> 
> Signed-off-by: Jonas Karlman <jonas at kwiboo.se>
> ---
>   drivers/usb/host/ehci-generic.c | 23 +++++++++++------------
>   1 file changed, 11 insertions(+), 12 deletions(-)
> 
> diff --git a/drivers/usb/host/ehci-generic.c b/drivers/usb/host/ehci-generic.c
> index a765a307a323..936e30438d9f 100644
> --- a/drivers/usb/host/ehci-generic.c
> +++ b/drivers/usb/host/ehci-generic.c
> @@ -39,14 +39,10 @@ static int ehci_enable_vbus_supply(struct udevice *dev)
>   	if (ret && ret != -ENOENT)
>   		return ret;
>   
> -	if (priv->vbus_supply) {
> -		ret = regulator_set_enable(priv->vbus_supply, true);
> -		if (ret) {
> -			dev_err(dev, "Error enabling VBUS supply (ret=%d)\n", ret);
> -			return ret;
> -		}
> -	} else {
> -		dev_dbg(dev, "No vbus supply\n");
> +	ret = regulator_set_enable_if_allowed(priv->vbus_supply, true);
> +	if (ret && ret != -ENOSYS) {

Same comment as 2/5 -- the priv->vbus_supply check is likely mandatory.


More information about the U-Boot mailing list