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

Marek Vasut marex at denx.de
Sat Aug 12 07:59:44 CEST 2023


On 8/11/23 21:55, Jonas Karlman wrote:
> On 2023-08-11 21:00, Marek Vasut wrote:
>> 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.
> 
> It is not, I made a note of it in the cover letter.
> 
> """
> The regulator_set_enable_if_allowed function is more relaxed and will
> return ENOSYS if the provided regulator is NULL or when DM_REGULATOR
> was disabled. Using the following call convention should be safe:

Thank you for clarifying.

Reviewed-by: Marek Vasut <marex at denx.de>


More information about the U-Boot mailing list