[U-Boot] [PATCH 0/2] xhci-dwc3: Couple of fixes for USB3 support

This series has couple of fixes needed to get DWC3 USB3 controller to talk to USB3 devices on AM57xx SoCs.
Vignesh R (2): usb: xhci-dwc3: Power on USB PHY before using usb: xhci-dwc3: Enable USB3 PHY when available
drivers/usb/host/xhci-dwc3.c | 47 ++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 47 insertions(+)

It is wrong that expect phy init to also power on the PHY. Therefore, explicitly, call generic_phy_power_on() after generic_phy_power_init() in order to power on PHY before using it.
Signed-off-by: Vignesh R vigneshr@ti.com --- drivers/usb/host/xhci-dwc3.c | 12 ++++++++++++ 1 file changed, 12 insertions(+)
diff --git a/drivers/usb/host/xhci-dwc3.c b/drivers/usb/host/xhci-dwc3.c index 258d1cd00a08..cf1986bebd07 100644 --- a/drivers/usb/host/xhci-dwc3.c +++ b/drivers/usb/host/xhci-dwc3.c @@ -137,6 +137,12 @@ static int xhci_dwc3_probe(struct udevice *dev) pr_err("Can't init USB PHY for %s\n", dev->name); return ret; } + + ret = generic_phy_power_on(&plat->usb_phy); + if (ret) { + pr_err("Can't power on USB PHY for %s\n", dev->name); + return ret; + } }
dwc3_reg = (struct dwc3 *)((char *)(hccr) + DWC3_REG_OFFSET); @@ -159,6 +165,12 @@ static int xhci_dwc3_remove(struct udevice *dev) int ret;
if (generic_phy_valid(&plat->usb_phy)) { + ret = generic_phy_power_off(&plat->usb_phy); + if (ret) { + pr_err("Can't poweroff USB PHY for %s\n", dev->name); + return ret; + } + ret = generic_phy_exit(&plat->usb_phy); if (ret) { pr_err("Can't deinit USB PHY for %s\n", dev->name);

On Mon, Mar 5, 2018 at 7:27 PM, Vignesh R vigneshr@ti.com wrote:
It is wrong that expect phy init to also power on the PHY. Therefore, explicitly, call generic_phy_power_on() after generic_phy_power_init() in order to power on PHY before using it.
Signed-off-by: Vignesh R vigneshr@ti.com
drivers/usb/host/xhci-dwc3.c | 12 ++++++++++++ 1 file changed, 12 insertions(+)
Reviewed-by: Bin Meng bmeng.cn@gmail.com

DWC3 USB3 controllers will need USB3 PHY to be enabled, in addition to USB2 PHY, to be functional. Therefore enable USB3 PHY when available.
Signed-off-by: Vignesh R vigneshr@ti.com --- drivers/usb/host/xhci-dwc3.c | 35 +++++++++++++++++++++++++++++++++++ 1 file changed, 35 insertions(+)
diff --git a/drivers/usb/host/xhci-dwc3.c b/drivers/usb/host/xhci-dwc3.c index cf1986bebd07..e7bc0bc35a86 100644 --- a/drivers/usb/host/xhci-dwc3.c +++ b/drivers/usb/host/xhci-dwc3.c @@ -23,6 +23,7 @@ DECLARE_GLOBAL_DATA_PTR;
struct xhci_dwc3_platdata { struct phy usb_phy; + struct phy usb3_phy; };
void dwc3_set_mode(struct dwc3 *dwc3_reg, u32 mode) @@ -145,6 +146,26 @@ static int xhci_dwc3_probe(struct udevice *dev) } }
+ ret = generic_phy_get_by_index(dev, 1, &plat->usb3_phy); + if (ret) { + if (ret != -ENOENT) { + pr_err("Failed to get USB3 PHY for %s\n", dev->name); + return ret; + } + } else { + ret = generic_phy_init(&plat->usb3_phy); + if (ret) { + pr_err("Can't init USB3 PHY for %s\n", dev->name); + return ret; + } + + ret = generic_phy_power_on(&plat->usb3_phy); + if (ret) { + pr_err("Can't power on USB3 PHY for %s\n", dev->name); + return ret; + } + } + dwc3_reg = (struct dwc3 *)((char *)(hccr) + DWC3_REG_OFFSET);
dwc3_core_init(dwc3_reg); @@ -178,6 +199,20 @@ static int xhci_dwc3_remove(struct udevice *dev) } }
+ if (generic_phy_valid(&plat->usb3_phy)) { + ret = generic_phy_power_off(&plat->usb3_phy); + if (ret) { + pr_err("Can't poweroff USB3 PHY for %s\n", dev->name); + return ret; + } + + ret = generic_phy_exit(&plat->usb3_phy); + if (ret) { + pr_err("Can't deinit USB3 PHY for %s\n", dev->name); + return ret; + } + } + return xhci_deregister(dev); }

