use separate buffer for ctrl transfer.
This commit is contained in:
		| @@ -52,7 +52,7 @@ typedef struct | ||||
|  | ||||
|   CFG_TUSB_MEM_ALIGN uint8_t epin_buf[CFG_TUD_HID_EP_BUFSIZE]; | ||||
|   CFG_TUSB_MEM_ALIGN uint8_t epout_buf[CFG_TUD_HID_EP_BUFSIZE]; | ||||
|   CFG_TUSB_MEM_ALIGN uint8_t set_report_buf[CFG_TUD_HID_EP_BUFSIZE]; | ||||
|   CFG_TUSB_MEM_ALIGN uint8_t ctrl_buf[CFG_TUD_HID_EP_BUFSIZE]; | ||||
|  | ||||
|   // TODO save hid descriptor since host can specifically request this after enumeration | ||||
|   // Note: HID descriptor may be not available from application after enumeration | ||||
| @@ -296,7 +296,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_id   = tu_u16_low(request->wValue); | ||||
|  | ||||
|           uint8_t* report_buf = p_hid->epin_buf; | ||||
|           uint8_t* report_buf = p_hid->ctrl_buf; | ||||
|           uint16_t req_len = tu_min16(request->wLength, CFG_TUD_HID_EP_BUFSIZE); | ||||
|  | ||||
|           uint16_t xferlen = 0; | ||||
| @@ -313,22 +313,22 @@ bool hidd_control_xfer_cb (uint8_t rhport, uint8_t stage, tusb_control_request_t | ||||
|           xferlen += tud_hid_get_report_cb(hid_itf, report_id, (hid_report_type_t) report_type, report_buf, req_len); | ||||
|           TU_ASSERT( xferlen > 0 ); | ||||
|  | ||||
|           tud_control_xfer(rhport, request, p_hid->epin_buf, xferlen); | ||||
|           tud_control_xfer(rhport, request, p_hid->ctrl_buf, xferlen); | ||||
|         } | ||||
|       break; | ||||
|  | ||||
|       case  HID_REQ_CONTROL_SET_REPORT: | ||||
|         if ( stage == CONTROL_STAGE_SETUP ) | ||||
|         { | ||||
|           TU_VERIFY(request->wLength <= sizeof(p_hid->set_report_buf)); | ||||
|           tud_control_xfer(rhport, request, p_hid->set_report_buf, request->wLength); | ||||
|           TU_VERIFY(request->wLength <= sizeof(p_hid->ctrl_buf)); | ||||
|           tud_control_xfer(rhport, request, p_hid->ctrl_buf, request->wLength); | ||||
|         } | ||||
|         else if ( stage == CONTROL_STAGE_ACK ) | ||||
|         { | ||||
|           uint8_t const report_type = tu_u16_high(request->wValue); | ||||
|           uint8_t const report_id   = tu_u16_low(request->wValue); | ||||
|  | ||||
|           uint8_t const* report_buf = p_hid->set_report_buf; | ||||
|           uint8_t const* report_buf = p_hid->ctrl_buf; | ||||
|           uint16_t report_len = tu_min16(request->wLength, CFG_TUD_HID_EP_BUFSIZE); | ||||
|  | ||||
|           // If host request a specific Report ID, extract report ID in buffer before invoking callback | ||||
|   | ||||
		Reference in New Issue
	
	Block a user
	 HiFiPhile
					HiFiPhile