nxp tdi: implement dcd edpt close all
This commit is contained in:
		| @@ -57,11 +57,15 @@ | |||||||
| // ENDPTCTRL | // ENDPTCTRL | ||||||
| enum { | enum { | ||||||
|   ENDPTCTRL_STALL          = TU_BIT(0), |   ENDPTCTRL_STALL          = TU_BIT(0), | ||||||
|   ENDPTCTRL_TOGGLE_INHIBIT = TU_BIT(5), ///< used for test only |   ENDPTCTRL_TOGGLE_INHIBIT = TU_BIT(5), // used for test only | ||||||
|   ENDPTCTRL_TOGGLE_RESET   = TU_BIT(6), |   ENDPTCTRL_TOGGLE_RESET   = TU_BIT(6), | ||||||
|   ENDPTCTRL_ENABLE         = TU_BIT(7) |   ENDPTCTRL_ENABLE         = TU_BIT(7) | ||||||
| }; | }; | ||||||
|  |  | ||||||
|  | enum { | ||||||
|  |   ENDPTCTRL_TYPE_POS  = 2, // Endpoint type is 2-bit field | ||||||
|  | }; | ||||||
|  |  | ||||||
| // USBSTS, USBINTR | // USBSTS, USBINTR | ||||||
| enum { | enum { | ||||||
|   INTR_USB         = TU_BIT(0), |   INTR_USB         = TU_BIT(0), | ||||||
| @@ -193,9 +197,9 @@ static void bus_reset(uint8_t rhport) | |||||||
|   // endpoint type of the unused direction must be changed from the control type to any other |   // endpoint type of the unused direction must be changed from the control type to any other | ||||||
|   // type (e.g. bulk). Leaving an un-configured endpoint control will cause undefined behavior |   // type (e.g. bulk). Leaving an un-configured endpoint control will cause undefined behavior | ||||||
|   // for the data PID tracking on the active endpoint. |   // for the data PID tracking on the active endpoint. | ||||||
|   for( int i=1; i < _dcd_controller[rhport].ep_count; i++) |   for( uint8_t i=1; i < _dcd_controller[rhport].ep_count; i++) | ||||||
|   { |   { | ||||||
|     dcd_reg->ENDPTCTRL[i] = (TUSB_XFER_BULK << 2) | (TUSB_XFER_BULK << 18); |     dcd_reg->ENDPTCTRL[i] = (TUSB_XFER_BULK << ENDPTCTRL_TYPE_POS) | (TUSB_XFER_BULK << (16+ENDPTCTRL_TYPE_POS)); | ||||||
|   } |   } | ||||||
|  |  | ||||||
|   //------------- Clear All Registers -------------// |   //------------- Clear All Registers -------------// | ||||||
| @@ -364,8 +368,17 @@ bool dcd_edpt_open(uint8_t rhport, tusb_desc_endpoint_t const * p_endpoint_desc) | |||||||
|  |  | ||||||
| void dcd_edpt_close_all (uint8_t rhport) | void dcd_edpt_close_all (uint8_t rhport) | ||||||
| { | { | ||||||
|   (void) rhport; |   dcd_registers_t* dcd_reg = _dcd_controller[rhport].regs; | ||||||
|   // TODO implement dcd_edpt_close_all() |  | ||||||
|  |   // Disable all non-control endpoints | ||||||
|  |   for( uint8_t epnum=1; epnum < _dcd_controller[rhport].ep_count; epnum++) | ||||||
|  |   { | ||||||
|  |     _dcd_data.qhd[epnum][TUSB_DIR_OUT].qtd_overlay.halted = 1; | ||||||
|  |     _dcd_data.qhd[epnum][TUSB_DIR_IN ].qtd_overlay.halted = 1; | ||||||
|  |  | ||||||
|  |     dcd_reg->ENDPTFLUSH = TU_BIT(epnum) |  TU_BIT(epnum+16); | ||||||
|  |     dcd_reg->ENDPTCTRL[epnum] = (TUSB_XFER_BULK << ENDPTCTRL_TYPE_POS) | (TUSB_XFER_BULK << (16+ENDPTCTRL_TYPE_POS)); | ||||||
|  |   } | ||||||
| } | } | ||||||
|  |  | ||||||
| bool dcd_edpt_xfer(uint8_t rhport, uint8_t ep_addr, uint8_t * buffer, uint16_t total_bytes) | bool dcd_edpt_xfer(uint8_t rhport, uint8_t ep_addr, uint8_t * buffer, uint16_t total_bytes) | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user
	 hathach
					hathach