Changes in / [b65ca41d:1d7a74e] in mainline
- Location:
- uspace/drv/usbhub
- Files:
-
- 3 edited
Legend:
- Unmodified
- Added
- Removed
-
uspace/drv/usbhub/main.c
rb65ca41d r1d7a74e 52 52 while(true){ 53 53 usb_hub_check_hub_changes(); 54 async_usleep(1000 * 1000 );/// \TODO proper number once54 async_usleep(1000 * 1000); 55 55 } 56 56 return 0; -
uspace/drv/usbhub/usbhub.c
rb65ca41d r1d7a74e 46 46 #include "usbhub_private.h" 47 47 #include "port_status.h" 48 #include "usb/usb.h"49 48 50 49 static usb_iface_t hub_usb_iface = { … … 86 85 87 86 // get hub descriptor 87 usb_target_t target; 88 target.address = addr; 89 target.endpoint = 0; 90 usb_device_request_setup_packet_t request; 91 //printf("[usb_hub] creating descriptor request\n"); 92 usb_hub_set_descriptor_request(&request); 88 93 89 94 //printf("[usb_hub] creating serialized descriptor\n"); … … 93 98 int opResult; 94 99 //printf("[usb_hub] starting control transaction\n"); 95 96 opResult = usb_drv_req_get_descriptor(hc, addr, 97 USB_REQUEST_TYPE_CLASS, 98 USB_DESCTYPE_HUB, 0, 0, serialized_descriptor, 100 opResult = usb_drv_sync_control_read( 101 hc, target, &request, serialized_descriptor, 99 102 USB_HUB_MAX_DESCRIPTOR_SIZE, &received_size); 100 101 103 if (opResult != EOK) { 102 104 dprintf(1,"[usb_hub] failed when receiving hub descriptor, badcode = %d",opResult); … … 153 155 int port; 154 156 int opResult; 157 usb_device_request_setup_packet_t request; 155 158 usb_target_t target; 156 159 target.address = hub_info->usb_device->address; … … 170 173 if(std_descriptor.configuration_count<1){ 171 174 dprintf(1,"[usb_hub] THERE ARE NO CONFIGURATIONS AVAILABLE"); 172 //shouldn`t I return?173 175 } 174 176 /// \TODO check other configurations … … 182 184 } 183 185 //set configuration 184 opResult = usb_drv_req_set_configuration(hc, target.address, 185 config_descriptor.configuration_number); 186 186 request.request_type = 0; 187 request.request = USB_DEVREQ_SET_CONFIGURATION; 188 request.index=0; 189 request.length=0; 190 request.value_high=0; 191 request.value_low = config_descriptor.configuration_number; 192 opResult = usb_drv_sync_control_write(hc, target, &request, NULL, 0); 187 193 if (opResult != EOK) { 188 194 dprintf(1,"[usb_hub]something went wrong when setting hub`s configuration, %d", opResult); 189 195 } 190 196 191 usb_device_request_setup_packet_t request;192 197 for (port = 1; port < hub_info->port_count+1; ++port) { 193 198 usb_hub_set_power_port_request(&request, port); … … 224 229 225 230 231 226 232 //********************************************* 227 233 // … … 231 237 232 238 /** 233 * Convenience function for releasing default address and writing debug info234 * (these few lines are used too often to be written again and again) .239 * convenience function for releasing default address and writing debug info 240 * (these few lines are used too often to be written again and again) 235 241 * @param hc 236 242 * @return … … 247 253 248 254 /** 249 * Reset the port with new device and reserve the default address.255 * reset the port with new device and reserve the default address 250 256 * @param hc 251 257 * @param port … … 276 282 277 283 /** 278 * Finalize adding new device after port reset284 * finalize adding new device after port reset 279 285 * @param hc 280 286 * @param port … … 339 345 340 346 /** 341 * Unregister device address in hc347 * unregister device address in hc 342 348 * @param hc 343 349 * @param port … … 349 355 int opResult; 350 356 351 /** \TODO remove device from device manager - not yet implemented in 352 * devide manager 353 */ 357 /// \TODO remove device 354 358 355 359 hub->attached_devs[port].devman_handle=0; … … 372 376 373 377 /** 374 * Process interrupts on given hub port378 * process interrupts on given hub port 375 379 * @param hc 376 380 * @param port … … 430 434 usb_port_set_reset_completed(&status, false); 431 435 usb_port_set_dev_connected(&status, false); 432 if (status>>16) { 433 dprintf(1,"[usb_hub]there was some unsupported change on port %d: %X",port,status); 434 436 if (status) { 437 dprintf(1,"[usb_hub]there was some unsupported change on port %d",port); 435 438 } 436 439 /// \TODO handle other changes … … 439 442 } 440 443 441 /** 442 * Check changes on all known hubs. 444 /* Check changes on all known hubs. 443 445 */ 444 446 void usb_hub_check_hub_changes(void) { -
uspace/drv/usbhub/usbhub_private.h
rb65ca41d r1d7a74e 31 31 */ 32 32 /** @file 33 * @brief Hub driver private definitions33 * @brief Hub driver. 34 34 */ 35 35 … … 68 68 69 69 /** 70 * Create hub structure instance70 * create hub structure instance 71 71 * 72 72 * Set the address and port count information most importantly. … … 78 78 usb_hub_info_t * usb_create_hub_info(device_t * device, int hc); 79 79 80 /** List of hubs maanged by this driver */80 /** list of hubs maanged by this driver */ 81 81 extern usb_general_list_t usb_hub_list; 82 82 83 /** Lock for hub list*/83 /** lock for hub list*/ 84 84 extern futex_t usb_hub_list_lock; 85 85 86 86 87 87 /** 88 * Perform complete control read transaction88 * perform complete control read transaction 89 89 * 90 * Manages all three steps of transaction: setup, read and finalize90 * manages all three steps of transaction: setup, read and finalize 91 91 * @param phone 92 92 * @param target 93 * @param request Request packet94 * @param rcvd_buffer Received data93 * @param request request for data 94 * @param rcvd_buffer received data 95 95 * @param rcvd_size 96 * @param actual_size Actual size of received data96 * @param actual_size actual size of received data 97 97 * @return error code 98 98 */ … … 104 104 105 105 /** 106 * Perform complete control write transaction106 * perform complete control write transaction 107 107 * 108 * Manages all three steps of transaction: setup, write and finalize108 * manages all three steps of transaction: setup, write and finalize 109 109 * @param phone 110 110 * @param target 111 * @param request Request packet to send data111 * @param request request to send data 112 112 * @param sent_buffer 113 113 * @param sent_size … … 121 121 122 122 /** 123 * Set the device request to be a get hub descriptor request.123 * set the device request to be a get hub descriptor request. 124 124 * @warning the size is allways set to USB_HUB_MAX_DESCRIPTOR_SIZE 125 125 * @param request … … 137 137 } 138 138 139 /**140 * Clear feature on hub port.141 *142 * @param hc Host controller telephone143 * @param address Hub address144 * @param port_index Port145 * @param feature Feature selector146 * @return Operation result147 */148 139 static inline int usb_hub_clear_port_feature(int hc, usb_address_t address, 149 140 int port_index,
Note:
See TracChangeset
for help on using the changeset viewer.