Merge remote-tracking branch 'upstream/master' into edpt_ISO_xfer
This commit is contained in:
		| @@ -1,6 +1,6 @@ | |||||||
| # TinyUSB | # TinyUSB | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
| [](https://github.com/hathach/tinyusb/actions) [](https://opensource.org/licenses/MIT) | [](https://github.com/hathach/tinyusb/actions) [](https://opensource.org/licenses/MIT) | ||||||
|  |  | ||||||
|   | |||||||
| @@ -239,9 +239,10 @@ void tud_hid_report_complete_cb(uint8_t itf, uint8_t const* report, uint8_t len) | |||||||
| // Invoked when received GET_REPORT control request | // Invoked when received GET_REPORT control request | ||||||
| // Application must fill buffer report's content and return its length. | // Application must fill buffer report's content and return its length. | ||||||
| // Return zero will cause the stack to STALL request | // Return zero will cause the stack to STALL request | ||||||
| uint16_t tud_hid_get_report_cb(uint8_t report_id, hid_report_type_t report_type, uint8_t* buffer, uint16_t reqlen) | uint16_t tud_hid_get_report_cb(uint8_t itf, uint8_t report_id, hid_report_type_t report_type, uint8_t* buffer, uint16_t reqlen) | ||||||
| { | { | ||||||
|   // TODO not Implemented |   // TODO not Implemented | ||||||
|  |   (void) itf; | ||||||
|   (void) report_id; |   (void) report_id; | ||||||
|   (void) report_type; |   (void) report_type; | ||||||
|   (void) buffer; |   (void) buffer; | ||||||
| @@ -252,9 +253,10 @@ uint16_t tud_hid_get_report_cb(uint8_t report_id, hid_report_type_t report_type, | |||||||
|  |  | ||||||
| // Invoked when received SET_REPORT control request or | // Invoked when received SET_REPORT control request or | ||||||
| // received data on OUT endpoint ( Report ID = 0, Type = 0 ) | // received data on OUT endpoint ( Report ID = 0, Type = 0 ) | ||||||
| void tud_hid_set_report_cb(uint8_t report_id, hid_report_type_t report_type, uint8_t const* buffer, uint16_t bufsize) | void tud_hid_set_report_cb(uint8_t itf, uint8_t report_id, hid_report_type_t report_type, uint8_t const* buffer, uint16_t bufsize) | ||||||
| { | { | ||||||
|   // TODO set LED based on CAPLOCK, NUMLOCK etc... |   // TODO set LED based on CAPLOCK, NUMLOCK etc... | ||||||
|  |   (void) itf; | ||||||
|   (void) report_id; |   (void) report_id; | ||||||
|   (void) report_type; |   (void) report_type; | ||||||
|   (void) buffer; |   (void) buffer; | ||||||
|   | |||||||
| @@ -82,8 +82,9 @@ uint8_t const desc_hid_report[] = | |||||||
| // Invoked when received GET HID REPORT DESCRIPTOR | // Invoked when received GET HID REPORT DESCRIPTOR | ||||||
| // Application return pointer to descriptor | // Application return pointer to descriptor | ||||||
| // Descriptor contents must exist long enough for transfer to complete | // Descriptor contents must exist long enough for transfer to complete | ||||||
| uint8_t const * tud_hid_descriptor_report_cb(void) | uint8_t const * tud_hid_descriptor_report_cb(uint8_t itf) | ||||||
| { | { | ||||||
|  |   (void) itf; | ||||||
|   return desc_hid_report; |   return desc_hid_report; | ||||||
| } | } | ||||||
|  |  | ||||||
|   | |||||||
| @@ -299,9 +299,10 @@ void tud_hid_report_complete_cb(uint8_t itf, uint8_t const* report, uint8_t len) | |||||||
| // Invoked when received GET_REPORT control request | // Invoked when received GET_REPORT control request | ||||||
| // Application must fill buffer report's content and return its length. | // Application must fill buffer report's content and return its length. | ||||||
| // Return zero will cause the stack to STALL request | // Return zero will cause the stack to STALL request | ||||||
| uint16_t tud_hid_get_report_cb(uint8_t report_id, hid_report_type_t report_type, uint8_t* buffer, uint16_t reqlen) | uint16_t tud_hid_get_report_cb(uint8_t itf, uint8_t report_id, hid_report_type_t report_type, uint8_t* buffer, uint16_t reqlen) | ||||||
| { | { | ||||||
|   // TODO not Implemented |   // TODO not Implemented | ||||||
|  |   (void) itf; | ||||||
|   (void) report_id; |   (void) report_id; | ||||||
|   (void) report_type; |   (void) report_type; | ||||||
|   (void) buffer; |   (void) buffer; | ||||||
| @@ -312,9 +313,10 @@ uint16_t tud_hid_get_report_cb(uint8_t report_id, hid_report_type_t report_type, | |||||||
|  |  | ||||||
| // Invoked when received SET_REPORT control request or | // Invoked when received SET_REPORT control request or | ||||||
| // received data on OUT endpoint ( Report ID = 0, Type = 0 ) | // received data on OUT endpoint ( Report ID = 0, Type = 0 ) | ||||||
| void tud_hid_set_report_cb(uint8_t report_id, hid_report_type_t report_type, uint8_t const* buffer, uint16_t bufsize) | void tud_hid_set_report_cb(uint8_t itf, uint8_t report_id, hid_report_type_t report_type, uint8_t const* buffer, uint16_t bufsize) | ||||||
| { | { | ||||||
|   // TODO set LED based on CAPLOCK, NUMLOCK etc... |   // TODO set LED based on CAPLOCK, NUMLOCK etc... | ||||||
|  |   (void) itf; | ||||||
|   (void) report_id; |   (void) report_id; | ||||||
|   (void) report_type; |   (void) report_type; | ||||||
|   (void) buffer; |   (void) buffer; | ||||||
|   | |||||||
| @@ -82,8 +82,9 @@ uint8_t const desc_hid_report[] = | |||||||
| // Invoked when received GET HID REPORT DESCRIPTOR | // Invoked when received GET HID REPORT DESCRIPTOR | ||||||
| // Application return pointer to descriptor | // Application return pointer to descriptor | ||||||
| // Descriptor contents must exist long enough for transfer to complete | // Descriptor contents must exist long enough for transfer to complete | ||||||
| uint8_t const * tud_hid_descriptor_report_cb(void) | uint8_t const * tud_hid_descriptor_report_cb(uint8_t itf) | ||||||
| { | { | ||||||
|  |   (void) itf; | ||||||
|   return desc_hid_report; |   return desc_hid_report; | ||||||
| } | } | ||||||
|  |  | ||||||
|   | |||||||
| @@ -121,9 +121,10 @@ void tud_resume_cb(void) | |||||||
| // Invoked when received GET_REPORT control request | // Invoked when received GET_REPORT control request | ||||||
| // Application must fill buffer report's content and return its length. | // Application must fill buffer report's content and return its length. | ||||||
| // Return zero will cause the stack to STALL request | // Return zero will cause the stack to STALL request | ||||||
| uint16_t tud_hid_get_report_cb(uint8_t report_id, hid_report_type_t report_type, uint8_t* buffer, uint16_t reqlen) | uint16_t tud_hid_get_report_cb(uint8_t itf, uint8_t report_id, hid_report_type_t report_type, uint8_t* buffer, uint16_t reqlen) | ||||||
| { | { | ||||||
|   // TODO not Implemented |   // TODO not Implemented | ||||||
|  |   (void) itf; | ||||||
|   (void) report_id; |   (void) report_id; | ||||||
|   (void) report_type; |   (void) report_type; | ||||||
|   (void) buffer; |   (void) buffer; | ||||||
| @@ -134,9 +135,10 @@ uint16_t tud_hid_get_report_cb(uint8_t report_id, hid_report_type_t report_type, | |||||||
|  |  | ||||||
| // Invoked when received SET_REPORT control request or | // Invoked when received SET_REPORT control request or | ||||||
| // received data on OUT endpoint ( Report ID = 0, Type = 0 ) | // received data on OUT endpoint ( Report ID = 0, Type = 0 ) | ||||||
| void tud_hid_set_report_cb(uint8_t report_id, hid_report_type_t report_type, uint8_t const* buffer, uint16_t bufsize) | void tud_hid_set_report_cb(uint8_t itf, uint8_t report_id, hid_report_type_t report_type, uint8_t const* buffer, uint16_t bufsize) | ||||||
| { | { | ||||||
|   // This example doesn't use multiple report and report ID |   // This example doesn't use multiple report and report ID | ||||||
|  |   (void) itf; | ||||||
|   (void) report_id; |   (void) report_id; | ||||||
|   (void) report_type; |   (void) report_type; | ||||||
|  |  | ||||||
|   | |||||||
| @@ -78,8 +78,9 @@ uint8_t const desc_hid_report[] = | |||||||
| // Invoked when received GET HID REPORT DESCRIPTOR | // Invoked when received GET HID REPORT DESCRIPTOR | ||||||
| // Application return pointer to descriptor | // Application return pointer to descriptor | ||||||
| // Descriptor contents must exist long enough for transfer to complete | // Descriptor contents must exist long enough for transfer to complete | ||||||
| uint8_t const * tud_hid_descriptor_report_cb(void) | uint8_t const * tud_hid_descriptor_report_cb(uint8_t itf) | ||||||
| { | { | ||||||
|  |   (void) itf; | ||||||
|   return desc_hid_report; |   return desc_hid_report; | ||||||
| } | } | ||||||
|  |  | ||||||
|   | |||||||
| @@ -172,25 +172,11 @@ void board_init(void) | |||||||
|    */ |    */ | ||||||
| #if CFG_TUSB_RHPORT0_MODE | #if CFG_TUSB_RHPORT0_MODE | ||||||
|   Chip_USB0_Init(); |   Chip_USB0_Init(); | ||||||
|  |  | ||||||
|   // Reset controller |  | ||||||
|   LPC_USB0->USBCMD_D |= 0x02; |  | ||||||
|   while( LPC_USB0->USBCMD_D & 0x02 ) {} |  | ||||||
|  |  | ||||||
|   // Set mode |  | ||||||
|   #if CFG_TUSB_RHPORT0_MODE & OPT_MODE_HOST |  | ||||||
|     LPC_USB0->USBMODE_H = USBMODE_HOST | (USBMODE_VBUS_HIGH << 5); |  | ||||||
|  |  | ||||||
|     LPC_USB0->PORTSC1_D |= (1<<24); // FIXME force full speed for debugging |  | ||||||
|   #else // TODO OTG |  | ||||||
|     LPC_USB0->USBMODE_D = USBMODE_DEVICE; |  | ||||||
|     LPC_USB0->OTGSC = (1<<3) | (1<<0) /*| (1<<16)| (1<<24)| (1<<25)| (1<<26)| (1<<27)| (1<<28)| (1<<29)| (1<<30)*/; |  | ||||||
|   #endif |  | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
|   /* USB1 |   /* From EA4357 user manual | ||||||
|    * |    * | ||||||
|    * For USB Device: |    * For USB1 Device: | ||||||
|    * - a 1.5Kohm pull-up resistor is needed on the USB DP data signal. There are two methods to create this. |    * - a 1.5Kohm pull-up resistor is needed on the USB DP data signal. There are two methods to create this. | ||||||
|    * JP15 is inserted and the pull-up resistor is always enabled. Alternatively, the pull-up resistor is activated |    * JP15 is inserted and the pull-up resistor is always enabled. Alternatively, the pull-up resistor is activated | ||||||
|    * inside the USB OTG chip (U31), and this has to be done via the I2C interface of GPIO52/GPIO53. In the latter case, |    * inside the USB OTG chip (U31), and this has to be done via the I2C interface of GPIO52/GPIO53. In the latter case, | ||||||
| @@ -200,7 +186,7 @@ void board_init(void) | |||||||
|    * of VBUS can be read via U31. |    * of VBUS can be read via U31. | ||||||
|    * - JP16 shall not be inserted. |    * - JP16 shall not be inserted. | ||||||
|    * |    * | ||||||
|    * For USB Host: |    * For USB1 Host: | ||||||
|    * - 15Kohm pull-down resistors are needed on the USB data signals. These are activated inside the USB OTG chip (U31), |    * - 15Kohm pull-down resistors are needed on the USB data signals. These are activated inside the USB OTG chip (U31), | ||||||
|    * and this has to be done via the I2C interface of GPIO52/GPIO53. |    * and this has to be done via the I2C interface of GPIO52/GPIO53. | ||||||
|    * - J20 is the connector to use when USB Host is used. In order to provide +5V to the external USB |    * - J20 is the connector to use when USB Host is used. In order to provide +5V to the external USB | ||||||
| @@ -211,20 +197,6 @@ void board_init(void) | |||||||
|    */ |    */ | ||||||
| #if CFG_TUSB_RHPORT1_MODE | #if CFG_TUSB_RHPORT1_MODE | ||||||
|   Chip_USB1_Init(); |   Chip_USB1_Init(); | ||||||
|  |  | ||||||
| //  // Reset controller |  | ||||||
| //  LPC_USB1->USBCMD_D |= 0x02; |  | ||||||
| //  while( LPC_USB1->USBCMD_D & 0x02 ) {} |  | ||||||
| // |  | ||||||
| //  // Set mode |  | ||||||
| //  #if CFG_TUSB_RHPORT1_MODE & OPT_MODE_HOST |  | ||||||
| //    LPC_USB1->USBMODE_H = USBMODE_HOST | (USBMODE_VBUS_HIGH << 5); |  | ||||||
| //  #else // TODO OTG |  | ||||||
| //    LPC_USB1->USBMODE_D = USBMODE_DEVICE; |  | ||||||
| //  #endif |  | ||||||
| // |  | ||||||
| //  // USB1 as fullspeed |  | ||||||
| //  LPC_USB1->PORTSC1_D |= (1<<24); |  | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
|   // USB0 Vbus Power: P2_3 on EA4357 channel B U20 GPIO26 active low (base board) |   // USB0 Vbus Power: P2_3 on EA4357 channel B U20 GPIO26 active low (base board) | ||||||
|   | |||||||
| @@ -169,20 +169,6 @@ void board_init(void) | |||||||
|    */ |    */ | ||||||
| #if CFG_TUSB_RHPORT0_MODE | #if CFG_TUSB_RHPORT0_MODE | ||||||
|   Chip_USB0_Init(); |   Chip_USB0_Init(); | ||||||
|  |  | ||||||
| //  // Reset controller |  | ||||||
| //  LPC_USB0->USBCMD_D |= 0x02; |  | ||||||
| //  while( LPC_USB0->USBCMD_D & 0x02 ) {} |  | ||||||
| // |  | ||||||
| //  // Set mode |  | ||||||
| //  #if CFG_TUSB_RHPORT0_MODE & OPT_MODE_HOST |  | ||||||
| //    LPC_USB0->USBMODE_H = USBMODE_HOST | (USBMODE_VBUS_HIGH << 5); |  | ||||||
| // |  | ||||||
| //    LPC_USB0->PORTSC1_D |= (1<<24); // FIXME force full speed for debugging |  | ||||||
| //  #else // TODO OTG |  | ||||||
| //    LPC_USB0->USBMODE_D = USBMODE_DEVICE; |  | ||||||
| //    LPC_USB0->OTGSC = (1<<3) | (1<<0) /*| (1<<16)| (1<<24)| (1<<25)| (1<<26)| (1<<27)| (1<<28)| (1<<29)| (1<<30)*/; |  | ||||||
| //  #endif |  | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
|   /* USB1 |   /* USB1 | ||||||
| @@ -206,20 +192,6 @@ void board_init(void) | |||||||
| #if CFG_TUSB_RHPORT1_MODE | #if CFG_TUSB_RHPORT1_MODE | ||||||
|   Chip_USB1_Init(); |   Chip_USB1_Init(); | ||||||
|  |  | ||||||
| //  // Reset controller |  | ||||||
| //  LPC_USB1->USBCMD_D |= 0x02; |  | ||||||
| //  while( LPC_USB1->USBCMD_D & 0x02 ) {} |  | ||||||
| // |  | ||||||
| //  // Set mode |  | ||||||
| //  #if CFG_TUSB_RHPORT1_MODE & OPT_MODE_HOST |  | ||||||
| //    LPC_USB1->USBMODE_H = USBMODE_HOST | (USBMODE_VBUS_HIGH << 5); |  | ||||||
| //  #else // TODO OTG |  | ||||||
| //    LPC_USB1->USBMODE_D = USBMODE_DEVICE; |  | ||||||
| //  #endif |  | ||||||
| // |  | ||||||
| //  // USB1 as fullspeed |  | ||||||
| //  LPC_USB1->PORTSC1_D |= (1<<24); |  | ||||||
|  |  | ||||||
| //	Chip_GPIO_SetPinDIROutput(LPC_GPIO_PORT, 5, 6);							/* GPIO5[6] = USB1_PWR_EN */ | //	Chip_GPIO_SetPinDIROutput(LPC_GPIO_PORT, 5, 6);							/* GPIO5[6] = USB1_PWR_EN */ | ||||||
| //	Chip_GPIO_SetPinState(LPC_GPIO_PORT, 5, 6, true);							/* GPIO5[6] output high */ | //	Chip_GPIO_SetPinState(LPC_GPIO_PORT, 5, 6, true);							/* GPIO5[6] output high */ | ||||||
| #endif | #endif | ||||||
|   | |||||||
| @@ -251,11 +251,7 @@ bool hidd_control_xfer_cb (uint8_t rhport, uint8_t stage, tusb_control_request_t | |||||||
|       } |       } | ||||||
|       else if (request->bRequest == TUSB_REQ_GET_DESCRIPTOR && desc_type == HID_DESC_TYPE_REPORT) |       else if (request->bRequest == TUSB_REQ_GET_DESCRIPTOR && desc_type == HID_DESC_TYPE_REPORT) | ||||||
|       { |       { | ||||||
|         uint8_t const * desc_report = tud_hid_descriptor_report_cb( |         uint8_t const * desc_report = tud_hid_descriptor_report_cb(hid_itf); | ||||||
|             #if CFG_TUD_HID > 1 |  | ||||||
|             hid_itf // TODO for backward compatible callback, remove later when appropriate |  | ||||||
|             #endif |  | ||||||
|         ); |  | ||||||
|         tud_control_xfer(rhport, request, (void*) desc_report, p_hid->report_desc_len); |         tud_control_xfer(rhport, request, (void*) desc_report, p_hid->report_desc_len); | ||||||
|       } |       } | ||||||
|       else |       else | ||||||
| @@ -275,12 +271,7 @@ bool hidd_control_xfer_cb (uint8_t rhport, uint8_t stage, tusb_control_request_t | |||||||
|           uint8_t const report_type = tu_u16_high(request->wValue); |           uint8_t const report_type = tu_u16_high(request->wValue); | ||||||
|           uint8_t const report_id   = tu_u16_low(request->wValue); |           uint8_t const report_id   = tu_u16_low(request->wValue); | ||||||
|  |  | ||||||
|           uint16_t xferlen  = tud_hid_get_report_cb( |           uint16_t xferlen = tud_hid_get_report_cb(hid_itf, report_id, (hid_report_type_t) report_type, p_hid->epin_buf, request->wLength); | ||||||
|               #if CFG_TUD_HID > 1 |  | ||||||
|               hid_itf, // TODO for backward compatible callback, remove later when appropriate |  | ||||||
|               #endif |  | ||||||
|               report_id, (hid_report_type_t) report_type, p_hid->epin_buf, request->wLength |  | ||||||
|           ); |  | ||||||
|           TU_ASSERT( xferlen > 0 ); |           TU_ASSERT( xferlen > 0 ); | ||||||
|  |  | ||||||
|           tud_control_xfer(rhport, request, p_hid->epin_buf, xferlen); |           tud_control_xfer(rhport, request, p_hid->epin_buf, xferlen); | ||||||
| @@ -298,12 +289,7 @@ bool hidd_control_xfer_cb (uint8_t rhport, uint8_t stage, tusb_control_request_t | |||||||
|           uint8_t const report_type = tu_u16_high(request->wValue); |           uint8_t const report_type = tu_u16_high(request->wValue); | ||||||
|           uint8_t const report_id   = tu_u16_low(request->wValue); |           uint8_t const report_id   = tu_u16_low(request->wValue); | ||||||
|  |  | ||||||
|           tud_hid_set_report_cb( |           tud_hid_set_report_cb(hid_itf, report_id, (hid_report_type_t) report_type, p_hid->epout_buf, request->wLength); | ||||||
|               #if CFG_TUD_HID > 1 |  | ||||||
|               hid_itf, // TODO for backward compatible callback, remove later when appropriate |  | ||||||
|               #endif |  | ||||||
|               report_id, (hid_report_type_t) report_type, p_hid->epout_buf, request->wLength |  | ||||||
|           ); |  | ||||||
|         } |         } | ||||||
|       break; |       break; | ||||||
|  |  | ||||||
| @@ -314,12 +300,7 @@ bool hidd_control_xfer_cb (uint8_t rhport, uint8_t stage, tusb_control_request_t | |||||||
|           if ( tud_hid_set_idle_cb ) |           if ( tud_hid_set_idle_cb ) | ||||||
|           { |           { | ||||||
|             // stall request if callback return false |             // stall request if callback return false | ||||||
|             TU_VERIFY( tud_hid_set_idle_cb( |             TU_VERIFY( tud_hid_set_idle_cb( hid_itf, p_hid->idle_rate) ); | ||||||
|                             #if CFG_TUD_HID > 1 |  | ||||||
|                             hid_itf, // TODO for backward compatible callback, remove later when appropriate |  | ||||||
|                             #endif |  | ||||||
|                             p_hid->idle_rate) |  | ||||||
|             ); |  | ||||||
|           } |           } | ||||||
|  |  | ||||||
|           tud_control_status(rhport, request); |           tud_control_status(rhport, request); | ||||||
| @@ -354,12 +335,7 @@ bool hidd_control_xfer_cb (uint8_t rhport, uint8_t stage, tusb_control_request_t | |||||||
|         { |         { | ||||||
|           if (tud_hid_boot_mode_cb) |           if (tud_hid_boot_mode_cb) | ||||||
|           { |           { | ||||||
|             tud_hid_boot_mode_cb( |             tud_hid_boot_mode_cb(hid_itf, p_hid->boot_mode); | ||||||
|                 #if CFG_TUD_HID > 1 |  | ||||||
|                 hid_itf, // TODO for backward compatible callback, remove later when appropriate |  | ||||||
|                 #endif |  | ||||||
|                 p_hid->boot_mode |  | ||||||
|             ); |  | ||||||
|           } |           } | ||||||
|         } |         } | ||||||
|       break; |       break; | ||||||
| @@ -400,12 +376,7 @@ bool hidd_xfer_cb(uint8_t rhport, uint8_t ep_addr, xfer_result_t result, uint32_ | |||||||
|   // Received report |   // Received report | ||||||
|   else if (ep_addr == p_hid->ep_out) |   else if (ep_addr == p_hid->ep_out) | ||||||
|   { |   { | ||||||
|     tud_hid_set_report_cb( |     tud_hid_set_report_cb(itf, 0, HID_REPORT_TYPE_INVALID, p_hid->epout_buf, xferred_bytes); | ||||||
|         #if CFG_TUD_HID > 1 |  | ||||||
|         itf, // TODO for backward compatible callback, remove later when appropriate |  | ||||||
|         #endif |  | ||||||
|         0, HID_REPORT_TYPE_INVALID, p_hid->epout_buf, xferred_bytes |  | ||||||
|     ); |  | ||||||
|     TU_ASSERT(usbd_edpt_xfer(rhport, p_hid->ep_out, p_hid->epout_buf, sizeof(p_hid->epout_buf))); |     TU_ASSERT(usbd_edpt_xfer(rhport, p_hid->ep_out, p_hid->epout_buf, sizeof(p_hid->epout_buf))); | ||||||
|   } |   } | ||||||
|  |  | ||||||
|   | |||||||
| @@ -88,8 +88,6 @@ static inline bool tud_hid_mouse_report(uint8_t report_id, uint8_t buttons, int8 | |||||||
| // Callbacks (Weak is optional) | // Callbacks (Weak is optional) | ||||||
| //--------------------------------------------------------------------+ | //--------------------------------------------------------------------+ | ||||||
|  |  | ||||||
| #if CFG_TUD_HID > 1 |  | ||||||
|  |  | ||||||
| // Invoked when received GET HID REPORT DESCRIPTOR request | // Invoked when received GET HID REPORT DESCRIPTOR request | ||||||
| // Application return pointer to descriptor, whose contents must exist long enough for transfer to complete | // Application return pointer to descriptor, whose contents must exist long enough for transfer to complete | ||||||
| uint8_t const * tud_hid_descriptor_report_cb(uint8_t itf); | uint8_t const * tud_hid_descriptor_report_cb(uint8_t itf); | ||||||
| @@ -111,18 +109,6 @@ TU_ATTR_WEAK void tud_hid_boot_mode_cb(uint8_t itf, uint8_t boot_mode); | |||||||
| // - Idle Rate > 0 : skip duplication, but send at least 1 report every idle rate (in unit of 4 ms). | // - Idle Rate > 0 : skip duplication, but send at least 1 report every idle rate (in unit of 4 ms). | ||||||
| TU_ATTR_WEAK bool tud_hid_set_idle_cb(uint8_t itf, uint8_t idle_rate); | TU_ATTR_WEAK bool tud_hid_set_idle_cb(uint8_t itf, uint8_t idle_rate); | ||||||
|  |  | ||||||
| #else |  | ||||||
|  |  | ||||||
| // TODO for backward compatible callback, remove later when appropriate |  | ||||||
| uint8_t const * tud_hid_descriptor_report_cb(void); |  | ||||||
| uint16_t tud_hid_get_report_cb(uint8_t report_id, hid_report_type_t report_type, uint8_t* buffer, uint16_t reqlen); |  | ||||||
| void tud_hid_set_report_cb(uint8_t report_id, hid_report_type_t report_type, uint8_t const* buffer, uint16_t bufsize); |  | ||||||
|  |  | ||||||
| TU_ATTR_WEAK void tud_hid_boot_mode_cb(uint8_t boot_mode); |  | ||||||
| TU_ATTR_WEAK bool tud_hid_set_idle_cb(uint8_t idle_rate); |  | ||||||
|  |  | ||||||
| #endif |  | ||||||
|  |  | ||||||
| // Invoked when sent REPORT successfully to host | // Invoked when sent REPORT successfully to host | ||||||
| // Application can use this to send the next report | // Application can use this to send the next report | ||||||
| // Note: For composite reports, report[0] is report ID | // Note: For composite reports, report[0] is report ID | ||||||
|   | |||||||
| @@ -329,6 +329,7 @@ bool dcd_edpt_xfer(uint8_t rhport, uint8_t ep_addr, uint8_t *buffer, uint16_t to | |||||||
|   { |   { | ||||||
|     if (total_bytes == 0) |     if (total_bytes == 0) | ||||||
|     { |     { | ||||||
|  |       usbdcd_driver.setup_processed = true; | ||||||
|       dcd_event_xfer_complete(0, ep_addr, 0, XFER_RESULT_SUCCESS, false); |       dcd_event_xfer_complete(0, ep_addr, 0, XFER_RESULT_SUCCESS, false); | ||||||
|     } |     } | ||||||
|     else if (ep_addr == 0x00 && total_bytes == usbdcd_driver.outlen) |     else if (ep_addr == 0x00 && total_bytes == usbdcd_driver.outlen) | ||||||
| @@ -350,12 +351,15 @@ bool dcd_edpt_xfer(uint8_t rhport, uint8_t ep_addr, uint8_t *buffer, uint16_t to | |||||||
|       } |       } | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     usbdcd_driver.setup_processed = true; |  | ||||||
|     struct usb_ctrlreq_s ctrl; |     struct usb_ctrlreq_s ctrl; | ||||||
|  |  | ||||||
|     if (osal_queue_receive(usbdcd_driver.setup_queue, &ctrl)) |     if (usbdcd_driver.setup_processed) | ||||||
|     { |     { | ||||||
|       dcd_event_setup_received(0, (uint8_t *)&ctrl, false); |       if (osal_queue_receive(usbdcd_driver.setup_queue, &ctrl)) | ||||||
|  |       { | ||||||
|  |         usbdcd_driver.setup_processed = false; | ||||||
|  |         dcd_event_setup_received(0, (uint8_t *)&ctrl, false); | ||||||
|  |       } | ||||||
|     } |     } | ||||||
|   } |   } | ||||||
|   else |   else | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user
	 Reinhard Panhuber
					Reinhard Panhuber