static void ci13xxx_msm_notify_event(struct ci13xxx *ci, unsigned event) { struct device *dev = ci->gadget.dev.parent; switch (event) { case CI13XXX_CONTROLLER_RESET_EVENT: dev_info(dev, "CI13XXX_CONTROLLER_RESET_EVENT received\n"); ci13xxx_msm_reset(ci); break; case CI13XXX_CONTROLLER_DISCONNECT_EVENT: dev_info(dev, "CI13XXX_CONTROLLER_DISCONNECT_EVENT received\n"); ci13xxx_msm_disconnect(ci); ci13xxx_msm_resume(ci); break; case CI13XXX_CONTROLLER_CONNECT_EVENT: dev_info(dev, "CI13XXX_CONTROLLER_CONNECT_EVENT received\n"); ci13xxx_msm_connect(ci); break; case CI13XXX_CONTROLLER_SUSPEND_EVENT: dev_info(dev, "CI13XXX_CONTROLLER_SUSPEND_EVENT received\n"); ci13xxx_msm_suspend(ci); break; case CI13XXX_CONTROLLER_RESUME_EVENT: dev_info(dev, "CI13XXX_CONTROLLER_RESUME_EVENT received\n"); ci13xxx_msm_resume(ci); break; default: dev_dbg(dev, "unknown ci13xxx event\n"); break; } }
static void ci13xxx_msm_notify_event(struct ci13xxx *udc, unsigned event) { struct device *dev = udc->gadget.dev.parent; switch (event) { case CI13XXX_CONTROLLER_RESET_EVENT: dev_info(dev, "CI13XXX_CONTROLLER_RESET_EVENT received\n"); ci13xxx_msm_reset(); break; case CI13XXX_CONTROLLER_DISCONNECT_EVENT: dev_info(dev, "CI13XXX_CONTROLLER_DISCONNECT_EVENT received\n"); ci13xxx_msm_disconnect(); ci13xxx_msm_resume(); break; case CI13XXX_CONTROLLER_CONNECT_EVENT: dev_info(dev, "CI13XXX_CONTROLLER_CONNECT_EVENT received\n"); ci13xxx_msm_connect(); break; case CI13XXX_CONTROLLER_SUSPEND_EVENT: dev_info(dev, "CI13XXX_CONTROLLER_SUSPEND_EVENT received\n"); ci13xxx_msm_suspend(); break; case CI13XXX_CONTROLLER_RESUME_EVENT: dev_info(dev, "CI13XXX_CONTROLLER_RESUME_EVENT received\n"); ci13xxx_msm_resume(); break; case CI13XXX_CONTROLLER_ERROR_EVENT: dev_info(dev, "CI13XXX_CONTROLLER_ERROR_EVENT received\n"); ci13xxx_msm_mark_err_event(); break; case CI13XXX_CONTROLLER_UDC_STARTED_EVENT: dev_info(dev, "CI13XXX_CONTROLLER_UDC_STARTED_EVENT received\n"); udc->gadget.interrupt_num = _udc_ctxt.irq; break; default: dev_dbg(dev, "unknown ci13xxx_udc event\n"); break; } }
static void ci13xxx_msm_notify_event(struct ci13xxx *udc, unsigned event) { struct device *dev = udc->gadget.dev.parent; switch (event) { case CI13XXX_CONTROLLER_RESET_EVENT: dev_info(dev, "CI13XXX_CONTROLLER_RESET_EVENT received\n"); ci13xxx_msm_reset(); #ifdef CONFIG_USB_G_LGE_ANDROID cancel_delayed_work_sync(&_udc_ctxt.wunlock_w); wake_lock(&_udc_ctxt.wlock); #endif break; case CI13XXX_CONTROLLER_DISCONNECT_EVENT: dev_info(dev, "CI13XXX_CONTROLLER_DISCONNECT_EVENT received\n"); ci13xxx_msm_disconnect(); ci13xxx_msm_resume(); #ifdef CONFIG_USB_G_LGE_ANDROID schedule_delayed_work(&_udc_ctxt.wunlock_w, UNLOCK_DELAY); #endif break; case CI13XXX_CONTROLLER_CONNECT_EVENT: dev_info(dev, "CI13XXX_CONTROLLER_CONNECT_EVENT received\n"); ci13xxx_msm_connect(); break; case CI13XXX_CONTROLLER_SUSPEND_EVENT: dev_info(dev, "CI13XXX_CONTROLLER_SUSPEND_EVENT received\n"); ci13xxx_msm_suspend(); break; case CI13XXX_CONTROLLER_RESUME_EVENT: dev_info(dev, "CI13XXX_CONTROLLER_RESUME_EVENT received\n"); ci13xxx_msm_resume(); break; default: dev_dbg(dev, "unknown ci13xxx_udc event\n"); break; } #ifdef CONFIG_LGE_PM_VZW_FAST_CHG switch (event) { case CI13XXX_CONTROLLER_CONNECT_EVENT: case CI13XXX_CONTROLLER_RESUME_EVENT: pr_info("%s: [USB_DRV] CONNECTING\n", __func__); if (usb_connecting_flag) { cancel_delayed_work_sync(&usb_detect_w); } else { usb_connecting_flag = true; } usb_connected_flag = false; usb_configured_flag = false; lge_usb_config_finish = 0; schedule_delayed_work(&usb_detect_w, USB_DETECT_DELAY); break; case CI13XXX_CONTROLLER_DISCONNECT_EVENT: cancel_delayed_work_sync(&usb_detect_w); lge_usb_config_finish = 0; usb_connecting_flag = false; usb_connected_flag = false; usb_configured_flag = false; break; default: break; } #endif }