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 <jo...@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.

Reply via email to