+ /* Type Defines: */\r
+ /** Class state structure. An instance of this structure should be made within the user application,\r
+ * and passed to each of the HID class driver functions as the HIDInterfaceInfo parameter. This\r
+ * stores each HID interface's configuration and state information.\r
+ */\r
+ typedef struct\r
+ {\r
+ const struct\r
+ {\r
+ uint8_t DataINPipeNumber; /**< Pipe number of the HID interface's IN data pipe */\r
+ uint8_t DataOUTPipeNumber; /**< Pipe number of the HID interface's OUT data pipe */\r
+ \r
+ bool MatchInterfaceProtocol;\r
+ uint8_t HIDInterfaceProtocol;\r
+ } Config; /**< Config data for the USB class interface within the device. All elements in this section\r
+ * <b>must</b> be set or the interface will fail to enumerate and operate correctly.\r
+ */\r
+ struct\r
+ {\r
+ uint16_t DataINPipeSize; /**< Size in bytes of the HID interface's IN data pipe */\r
+ uint16_t DataOUTPipeSize; /**< Size in bytes of the HID interface's OUT data pipe */\r
+ } State; /**< State data for the USB class interface within the device. All elements in this section\r
+ * <b>may</b> be set to initial values, but may also be ignored to default to sane values when\r
+ * the interface is enumerated.\r
+ */\r
+ } USB_ClassInfo_HID_Host_t;\r
+\r
+ /* Enums: */\r
+ enum\r
+ {\r
+ HID_ENUMERROR_NoError = 0, /**< Configuration Descriptor was processed successfully */\r
+ HID_ENUMERROR_ControlError = 1, /**< A control request to the device failed to complete successfully */\r
+ HID_ENUMERROR_DescriptorTooLarge = 2, /**< The device's Configuration Descriptor is too large to process */\r
+ HID_ENUMERROR_InvalidConfigDataReturned = 3, /**< The device returned an invalid Configuration Descriptor */\r
+ HID_ENUMERROR_NoHIDInterfaceFound = 4, /**< A compatible HID interface was not found in the device's Configuration Descriptor */\r
+ HID_ENUMERROR_EndpointsNotFound = 5, /**< Compatible HID endpoints were not found in the device's CDC interface */\r
+ } CDCHost_EnumerationFailure_ErrorCodes_t;\r
+ \r