mirror of
https://github.com/AsahiLinux/u-boot
synced 2024-12-01 08:59:33 +00:00
phy: usbphyc: use regulator_set_enable_if_allowed for disabling vbus supply
Use regulator_set_enable_if_allowed() api instead of regulator_set_enable() while disabling vbus supply. This way the driver doesn't see an error when it disable an always-on regulator for VBUS. This patch is needed for STM32MP157C-DK2 board when the regulator v3v3: buck4 used as the phy vbus supply in kernel device tree is always on with the next hack for low power use-case: &usbphyc_port0 { ... /* * Hack to keep hub active until all connected devices are suspended * otherwise the hub will be powered off as soon as the v3v3 is disabled * and it can disturb connected devices. */ connector { compatible = "usb-a-connector"; vbus-supply = <&v3v3>; }; }; Without this patch and the previous update in DT the command "usb stop" failed and the next command "usb start" cause a crash. Signed-off-by: Patrick Delaunay <patrick.delaunay@foss.st.com> Reviewed-by: Patrice Chotard <patrice.chotard@foss.st.com> Reviewed-by: Marek Vasut <marex@denx.de>
This commit is contained in:
parent
7a7b0856ca
commit
91dae6d0a1
1 changed files with 1 additions and 1 deletions
|
@ -375,7 +375,7 @@ static int stm32_usbphyc_phy_power_off(struct phy *phy)
|
||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
if (usbphyc_phy->vbus) {
|
if (usbphyc_phy->vbus) {
|
||||||
ret = regulator_set_enable(usbphyc_phy->vbus, false);
|
ret = regulator_set_enable_if_allowed(usbphyc_phy->vbus, false);
|
||||||
if (ret)
|
if (ret)
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue