mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/next/linux-next.git
synced 2025-01-17 13:58:46 +00:00
usb: common: usb-conn-gpio: Make VBUS supply completely optional
It makes sense that if the USB connector is a child of an USB port providing VBUS supply, there is no need to do it again. But this does not handle the case where VBUS is controlled by PWR from USB host controller, without any regulator at all. Support this by making VBUS pure optional. Signed-off-by: Alexander Stein <alexander.stein@ew.tq-group.com> Link: https://lore.kernel.org/r/20220309093842.113260-1-alexander.stein@ew.tq-group.com Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
This commit is contained in:
parent
b07cabb836
commit
d790a9db91
@ -175,7 +175,6 @@ static int usb_conn_probe(struct platform_device *pdev)
|
|||||||
{
|
{
|
||||||
struct device *dev = &pdev->dev;
|
struct device *dev = &pdev->dev;
|
||||||
struct usb_conn_info *info;
|
struct usb_conn_info *info;
|
||||||
bool need_vbus = true;
|
|
||||||
int ret = 0;
|
int ret = 0;
|
||||||
|
|
||||||
info = devm_kzalloc(dev, sizeof(*info), GFP_KERNEL);
|
info = devm_kzalloc(dev, sizeof(*info), GFP_KERNEL);
|
||||||
@ -205,22 +204,9 @@ static int usb_conn_probe(struct platform_device *pdev)
|
|||||||
|
|
||||||
INIT_DELAYED_WORK(&info->dw_det, usb_conn_detect_cable);
|
INIT_DELAYED_WORK(&info->dw_det, usb_conn_detect_cable);
|
||||||
|
|
||||||
/*
|
info->vbus = devm_regulator_get_optional(dev, "vbus");
|
||||||
* If the USB connector is a child of a USB port and that port already provides the VBUS
|
if (PTR_ERR(info->vbus) == -ENODEV)
|
||||||
* supply, there's no need for the USB connector to provide it again.
|
info->vbus = NULL;
|
||||||
*/
|
|
||||||
if (dev->parent && dev->parent->of_node) {
|
|
||||||
if (of_find_property(dev->parent->of_node, "vbus-supply", NULL))
|
|
||||||
need_vbus = false;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (!need_vbus) {
|
|
||||||
info->vbus = devm_regulator_get_optional(dev, "vbus");
|
|
||||||
if (PTR_ERR(info->vbus) == -ENODEV)
|
|
||||||
info->vbus = NULL;
|
|
||||||
} else {
|
|
||||||
info->vbus = devm_regulator_get(dev, "vbus");
|
|
||||||
}
|
|
||||||
|
|
||||||
if (IS_ERR(info->vbus)) {
|
if (IS_ERR(info->vbus)) {
|
||||||
ret = PTR_ERR(info->vbus);
|
ret = PTR_ERR(info->vbus);
|
||||||
|
Loading…
x
Reference in New Issue
Block a user