This patch provides mechanism for subordinate devices to check whether the DWC3 core probed successfully or otherwise. Useful if PHYs are required to configure controllers, but aren't yet available. The DWC3 core driver will defer probe if PHYs are unavailable, however subordinate DWC3 drivers currently do not have any visibility or means to check status - until now. Another way to do this would be to *_phy_get*(), but if every driver did this it would create a high level of code duplication. Signed-off-by: Lee Jones <lee.jones@xxxxxxxxxx> --- drivers/usb/dwc3/core.c | 12 ++++++++++++ drivers/usb/dwc3/core.h | 1 + 2 files changed, 13 insertions(+) diff --git a/drivers/usb/dwc3/core.c b/drivers/usb/dwc3/core.c index eb69eb9..171ca52 100644 --- a/drivers/usb/dwc3/core.c +++ b/drivers/usb/dwc3/core.c @@ -47,6 +47,14 @@ /* -------------------------------------------------------------------------- */ +static bool is_enabled = false; + +int dwc3_is_enabled(void) +{ + return is_enabled; +} +EXPORT_SYMBOL(dwc3_is_enabled); + void dwc3_set_mode(struct dwc3 *dwc, u32 mode) { u32 reg; @@ -757,6 +765,8 @@ static int dwc3_probe(struct platform_device *pdev) pm_runtime_allow(dev); + is_enabled = true; + return 0; err3: @@ -786,6 +796,8 @@ static int dwc3_remove(struct platform_device *pdev) { struct dwc3 *dwc = platform_get_drvdata(pdev); + is_enabled = false; + usb_phy_set_suspend(dwc->usb2_phy, 1); usb_phy_set_suspend(dwc->usb3_phy, 1); phy_power_off(dwc->usb2_generic_phy); diff --git a/drivers/usb/dwc3/core.h b/drivers/usb/dwc3/core.h index 57332e3..94dee86 100644 --- a/drivers/usb/dwc3/core.h +++ b/drivers/usb/dwc3/core.h @@ -906,6 +906,7 @@ struct dwc3_gadget_ep_cmd_params { /* prototypes */ void dwc3_set_mode(struct dwc3 *dwc, u32 mode); int dwc3_gadget_resize_tx_fifos(struct dwc3 *dwc); +int dwc3_is_enabled(void); #if IS_ENABLED(CONFIG_USB_DWC3_HOST) || IS_ENABLED(CONFIG_USB_DWC3_DUAL_ROLE) int dwc3_host_init(struct dwc3 *dwc); -- 1.8.3.2 -- To unsubscribe from this list: send the line "unsubscribe linux-usb" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html