usb: chipidea: introduce CI_HDRC_CONTROLLER_VBUS_EVENT glue layer use
authorPeter Chen <peter.chen@nxp.com>
Thu, 23 Jan 2020 06:00:26 +0000 (14:00 +0800)
committerPeter Chen <peter.chen@nxp.com>
Wed, 6 May 2020 01:41:55 +0000 (09:41 +0800)
Some vendors glue layer need to handle some events for vbus, eg,
some i.mx platforms (imx7d, imx8mm, imx8mn, etc) needs vbus event
to handle charger detection, its charger detection is finished at
glue layer code, but not at USB PHY driver.

Signed-off-by: Peter Chen <peter.chen@nxp.com>
drivers/usb/chipidea/udc.c
include/linux/usb/chipidea.h

index 921bcf14dc06154ad67649292889565605390a73..da70fbe7ca4c9130722b2244b23ee84b7bf7a62a 100644 (file)
@@ -1561,6 +1561,7 @@ static int ci_udc_vbus_session(struct usb_gadget *_gadget, int is_active)
 {
        struct ci_hdrc *ci = container_of(_gadget, struct ci_hdrc, gadget);
        unsigned long flags;
+       int ret = 0;
 
        spin_lock_irqsave(&ci->lock, flags);
        ci->vbus_active = is_active;
@@ -1570,10 +1571,14 @@ static int ci_udc_vbus_session(struct usb_gadget *_gadget, int is_active)
                usb_phy_set_charger_state(ci->usb_phy, is_active ?
                        USB_CHARGER_PRESENT : USB_CHARGER_ABSENT);
 
+       if (ci->platdata->notify_event)
+               ret = ci->platdata->notify_event(ci,
+                               CI_HDRC_CONTROLLER_VBUS_EVENT);
+
        if (ci->driver)
                ci_hdrc_gadget_connect(_gadget, is_active);
 
-       return 0;
+       return ret;
 }
 
 static int ci_udc_wakeup(struct usb_gadget *_gadget)
index edd89b7c8f184dbe18617706f0e1d93e1e916fa5..54167a2d28ea224bed8cad11e3bfd94df1d60586 100644 (file)
@@ -67,6 +67,7 @@ struct ci_hdrc_platform_data {
 #define CI_HDRC_CONTROLLER_STOPPED_EVENT       1
 #define CI_HDRC_IMX_HSIC_ACTIVE_EVENT          2
 #define CI_HDRC_IMX_HSIC_SUSPEND_EVENT         3
+#define CI_HDRC_CONTROLLER_VBUS_EVENT          4
        int     (*notify_event) (struct ci_hdrc *ci, unsigned event);
        struct regulator        *reg_vbus;
        struct usb_otg_caps     ci_otg_caps;