Hi Vignesh,
On Mon, Mar 5, 2018 at 7:27 PM, Vignesh R vigneshr@ti.com wrote:
DWC3 USB3 controllers will need USB3 PHY to be enabled, in addition to USB2 PHY, to be functional. Therefore enable USB3 PHY when available.
Signed-off-by: Vignesh R vigneshr@ti.com
drivers/usb/host/xhci-dwc3.c | 35 +++++++++++++++++++++++++++++++++++ 1 file changed, 35 insertions(+)
diff --git a/drivers/usb/host/xhci-dwc3.c b/drivers/usb/host/xhci-dwc3.c index cf1986bebd07..e7bc0bc35a86 100644 --- a/drivers/usb/host/xhci-dwc3.c +++ b/drivers/usb/host/xhci-dwc3.c @@ -23,6 +23,7 @@ DECLARE_GLOBAL_DATA_PTR;
struct xhci_dwc3_platdata { struct phy usb_phy;
struct phy usb3_phy;
};
void dwc3_set_mode(struct dwc3 *dwc3_reg, u32 mode) @@ -145,6 +146,26 @@ static int xhci_dwc3_probe(struct udevice *dev) } }
ret = generic_phy_get_by_index(dev, 1, &plat->usb3_phy);
if (ret) {
if (ret != -ENOENT) {
pr_err("Failed to get USB3 PHY for %s\n", dev->name);
return ret;
}
} else {
ret = generic_phy_init(&plat->usb3_phy);
if (ret) {
pr_err("Can't init USB3 PHY for %s\n", dev->name);
return ret;
}
ret = generic_phy_power_on(&plat->usb3_phy);
if (ret) {
pr_err("Can't power on USB3 PHY for %s\n", dev->name);
return ret;
}
}
This looks superfluous. Can we abstract the PHY operation to a new function, and pass the phy pointer and index in?
dwc3_reg = (struct dwc3 *)((char *)(hccr) + DWC3_REG_OFFSET); dwc3_core_init(dwc3_reg);
@@ -178,6 +199,20 @@ static int xhci_dwc3_remove(struct udevice *dev) } }
if (generic_phy_valid(&plat->usb3_phy)) {
ret = generic_phy_power_off(&plat->usb3_phy);
if (ret) {
pr_err("Can't poweroff USB3 PHY for %s\n", dev->name);
return ret;
}
ret = generic_phy_exit(&plat->usb3_phy);
if (ret) {
pr_err("Can't deinit USB3 PHY for %s\n", dev->name);
return ret;
}
}
ditto
return xhci_deregister(dev);
}
Regards, Bin

Hi Bin,
On Tuesday 06 March 2018 12:59 PM, Bin Meng wrote:
Hi Vignesh,
On Mon, Mar 5, 2018 at 7:27 PM, Vignesh R vigneshr@ti.com wrote:
DWC3 USB3 controllers will need USB3 PHY to be enabled, in addition to USB2 PHY, to be functional. Therefore enable USB3 PHY when available.
Signed-off-by: Vignesh R vigneshr@ti.com
drivers/usb/host/xhci-dwc3.c | 35 +++++++++++++++++++++++++++++++++++ 1 file changed, 35 insertions(+)
diff --git a/drivers/usb/host/xhci-dwc3.c b/drivers/usb/host/xhci-dwc3.c index cf1986bebd07..e7bc0bc35a86 100644 --- a/drivers/usb/host/xhci-dwc3.c +++ b/drivers/usb/host/xhci-dwc3.c @@ -23,6 +23,7 @@ DECLARE_GLOBAL_DATA_PTR;
struct xhci_dwc3_platdata { struct phy usb_phy;
struct phy usb3_phy;
};
void dwc3_set_mode(struct dwc3 *dwc3_reg, u32 mode) @@ -145,6 +146,26 @@ static int xhci_dwc3_probe(struct udevice *dev) } }
ret = generic_phy_get_by_index(dev, 1, &plat->usb3_phy);
if (ret) {
if (ret != -ENOENT) {
pr_err("Failed to get USB3 PHY for %s\n", dev->name);
return ret;
}
} else {
ret = generic_phy_init(&plat->usb3_phy);
if (ret) {
pr_err("Can't init USB3 PHY for %s\n", dev->name);
return ret;
}
ret = generic_phy_power_on(&plat->usb3_phy);
if (ret) {
pr_err("Can't power on USB3 PHY for %s\n", dev->name);
return ret;
}
}
This looks superfluous. Can we abstract the PHY operation to a new function, and pass the phy pointer and index in?
Okay, will extract this into a separate function here.
dwc3_reg = (struct dwc3 *)((char *)(hccr) + DWC3_REG_OFFSET); dwc3_core_init(dwc3_reg);
@@ -178,6 +199,20 @@ static int xhci_dwc3_remove(struct udevice *dev) } }
if (generic_phy_valid(&plat->usb3_phy)) {
ret = generic_phy_power_off(&plat->usb3_phy);
if (ret) {
pr_err("Can't poweroff USB3 PHY for %s\n", dev->name);
return ret;
}
ret = generic_phy_exit(&plat->usb3_phy);
if (ret) {
pr_err("Can't deinit USB3 PHY for %s\n", dev->name);
return ret;
}
}
ditto
okay, thanks for the review!

On 03/05/2018 12:27 PM, Vignesh R wrote:
This series has couple of fixes needed to get DWC3 USB3 controller to talk to USB3 devices on AM57xx SoCs.
Vignesh R (2): usb: xhci-dwc3: Power on USB PHY before using usb: xhci-dwc3: Enable USB3 PHY when available
drivers/usb/host/xhci-dwc3.c | 47 ++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 47 insertions(+)
Bin, please give me a R-B/A-B on these. Thanks!
participants (3)
-
Bin Meng
-
Marek Vasut
-
Vignesh R