/* See virtual_com.h for documentation of this function. */ void USB_VcomDeinit(usb_device_handle deviceHandle) { USB_DeviceStop(deviceHandle); USB_DeviceDeinit(deviceHandle); s_cdcVcom.deviceHandle = NULL; #if defined(USB_DEVICE_CONFIG_EHCI) && (USB_DEVICE_CONFIG_EHCI > 0) USB_EhciPhyDeinit(CONTROLLER_ID); #endif #if defined(USB_DEVICE_CONFIG_KHCI) && (USB_DEVICE_CONFIG_KHCI > 0) CLOCK_DisableUsbfs0Clock(); #endif #if defined(USB_DEVICE_CONFIG_LPCIP3511FS) && (USB_DEVICE_CONFIG_LPCIP3511FS > 0U) /* enable USB IP clock, user code. */ CLOCK_DisableClock(kCLOCK_Usbd0); #endif /* USB_DEVICE_CONFIG_LPCIP3511FS */ #if defined(USB_DEVICE_CONFIG_LPCIP3511HS) && (USB_DEVICE_CONFIG_LPCIP3511HS > 0U) /* enable USB IP clock,user code. */ #endif /* USB_DEVICE_CONFIG_LPCIP3511HS */ }
/* The device callback */ static usb_status_t USB_DeviceCallback(usb_device_handle handle, uint32_t event, void *param) { usb_status_t error = kStatus_USB_Error; uint16_t *temp16 = (uint16_t *)param; uint8_t *temp8 = (uint8_t *)param; switch (event) { case kUSB_DeviceEventBusReset: { /* USB bus reset signal detected */ g_UsbDeviceHidMouse.attach = 0U; error = kStatus_USB_Success; #if defined(USB_DEVICE_CONFIG_EHCI) && (USB_DEVICE_CONFIG_EHCI > 0U) /* Get USB speed to configure the device, including max packet size and interval of the endpoints. */ if (kStatus_USB_Success == USB_DeviceClassGetSpeed(CONTROLLER_ID, &g_UsbDeviceHidMouse.speed)) { USB_DeviceSetSpeed(handle, g_UsbDeviceHidMouse.speed); } #endif } break; #if (defined(USB_DEVICE_CONFIG_DETACH_ENABLE) && (USB_DEVICE_CONFIG_DETACH_ENABLE > 0U)) case kUSB_DeviceEventAttach: { usb_echo("USB device attached.\r\n"); USB_DeviceRun(g_UsbDeviceHidMouse.deviceHandle); } break; case kUSB_DeviceEventDetach: { usb_echo("USB device detached.\r\n"); g_UsbDeviceHidMouse.attach = 0; USB_DeviceStop(g_UsbDeviceHidMouse.deviceHandle); } break; #endif case kUSB_DeviceEventSetConfiguration: if (param) { /* Set device configuration request */ g_UsbDeviceHidMouse.attach = 1U; g_UsbDeviceHidMouse.currentConfiguration = *temp8; if (USB_HID_MOUSE_CONFIGURE_INDEX == (*temp8)) { error = USB_DeviceHidMouseAction(); } } break; case kUSB_DeviceEventSetInterface: if (g_UsbDeviceHidMouse.attach) { /* Set device interface request */ uint8_t interface = (uint8_t)((*temp16 & 0xFF00U) >> 0x08U); uint8_t alternateSetting = (uint8_t)(*temp16 & 0x00FFU); if (interface < USB_HID_MOUSE_INTERFACE_COUNT) { g_UsbDeviceHidMouse.currentInterfaceAlternateSetting[interface] = alternateSetting; if (alternateSetting == 0U) { error = USB_DeviceHidMouseAction(); } } } break; case kUSB_DeviceEventGetConfiguration: if (param) { /* Get current configuration request */ *temp8 = g_UsbDeviceHidMouse.currentConfiguration; error = kStatus_USB_Success; } break; case kUSB_DeviceEventGetInterface: if (param) { /* Get current alternate setting of the interface request */ uint8_t interface = (uint8_t)((*temp16 & 0xFF00U) >> 0x08U); if (interface < USB_HID_MOUSE_INTERFACE_COUNT) { *temp16 = (*temp16 & 0xFF00U) | g_UsbDeviceHidMouse.currentInterfaceAlternateSetting[interface]; error = kStatus_USB_Success; } else { error = kStatus_USB_InvalidRequest; } } break; case kUSB_DeviceEventGetDeviceDescriptor: if (param) { /* Get device descriptor request */ error = USB_DeviceGetDeviceDescriptor(handle, (usb_device_get_device_descriptor_struct_t *)param); } break; case kUSB_DeviceEventGetConfigurationDescriptor: if (param) { /* Get device configuration descriptor request */ error = USB_DeviceGetConfigurationDescriptor(handle, (usb_device_get_configuration_descriptor_struct_t *)param); } break; case kUSB_DeviceEventGetStringDescriptor: if (param) { /* Get device string descriptor request */ error = USB_DeviceGetStringDescriptor(handle, (usb_device_get_string_descriptor_struct_t *)param); } break; case kUSB_DeviceEventGetHidDescriptor: if (param) { /* Get hid descriptor request */ error = USB_DeviceGetHidDescriptor(handle, (usb_device_get_hid_descriptor_struct_t *)param); } break; case kUSB_DeviceEventGetHidReportDescriptor: if (param) { /* Get hid report descriptor request */ error = USB_DeviceGetHidReportDescriptor(handle, (usb_device_get_hid_report_descriptor_struct_t *)param); } break; case kUSB_DeviceEventGetHidPhysicalDescriptor: if (param) { /* Get hid physical descriptor request */ error = USB_DeviceGetHidPhysicalDescriptor(handle, (usb_device_get_hid_physical_descriptor_struct_t *)param); } break; default: break; }