Changes in uspace/drv/usbhub/usbhub.c [09daa8b:e93e319] in mainline
- File:
-
- 1 edited
Legend:
- Unmodified
- Added
- Removed
-
uspace/drv/usbhub/usbhub.c
r09daa8b re93e319 53 53 #include "usb/classes/classes.h" 54 54 55 static ddf_dev_ops_t hub_device_ops = { 56 .interfaces[USB_DEV_IFACE] = &usb_iface_hub_impl 57 }; 58 59 /** Hub status-change endpoint description 60 * 61 * For more see usb hub specification in 11.15.1 of 62 */ 63 static usb_endpoint_description_t status_change_endpoint_description = { 64 .transfer_type = USB_TRANSFER_INTERRUPT, 65 .direction = USB_DIRECTION_IN, 66 .interface_class = USB_CLASS_HUB, 67 .interface_subclass = 0, 68 .interface_protocol = 0, 69 .flags = 0 70 }; 71 55 72 int usb_hub_control_loop(void * hub_info_param){ 56 73 usb_hub_info_t * hub_info = (usb_hub_info_t*)hub_info_param; … … 61 78 async_usleep(1000 * 1000 );/// \TODO proper number once 62 79 } 63 usb_log_error("something in ctrl loop went wrong, errno %d \n",errorCode);80 usb_log_error("something in ctrl loop went wrong, errno %d",errorCode); 64 81 65 82 return 0; … … 74 91 75 92 /** 76 * create usb_hub_info_t structure 77 * 78 * Does only basic copying of known information into new structure. 79 * @param usb_dev usb device structure 80 * @return basic usb_hub_info_t structure 81 */ 82 static usb_hub_info_t * usb_hub_info_create(usb_device_t * usb_dev) { 83 usb_hub_info_t * result = usb_new(usb_hub_info_t); 84 if(!result) return NULL; 85 result->usb_device = usb_dev; 86 result->status_change_pipe = usb_dev->pipes[0].pipe; 87 result->control_pipe = &usb_dev->ctrl_pipe; 93 * Initialize connnections to host controller, device, and device 94 * control endpoint 95 * @param hub 96 * @param device 97 * @return 98 */ 99 static int usb_hub_init_communication(usb_hub_info_t * hub){ 100 usb_log_debug("Initializing hub USB communication (hub->device->handle=%zu).\n", hub->device->handle); 101 int opResult; 102 opResult = usb_device_connection_initialize_from_device( 103 &hub->device_connection, 104 hub->device); 105 if(opResult != EOK){ 106 usb_log_error("could not initialize connection to hc, errno %d",opResult); 107 return opResult; 108 } 109 usb_log_debug("Initializing USB wire abstraction.\n"); 110 opResult = usb_hc_connection_initialize_from_device(&hub->connection, 111 hub->device); 112 if(opResult != EOK){ 113 usb_log_error("could not initialize connection to device, errno %d", 114 opResult); 115 return opResult; 116 } 117 usb_log_debug("Initializing default control pipe.\n"); 118 opResult = usb_endpoint_pipe_initialize_default_control(&hub->endpoints.control, 119 &hub->device_connection); 120 if(opResult != EOK){ 121 usb_log_error("could not initialize connection to device endpoint, errno %d", 122 opResult); 123 return opResult; 124 } 125 126 opResult = usb_endpoint_pipe_probe_default_control(&hub->endpoints.control); 127 if (opResult != EOK) { 128 usb_log_error("failed probing endpoint 0, %d", opResult); 129 return opResult; 130 } 131 132 return EOK; 133 } 134 135 /** 136 * When entering this function, hub->endpoints.control should be active. 137 * @param hub 138 * @return 139 */ 140 static int usb_hub_process_configuration_descriptors( 141 usb_hub_info_t * hub){ 142 if(hub==NULL) { 143 return EINVAL; 144 } 145 int opResult; 146 147 //device descriptor 148 usb_standard_device_descriptor_t std_descriptor; 149 opResult = usb_request_get_device_descriptor(&hub->endpoints.control, 150 &std_descriptor); 151 if(opResult!=EOK){ 152 usb_log_error("could not get device descriptor, %d",opResult); 153 return opResult; 154 } 155 usb_log_info("hub has %d configurations", 156 std_descriptor.configuration_count); 157 if(std_descriptor.configuration_count<1){ 158 usb_log_error("THERE ARE NO CONFIGURATIONS AVAILABLE"); 159 //shouldn`t I return? 160 } 161 162 /* Retrieve full configuration descriptor. */ 163 uint8_t *descriptors = NULL; 164 size_t descriptors_size = 0; 165 opResult = usb_request_get_full_configuration_descriptor_alloc( 166 &hub->endpoints.control, 0, 167 (void **) &descriptors, &descriptors_size); 168 if (opResult != EOK) { 169 usb_log_error("Could not get configuration descriptor: %s.\n", 170 str_error(opResult)); 171 return opResult; 172 } 173 usb_standard_configuration_descriptor_t *config_descriptor 174 = (usb_standard_configuration_descriptor_t *) descriptors; 175 176 /* Set configuration. */ 177 opResult = usb_request_set_configuration(&hub->endpoints.control, 178 config_descriptor->configuration_number); 179 180 if (opResult != EOK) { 181 usb_log_error("Failed to set hub configuration: %s.\n", 182 str_error(opResult)); 183 return opResult; 184 } 185 usb_log_debug("\tused configuration %d", 186 config_descriptor->configuration_number); 187 188 usb_endpoint_mapping_t endpoint_mapping[1] = { 189 { 190 .pipe = &hub->endpoints.status_change, 191 .description = &status_change_endpoint_description, 192 .interface_no = 193 usb_device_get_assigned_interface(hub->device) 194 } 195 }; 196 opResult = usb_endpoint_pipe_initialize_from_configuration( 197 endpoint_mapping, 1, 198 descriptors, descriptors_size, 199 &hub->device_connection); 200 if (opResult != EOK) { 201 usb_log_error("Failed to initialize status change pipe: %s", 202 str_error(opResult)); 203 return opResult; 204 } 205 if (!endpoint_mapping[0].present) { 206 usb_log_error("Not accepting device, " \ 207 "cannot understand what is happenning"); 208 return EREFUSED; 209 } 210 211 free(descriptors); 212 return EOK; 213 214 } 215 216 217 /** 218 * Create hub representation from device information. 219 * @param device 220 * @return pointer to created structure or NULL in case of error 221 */ 222 usb_hub_info_t * usb_create_hub_info(ddf_dev_t * device) { 223 usb_hub_info_t* result = usb_new(usb_hub_info_t); 224 result->device = device; 225 int opResult; 226 opResult = usb_hub_init_communication(result); 227 if(opResult != EOK){ 228 free(result); 229 return NULL; 230 } 231 232 //result->device = device; 233 result->port_count = -1; 234 result->device = device; 88 235 result->is_default_address_used = false; 89 return result; 90 } 91 92 /** 93 * Load hub-specific information into hub_info structure. 94 * 95 * Particularly read port count and initialize structure holding port 96 * information. 97 * This function is hub-specific and should be run only after the hub is 98 * configured using usb_hub_set_configuration function. 99 * @param hub_info pointer to structure with usb hub data 100 * @return error code 101 */ 102 static int usb_hub_get_hub_specific_info(usb_hub_info_t * hub_info){ 236 237 //result->usb_device = usb_new(usb_hcd_attached_device_info_t); 238 size_t received_size; 239 103 240 // get hub descriptor 104 usb_log_debug("creating serialized descripto r\n");241 usb_log_debug("creating serialized descripton"); 105 242 void * serialized_descriptor = malloc(USB_HUB_MAX_DESCRIPTOR_SIZE); 106 243 usb_hub_descriptor_t * descriptor; 107 108 /* this was one fix of some bug, should not be needed anymore 109 int opResult = usb_request_set_configuration(&result->endpoints.control, 1); 110 if(opResult!=EOK){ 111 usb_log_error("could not set default configuration, errno %d",opResult); 112 return opResult; 113 } 114 */ 115 size_t received_size; 116 int opResult = usb_request_get_descriptor(&hub_info->usb_device->ctrl_pipe, 244 usb_log_debug("starting control transaction"); 245 usb_endpoint_pipe_start_session(&result->endpoints.control); 246 opResult = usb_request_set_configuration(&result->endpoints.control, 1); 247 assert(opResult == EOK); 248 249 opResult = usb_request_get_descriptor(&result->endpoints.control, 117 250 USB_REQUEST_TYPE_CLASS, USB_REQUEST_RECIPIENT_DEVICE, 118 251 USB_DESCTYPE_HUB, 119 252 0, 0, serialized_descriptor, 120 253 USB_HUB_MAX_DESCRIPTOR_SIZE, &received_size); 121 122 if (opResult != EOK) { 123 usb_log_error("failed when receiving hub descriptor, badcode = %d\n", 254 usb_endpoint_pipe_end_session(&result->endpoints.control); 255 256 if (opResult != EOK) { 257 usb_log_error("failed when receiving hub descriptor, badcode = %d", 124 258 opResult); 125 259 free(serialized_descriptor); 126 return opResult; 127 } 128 usb_log_debug2("deserializing descriptor\n"); 260 free(result); 261 return NULL; 262 } 263 usb_log_debug2("deserializing descriptor"); 129 264 descriptor = usb_deserialize_hub_desriptor(serialized_descriptor); 130 265 if(descriptor==NULL){ 131 usb_log_warning("could not deserialize descriptor \n"); 132 return opResult; 133 } 134 usb_log_info("setting port count to %d\n",descriptor->ports_count); 135 hub_info->port_count = descriptor->ports_count; 136 hub_info->attached_devs = (usb_hc_attached_device_t*) 137 malloc((hub_info->port_count+1) * sizeof(usb_hc_attached_device_t)); 266 usb_log_warning("could not deserialize descriptor "); 267 free(result); 268 return NULL; 269 } 270 271 usb_log_info("setting port count to %d",descriptor->ports_count); 272 result->port_count = descriptor->ports_count; 273 result->attached_devs = (usb_hc_attached_device_t*) 274 malloc((result->port_count+1) * sizeof(usb_hc_attached_device_t)); 138 275 int i; 139 for(i=0;i< hub_info->port_count+1;++i){140 hub_info->attached_devs[i].handle=0;141 hub_info->attached_devs[i].address=0;142 } 143 usb_log_debug2("freeing data \n");276 for(i=0;i<result->port_count+1;++i){ 277 result->attached_devs[i].handle=0; 278 result->attached_devs[i].address=0; 279 } 280 usb_log_debug2("freeing data"); 144 281 free(serialized_descriptor); 145 282 free(descriptor->devices_removable); 146 283 free(descriptor); 147 return EOK; 148 } 149 /** 150 * Set configuration of hub 151 * 152 * Check whether there is at least one configuration and sets the first one. 153 * This function should be run prior to running any hub-specific action. 154 * @param hub_info 284 285 //finish 286 287 usb_log_info("hub info created"); 288 289 return result; 290 } 291 292 /** 293 * Create hub representation and add it into hub list 294 * @param dev 155 295 * @return 156 296 */ 157 static int usb_hub_set_configuration(usb_hub_info_t * hub_info){ 158 //device descriptor 159 usb_standard_device_descriptor_t std_descriptor; 160 int opResult = usb_request_get_device_descriptor( 161 &hub_info->usb_device->ctrl_pipe, 162 &std_descriptor); 163 if(opResult!=EOK){ 164 usb_log_error("could not get device descriptor, %d\n",opResult); 165 return opResult; 166 } 167 usb_log_info("hub has %d configurations\n", 168 std_descriptor.configuration_count); 169 if(std_descriptor.configuration_count<1){ 170 usb_log_error("THERE ARE NO CONFIGURATIONS AVAILABLE\n"); 171 //shouldn`t I return? 172 } 173 174 /* Retrieve full configuration descriptor. */ 175 uint8_t *descriptors = NULL; 176 size_t descriptors_size = 0; 177 opResult = usb_request_get_full_configuration_descriptor_alloc( 178 &hub_info->usb_device->ctrl_pipe, 0, 179 (void **) &descriptors, &descriptors_size); 180 if (opResult != EOK) { 181 usb_log_error("Could not get configuration descriptor: %s.\n", 182 str_error(opResult)); 183 return opResult; 184 } 185 usb_standard_configuration_descriptor_t *config_descriptor 186 = (usb_standard_configuration_descriptor_t *) descriptors; 187 188 /* Set configuration. */ 189 opResult = usb_request_set_configuration(&hub_info->usb_device->ctrl_pipe, 190 config_descriptor->configuration_number); 191 192 if (opResult != EOK) { 193 usb_log_error("Failed to set hub configuration: %s.\n", 194 str_error(opResult)); 195 return opResult; 196 } 197 usb_log_debug("\tused configuration %d\n", 198 config_descriptor->configuration_number); 199 free(descriptors); 200 return EOK; 201 } 202 203 /** 204 * Initialize hub device driver fibril 205 * 206 * Creates hub representation and fibril that periodically checks hub`s status. 207 * Hub representation is passed to the fibril. 208 * @param usb_dev generic usb device information 209 * @return error code 210 */ 211 int usb_hub_add_device(usb_device_t * usb_dev){ 212 if(!usb_dev) return EINVAL; 213 usb_hub_info_t * hub_info = usb_hub_info_create(usb_dev); 214 //create hc connection 215 usb_log_debug("Initializing USB wire abstraction.\n"); 216 int opResult = usb_hc_connection_initialize_from_device( 217 &hub_info->connection, 218 hub_info->usb_device->ddf_dev); 297 int usb_add_hub_device(ddf_dev_t *dev) { 298 usb_log_info("add_hub_device(handle=%d)", (int) dev->handle); 299 300 //dev->ops = &hub_device_ops; 301 (void) hub_device_ops; 302 303 usb_hub_info_t * hub_info = usb_create_hub_info(dev); 304 if(!hub_info){ 305 return EINTR; 306 } 307 308 int opResult; 309 310 //perform final configurations 311 usb_endpoint_pipe_start_session(&hub_info->endpoints.control); 312 // process descriptors 313 opResult = usb_hub_process_configuration_descriptors(hub_info); 219 314 if(opResult != EOK){ 220 usb_log_error("could not initialize connection to device, errno %d\n",315 usb_log_error("could not get configuration descriptors, %d", 221 316 opResult); 222 free(hub_info); 223 return opResult; 224 } 225 226 usb_endpoint_pipe_start_session(hub_info->control_pipe); 227 //set hub configuration 228 opResult = usb_hub_set_configuration(hub_info); 229 if(opResult!=EOK){ 230 usb_log_error("could not set hub configuration, errno %d\n",opResult); 231 free(hub_info); 232 return opResult; 233 } 234 //get port count and create attached_devs 235 opResult = usb_hub_get_hub_specific_info(hub_info); 236 if(opResult!=EOK){ 237 usb_log_error("could not set hub configuration, errno %d\n",opResult); 238 free(hub_info); 239 return opResult; 240 } 241 usb_endpoint_pipe_end_session(hub_info->control_pipe); 242 243 244 /// \TODO what is this? 317 return opResult; 318 } 319 //power ports 320 usb_device_request_setup_packet_t request; 321 int port; 322 for (port = 1; port < hub_info->port_count+1; ++port) { 323 usb_hub_set_power_port_request(&request, port); 324 opResult = usb_endpoint_pipe_control_write(&hub_info->endpoints.control, 325 &request,sizeof(usb_device_request_setup_packet_t), NULL, 0); 326 usb_log_info("powering port %d",port); 327 if (opResult != EOK) { 328 usb_log_warning("something went wrong when setting hub`s %dth port", port); 329 } 330 } 331 //ports powered, hub seems to be enabled 332 usb_endpoint_pipe_end_session(&hub_info->endpoints.control); 333 334 //add the hub to list 335 //is this needed now? 336 fibril_mutex_lock(&usb_hub_list_lock); 337 usb_lst_append(&usb_hub_list, hub_info); 338 fibril_mutex_unlock(&usb_hub_list_lock); 339 usb_log_debug("hub info added to list"); 340 245 341 usb_log_debug("adding to ddf"); 246 ddf_fun_t *hub_fun = ddf_fun_create(hub_info->usb_device->ddf_dev, 247 fun_exposed, "hub"); 342 ddf_fun_t *hub_fun = ddf_fun_create(dev, fun_exposed, "hub"); 248 343 assert(hub_fun != NULL); 249 344 hub_fun->ops = NULL; … … 254 349 assert(rc == EOK); 255 350 256 //create fibril for the hub control loop257 351 fid_t fid = fibril_create(usb_hub_control_loop, hub_info); 258 352 if (fid == 0) { … … 261 355 } 262 356 fibril_add_ready(fid); 357 263 358 usb_log_debug("hub fibril created"); 264 usb_log_debug("has %d ports ",hub_info->port_count); 359 //(void)hub_info; 360 //usb_hub_check_hub_changes(); 361 362 usb_log_info("hub dev added"); 363 //address is lost... 364 usb_log_debug("\taddress %d, has %d ports ", 365 //hub_info->endpoints.control., 366 hub_info->port_count); 367 265 368 return EOK; 369 //return ENOTSUP; 266 370 } 267 371 … … 284 388 int opResult = usb_hc_release_default_address(&hub->connection); 285 389 if(opResult!=EOK){ 286 usb_log_error("could not release default address, errno %d \n",opResult);390 usb_log_error("could not release default address, errno %d",opResult); 287 391 return opResult; 288 392 } … … 301 405 //if this hub already uses default address, it cannot request it once more 302 406 if(hub->is_default_address_used) return; 303 usb_log_info("some connection changed\n"); 304 assert(hub->control_pipe->hc_phone); 305 int opResult = usb_hub_clear_port_feature(hub->control_pipe, 407 int opResult = usb_hub_clear_port_feature(&hub->endpoints.control, 306 408 port, USB_HUB_FEATURE_C_PORT_CONNECTION); 307 409 if(opResult != EOK){ 308 usb_log_warning("could not clear port-change-connection flag\n"); 309 } 410 usb_log_warning("could not clear port-change-connection flag"); 411 } 412 310 413 usb_device_request_setup_packet_t request; 311 414 usb_log_info("some connection changed"); 415 assert(hub->endpoints.control.hc_phone); 312 416 //get default address 313 417 opResult = usb_hc_reserve_default_address(&hub->connection, speed); 314 418 315 419 if (opResult != EOK) { 316 usb_log_warning("cannot assign default address, it is probably used %d \n",420 usb_log_warning("cannot assign default address, it is probably used %d", 317 421 opResult); 318 422 return; … … 322 426 usb_hub_set_reset_port_request(&request, port); 323 427 opResult = usb_endpoint_pipe_control_write( 324 hub->control_pipe,428 &hub->endpoints.control, 325 429 &request,sizeof(usb_device_request_setup_packet_t), 326 430 NULL, 0 327 431 ); 328 432 if (opResult != EOK) { 329 usb_log_error("something went wrong when reseting a port %d \n",opResult);433 usb_log_error("something went wrong when reseting a port %d",opResult); 330 434 //usb_hub_release_default_address(hc); 331 435 usb_hub_release_default_address(hub); … … 341 445 */ 342 446 static void usb_hub_finalize_add_device( usb_hub_info_t * hub, 343 uint16_t port, usb_speed_t speed) {447 uint16_t port, bool isLowSpeed) { 344 448 345 449 int opResult; 346 usb_log_info("finalizing add device \n");347 opResult = usb_hub_clear_port_feature( hub->control_pipe,450 usb_log_info("finalizing add device"); 451 opResult = usb_hub_clear_port_feature(&hub->endpoints.control, 348 452 port, USB_HUB_FEATURE_C_PORT_RESET); 349 453 350 454 if (opResult != EOK) { 351 usb_log_error("failed to clear port reset feature \n");455 usb_log_error("failed to clear port reset feature"); 352 456 usb_hub_release_default_address(hub); 353 457 return; … … 364 468 &new_device_connection); 365 469 usb_endpoint_pipe_probe_default_control(&new_device_pipe); 470 /// \TODO get highspeed info 471 usb_speed_t speed = isLowSpeed?USB_SPEED_LOW:USB_SPEED_FULL; 472 366 473 367 474 /* Request address from host controller. */ … … 371 478 ); 372 479 if (new_device_address < 0) { 373 usb_log_error("failed to get free USB address \n");480 usb_log_error("failed to get free USB address"); 374 481 opResult = new_device_address; 375 482 usb_hub_release_default_address(hub); 376 483 return; 377 484 } 378 usb_log_info("setting new address %d \n",new_device_address);485 usb_log_info("setting new address %d",new_device_address); 379 486 //opResult = usb_drv_req_set_address(hc, USB_ADDRESS_DEFAULT, 380 487 // new_device_address); … … 383 490 usb_endpoint_pipe_end_session(&new_device_pipe); 384 491 if (opResult != EOK) { 385 usb_log_error("could not set address for new device %d \n",opResult);492 usb_log_error("could not set address for new device %d",opResult); 386 493 usb_hub_release_default_address(hub); 387 494 return; … … 398 505 //?? 399 506 opResult = usb_device_register_child_in_devman(new_device_address, 400 hub->connection.hc_handle, hub-> usb_device->ddf_dev, &child_handle,507 hub->connection.hc_handle, hub->device, &child_handle, 401 508 NULL, NULL, NULL); 402 509 403 510 if (opResult != EOK) { 404 usb_log_error("could not start driver for new device %d \n",opResult);511 usb_log_error("could not start driver for new device %d",opResult); 405 512 return; 406 513 } … … 413 520 &hub->attached_devs[port]); 414 521 if (opResult != EOK) { 415 usb_log_error("could not assign address of device in hcd %d \n",opResult);416 return; 417 } 418 usb_log_info("new device address %d, handle %zu \n",522 usb_log_error("could not assign address of device in hcd %d",opResult); 523 return; 524 } 525 usb_log_info("new device address %d, handle %zu", 419 526 new_device_address, child_handle); 420 527 … … 430 537 usb_hub_info_t * hub,uint16_t port) { 431 538 432 int opResult = usb_hub_clear_port_feature( hub->control_pipe,539 int opResult = usb_hub_clear_port_feature(&hub->endpoints.control, 433 540 port, USB_HUB_FEATURE_C_PORT_CONNECTION); 434 541 if(opResult != EOK){ 435 usb_log_warning("could not clear port-change-connection flag \n");542 usb_log_warning("could not clear port-change-connection flag"); 436 543 } 437 544 /** \TODO remove device from device manager - not yet implemented in … … 452 559 */ 453 560 }else{ 454 usb_log_warning("this is strange, disconnected device had no address \n");561 usb_log_warning("this is strange, disconnected device had no address"); 455 562 //device was disconnected before it`s port was reset - return default address 456 563 usb_hub_release_default_address(hub); … … 470 577 uint16_t port){ 471 578 int opResult; 472 opResult = usb_hub_clear_port_feature( hub->control_pipe,579 opResult = usb_hub_clear_port_feature(&hub->endpoints.control, 473 580 port, USB_HUB_FEATURE_PORT_POWER); 474 581 if(opResult!=EOK){ 475 usb_log_error("cannot power off port %d; %d \n",582 usb_log_error("cannot power off port %d; %d", 476 583 port, opResult); 477 584 } … … 486 593 static void usb_hub_process_interrupt(usb_hub_info_t * hub, 487 594 uint16_t port) { 488 usb_log_debug("interrupt at port %d \n", port);595 usb_log_debug("interrupt at port %d", port); 489 596 //determine type of change 490 usb_endpoint_pipe_t *pipe = hub->control_pipe;597 usb_endpoint_pipe_t *pipe = &hub->endpoints.control; 491 598 492 599 int opResult; … … 505 612 ); 506 613 if (opResult != EOK) { 507 usb_log_error("could not get port status \n");614 usb_log_error("could not get port status"); 508 615 return; 509 616 } 510 617 if (rcvd_size != sizeof (usb_port_status_t)) { 511 usb_log_error("received status has incorrect size \n");618 usb_log_error("received status has incorrect size"); 512 619 return; 513 620 } … … 515 622 if (usb_port_connect_change(&status)) { 516 623 if (usb_port_dev_connected(&status)) { 517 usb_log_info("some connection changed \n");624 usb_log_info("some connection changed"); 518 625 usb_hub_init_add_device(hub, port, usb_port_speed(&status)); 519 626 } else { … … 527 634 usb_hub_over_current(hub,port); 528 635 }else{ 529 usb_log_info("over current condition was auto-resolved on port %d \n",636 usb_log_info("over current condition was auto-resolved on port %d", 530 637 port); 531 638 } … … 535 642 usb_log_info("port reset complete"); 536 643 if (usb_port_enabled(&status)) { 537 usb_hub_finalize_add_device(hub, port, usb_port_ speed(&status));644 usb_hub_finalize_add_device(hub, port, usb_port_low_speed(&status)); 538 645 } else { 539 usb_log_warning("port reset, but port still not enabled \n");646 usb_log_warning("port reset, but port still not enabled"); 540 647 } 541 648 } … … 546 653 usb_port_set_dev_connected(&status, false); 547 654 if (status>>16) { 548 usb_log_info("there was some unsupported change on port %d: %X \n",655 usb_log_info("there was some unsupported change on port %d: %X", 549 656 port,status); 550 657 551 658 } 659 /// \TODO handle other changes - is there any? 552 660 } 553 661 … … 560 668 int usb_hub_check_hub_changes(usb_hub_info_t * hub_info){ 561 669 int opResult; 562 opResult = usb_endpoint_pipe_start_session( 563 hub_info->status_change_pipe); 670 opResult = usb_endpoint_pipe_start_session(&hub_info->endpoints.status_change); 564 671 if(opResult != EOK){ 565 usb_log_error("could not initialize communication for hub; %d \n",672 usb_log_error("could not initialize communication for hub; %d", 566 673 opResult); 567 674 return opResult; … … 579 686 */ 580 687 opResult = usb_endpoint_pipe_read( 581 hub_info->status_change_pipe,688 &hub_info->endpoints.status_change, 582 689 change_bitmap, byte_length, &actual_size 583 690 ); … … 585 692 if (opResult != EOK) { 586 693 free(change_bitmap); 587 usb_log_warning("something went wrong while getting status of hub \n");588 usb_endpoint_pipe_end_session( hub_info->status_change_pipe);694 usb_log_warning("something went wrong while getting status of hub"); 695 usb_endpoint_pipe_end_session(&hub_info->endpoints.status_change); 589 696 return opResult; 590 697 } 591 698 unsigned int port; 592 opResult = usb_endpoint_pipe_start_session( hub_info->control_pipe);699 opResult = usb_endpoint_pipe_start_session(&hub_info->endpoints.control); 593 700 if(opResult!=EOK){ 594 usb_log_error("could not start control pipe session %d \n", opResult);595 usb_endpoint_pipe_end_session( hub_info->status_change_pipe);701 usb_log_error("could not start control pipe session %d", opResult); 702 usb_endpoint_pipe_end_session(&hub_info->endpoints.status_change); 596 703 return opResult; 597 704 } 598 705 opResult = usb_hc_connection_open(&hub_info->connection); 599 706 if(opResult!=EOK){ 600 usb_log_error("could not start host controller session %d \n",707 usb_log_error("could not start host controller session %d", 601 708 opResult); 602 usb_endpoint_pipe_end_session( hub_info->control_pipe);603 usb_endpoint_pipe_end_session( hub_info->status_change_pipe);709 usb_endpoint_pipe_end_session(&hub_info->endpoints.control); 710 usb_endpoint_pipe_end_session(&hub_info->endpoints.status_change); 604 711 return opResult; 605 712 } … … 615 722 } 616 723 usb_hc_connection_close(&hub_info->connection); 617 usb_endpoint_pipe_end_session( hub_info->control_pipe);618 usb_endpoint_pipe_end_session( hub_info->status_change_pipe);724 usb_endpoint_pipe_end_session(&hub_info->endpoints.control); 725 usb_endpoint_pipe_end_session(&hub_info->endpoints.status_change); 619 726 free(change_bitmap); 620 727 return EOK;
Note:
See TracChangeset
for help on using the changeset viewer.