handle unplug the hub itself
This commit is contained in:
		| @@ -283,23 +283,15 @@ void usbh_device_plugged_isr(uint8_t hostid, uint8_t hub_addr, uint8_t hub_port) | ||||
| // return true if found and unmounted device, false if cannot find | ||||
| bool usbh_device_unplugged(uint8_t hostid, uint8_t hub_addr, uint8_t hub_port) | ||||
| { | ||||
|   //------------- find the device address that is unplugged -------------// | ||||
|   uint8_t dev_addr = 0; | ||||
|   while ( dev_addr <= TUSB_CFG_HOST_DEVICE_MAX && | ||||
|           !(usbh_devices[dev_addr].core_id  == hostid   && | ||||
|             usbh_devices[dev_addr].hub_addr == hub_addr && | ||||
|             usbh_devices[dev_addr].hub_port == hub_port && | ||||
|             usbh_devices[dev_addr].state    != TUSB_DEVICE_STATE_UNPLUG ) ) | ||||
|   //------------- find the all devices (star-network) under port that is unplugged -------------// | ||||
|   for (uint8_t dev_addr = 0; dev_addr <= TUSB_CFG_HOST_DEVICE_MAX; dev_addr ++) | ||||
|   { | ||||
|     dev_addr++; | ||||
|   } | ||||
|  | ||||
|   if (dev_addr > TUSB_CFG_HOST_DEVICE_MAX) // unplug unmounted device | ||||
|     if (usbh_devices[dev_addr].core_id  == hostid   && | ||||
|         (hub_addr == 0 || usbh_devices[dev_addr].hub_addr == hub_addr) && // hub_addr == 0 & hub_port == 0 means roothub | ||||
|         (hub_port == 0 || usbh_devices[dev_addr].hub_port == hub_port) && | ||||
|         usbh_devices[dev_addr].state    != TUSB_DEVICE_STATE_UNPLUG) | ||||
|     { | ||||
|     return false; | ||||
|   } | ||||
|  | ||||
|   // if device unplugged is not a hub TODO handle hub unplugged | ||||
|       // TODO Hub multiple level | ||||
|       for (uint8_t class_index = 1; class_index < TUSB_CLASS_MAPPED_INDEX_END; class_index++) | ||||
|       { | ||||
|         if ((usbh_devices[dev_addr].flag_supported_class & BIT_(class_index)) && | ||||
| @@ -314,6 +306,8 @@ bool usbh_device_unplugged(uint8_t hostid, uint8_t hub_addr, uint8_t hub_port) | ||||
|       // HCD must set this device's state to TUSB_DEVICE_STATE_UNPLUG when done | ||||
|       usbh_devices[dev_addr].state = TUSB_DEVICE_STATE_REMOVING; | ||||
|       usbh_devices[dev_addr].flag_supported_class = 0; | ||||
|     } | ||||
|   } | ||||
|  | ||||
|   return true; | ||||
| } | ||||
| @@ -419,16 +413,17 @@ tusb_error_t enumeration_body_subtask(void) | ||||
|  | ||||
|   //------------- Reset device again before Set Address -------------// | ||||
|   if (usbh_devices[0].hub_addr == 0) | ||||
|   { // mount direct to root hub | ||||
|   { // connected directly to roothub | ||||
|     hcd_port_reset( usbh_devices[0].core_id ); // reset port after 8 byte descriptor | ||||
| //  osal_task_delay(50); // TODO reset is recommended to last 50 ms (NXP EHCI passes this) | ||||
|   }else | ||||
|   { | ||||
|   { // connected via a hub | ||||
|     OSAL_SUBTASK_INVOKED_AND_WAIT ( hub_port_reset_subtask(usbh_devices[0].hub_addr, usbh_devices[0].hub_port), error ); | ||||
|     SUBTASK_ASSERT_STATUS( error ); | ||||
|  | ||||
|     // Acknowledge Port Reset Change | ||||
|     if ( TUSB_ERROR_NONE == error ) | ||||
|     { // Acknowledge Port Reset Change if Reset Successful | ||||
|       OSAL_SUBTASK_INVOKED_AND_WAIT( hub_port_clear_feature_subtask(usbh_devices[0].hub_addr, usbh_devices[0].hub_port, HUB_FEATURE_PORT_RESET_CHANGE), error ); | ||||
|     } | ||||
|  | ||||
|     (void) hub_status_pipe_queue( usbh_devices[0].hub_addr ); // done with hub, waiting for next data on status pipe | ||||
|   } | ||||
|   | ||||
| @@ -76,7 +76,7 @@ typedef struct ATTR_ALIGNED(4){ | ||||
|   uint8_t reserve; | ||||
| } usbh_enumerate_t; | ||||
|  | ||||
| typedef struct { // TODO internal structure, re-order members | ||||
| typedef struct { | ||||
|   //------------- port -------------// | ||||
|   uint8_t core_id; | ||||
|   uint8_t hub_addr; | ||||
|   | ||||
		Reference in New Issue
	
	Block a user
	 hathach
					hathach