Changes in uspace/drv/usbhub/usbhub.c [e93e319:09daa8b] in mainline
- File:
-
- 1 edited
Legend:
- Unmodified
- Added
- Removed
-
uspace/drv/usbhub/usbhub.c
re93e319 r09daa8b 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_impl57 };58 59 /** Hub status-change endpoint description60 *61 * For more see usb hub specification in 11.15.1 of62 */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 = 070 };71 72 55 int usb_hub_control_loop(void * hub_info_param){ 73 56 usb_hub_info_t * hub_info = (usb_hub_info_t*)hub_info_param; … … 78 61 async_usleep(1000 * 1000 );/// \TODO proper number once 79 62 } 80 usb_log_error("something in ctrl loop went wrong, errno %d ",errorCode);63 usb_log_error("something in ctrl loop went wrong, errno %d\n",errorCode); 81 64 82 65 return 0; … … 91 74 92 75 /** 93 * Initialize connnections to host controller, device, and device 94 * control endpoint 95 * @param hub 96 * @param device 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; 88 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){ 103 // get hub descriptor 104 usb_log_debug("creating serialized descriptor\n"); 105 void * serialized_descriptor = malloc(USB_HUB_MAX_DESCRIPTOR_SIZE); 106 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, 117 USB_REQUEST_TYPE_CLASS, USB_REQUEST_RECIPIENT_DEVICE, 118 USB_DESCTYPE_HUB, 119 0, 0, serialized_descriptor, 120 USB_HUB_MAX_DESCRIPTOR_SIZE, &received_size); 121 122 if (opResult != EOK) { 123 usb_log_error("failed when receiving hub descriptor, badcode = %d\n", 124 opResult); 125 free(serialized_descriptor); 126 return opResult; 127 } 128 usb_log_debug2("deserializing descriptor\n"); 129 descriptor = usb_deserialize_hub_desriptor(serialized_descriptor); 130 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)); 138 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"); 144 free(serialized_descriptor); 145 free(descriptor->devices_removable); 146 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 97 155 * @return 98 156 */ 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 157 static int usb_hub_set_configuration(usb_hub_info_t * hub_info){ 147 158 //device descriptor 148 159 usb_standard_device_descriptor_t std_descriptor; 149 opResult = usb_request_get_device_descriptor(&hub->endpoints.control, 160 int opResult = usb_request_get_device_descriptor( 161 &hub_info->usb_device->ctrl_pipe, 150 162 &std_descriptor); 151 163 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 ",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", 156 168 std_descriptor.configuration_count); 157 169 if(std_descriptor.configuration_count<1){ 158 usb_log_error("THERE ARE NO CONFIGURATIONS AVAILABLE ");170 usb_log_error("THERE ARE NO CONFIGURATIONS AVAILABLE\n"); 159 171 //shouldn`t I return? 160 172 } … … 164 176 size_t descriptors_size = 0; 165 177 opResult = usb_request_get_full_configuration_descriptor_alloc( 166 &hub ->endpoints.control, 0,178 &hub_info->usb_device->ctrl_pipe, 0, 167 179 (void **) &descriptors, &descriptors_size); 168 180 if (opResult != EOK) { … … 175 187 176 188 /* Set configuration. */ 177 opResult = usb_request_set_configuration(&hub ->endpoints.control,189 opResult = usb_request_set_configuration(&hub_info->usb_device->ctrl_pipe, 178 190 config_descriptor->configuration_number); 179 191 … … 183 195 return opResult; 184 196 } 185 usb_log_debug("\tused configuration %d ",197 usb_log_debug("\tused configuration %d\n", 186 198 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 199 free(descriptors); 212 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); 219 if(opResult != EOK){ 220 usb_log_error("could not initialize connection to device, errno %d\n", 221 opResult); 222 free(hub_info); 223 return opResult; 224 } 213 225 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; 235 result->is_default_address_used = false; 236 237 //result->usb_device = usb_new(usb_hcd_attached_device_info_t); 238 size_t received_size; 239 240 // get hub descriptor 241 usb_log_debug("creating serialized descripton"); 242 void * serialized_descriptor = malloc(USB_HUB_MAX_DESCRIPTOR_SIZE); 243 usb_hub_descriptor_t * descriptor; 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, 250 USB_REQUEST_TYPE_CLASS, USB_REQUEST_RECIPIENT_DEVICE, 251 USB_DESCTYPE_HUB, 252 0, 0, serialized_descriptor, 253 USB_HUB_MAX_DESCRIPTOR_SIZE, &received_size); 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", 258 opResult); 259 free(serialized_descriptor); 260 free(result); 261 return NULL; 262 } 263 usb_log_debug2("deserializing descriptor"); 264 descriptor = usb_deserialize_hub_desriptor(serialized_descriptor); 265 if(descriptor==NULL){ 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)); 275 int i; 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"); 281 free(serialized_descriptor); 282 free(descriptor->devices_removable); 283 free(descriptor); 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 295 * @return 296 */ 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); 314 if(opResult != EOK){ 315 usb_log_error("could not get configuration descriptors, %d", 316 opResult); 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 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? 341 245 usb_log_debug("adding to ddf"); 342 ddf_fun_t *hub_fun = ddf_fun_create(dev, fun_exposed, "hub"); 246 ddf_fun_t *hub_fun = ddf_fun_create(hub_info->usb_device->ddf_dev, 247 fun_exposed, "hub"); 343 248 assert(hub_fun != NULL); 344 249 hub_fun->ops = NULL; … … 349 254 assert(rc == EOK); 350 255 256 //create fibril for the hub control loop 351 257 fid_t fid = fibril_create(usb_hub_control_loop, hub_info); 352 258 if (fid == 0) { … … 355 261 } 356 262 fibril_add_ready(fid); 357 358 263 usb_log_debug("hub fibril created"); 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 264 usb_log_debug("has %d ports ",hub_info->port_count); 368 265 return EOK; 369 //return ENOTSUP;370 266 } 371 267 … … 388 284 int opResult = usb_hc_release_default_address(&hub->connection); 389 285 if(opResult!=EOK){ 390 usb_log_error("could not release default address, errno %d ",opResult);286 usb_log_error("could not release default address, errno %d\n",opResult); 391 287 return opResult; 392 288 } … … 405 301 //if this hub already uses default address, it cannot request it once more 406 302 if(hub->is_default_address_used) return; 407 int opResult = usb_hub_clear_port_feature(&hub->endpoints.control, 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, 408 306 port, USB_HUB_FEATURE_C_PORT_CONNECTION); 409 307 if(opResult != EOK){ 410 usb_log_warning("could not clear port-change-connection flag"); 411 } 412 308 usb_log_warning("could not clear port-change-connection flag\n"); 309 } 413 310 usb_device_request_setup_packet_t request; 414 usb_log_info("some connection changed"); 415 assert(hub->endpoints.control.hc_phone); 311 416 312 //get default address 417 313 opResult = usb_hc_reserve_default_address(&hub->connection, speed); 418 314 419 315 if (opResult != EOK) { 420 usb_log_warning("cannot assign default address, it is probably used %d ",316 usb_log_warning("cannot assign default address, it is probably used %d\n", 421 317 opResult); 422 318 return; … … 426 322 usb_hub_set_reset_port_request(&request, port); 427 323 opResult = usb_endpoint_pipe_control_write( 428 &hub->endpoints.control,324 hub->control_pipe, 429 325 &request,sizeof(usb_device_request_setup_packet_t), 430 326 NULL, 0 431 327 ); 432 328 if (opResult != EOK) { 433 usb_log_error("something went wrong when reseting a port %d ",opResult);329 usb_log_error("something went wrong when reseting a port %d\n",opResult); 434 330 //usb_hub_release_default_address(hc); 435 331 usb_hub_release_default_address(hub); … … 445 341 */ 446 342 static void usb_hub_finalize_add_device( usb_hub_info_t * hub, 447 uint16_t port, bool isLowSpeed) {343 uint16_t port, usb_speed_t speed) { 448 344 449 345 int opResult; 450 usb_log_info("finalizing add device ");451 opResult = usb_hub_clear_port_feature( &hub->endpoints.control,346 usb_log_info("finalizing add device\n"); 347 opResult = usb_hub_clear_port_feature(hub->control_pipe, 452 348 port, USB_HUB_FEATURE_C_PORT_RESET); 453 349 454 350 if (opResult != EOK) { 455 usb_log_error("failed to clear port reset feature ");351 usb_log_error("failed to clear port reset feature\n"); 456 352 usb_hub_release_default_address(hub); 457 353 return; … … 468 364 &new_device_connection); 469 365 usb_endpoint_pipe_probe_default_control(&new_device_pipe); 470 /// \TODO get highspeed info471 usb_speed_t speed = isLowSpeed?USB_SPEED_LOW:USB_SPEED_FULL;472 473 366 474 367 /* Request address from host controller. */ … … 478 371 ); 479 372 if (new_device_address < 0) { 480 usb_log_error("failed to get free USB address ");373 usb_log_error("failed to get free USB address\n"); 481 374 opResult = new_device_address; 482 375 usb_hub_release_default_address(hub); 483 376 return; 484 377 } 485 usb_log_info("setting new address %d ",new_device_address);378 usb_log_info("setting new address %d\n",new_device_address); 486 379 //opResult = usb_drv_req_set_address(hc, USB_ADDRESS_DEFAULT, 487 380 // new_device_address); … … 490 383 usb_endpoint_pipe_end_session(&new_device_pipe); 491 384 if (opResult != EOK) { 492 usb_log_error("could not set address for new device %d ",opResult);385 usb_log_error("could not set address for new device %d\n",opResult); 493 386 usb_hub_release_default_address(hub); 494 387 return; … … 505 398 //?? 506 399 opResult = usb_device_register_child_in_devman(new_device_address, 507 hub->connection.hc_handle, hub-> device, &child_handle,400 hub->connection.hc_handle, hub->usb_device->ddf_dev, &child_handle, 508 401 NULL, NULL, NULL); 509 402 510 403 if (opResult != EOK) { 511 usb_log_error("could not start driver for new device %d ",opResult);404 usb_log_error("could not start driver for new device %d\n",opResult); 512 405 return; 513 406 } … … 520 413 &hub->attached_devs[port]); 521 414 if (opResult != EOK) { 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 ",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", 526 419 new_device_address, child_handle); 527 420 … … 537 430 usb_hub_info_t * hub,uint16_t port) { 538 431 539 int opResult = usb_hub_clear_port_feature( &hub->endpoints.control,432 int opResult = usb_hub_clear_port_feature(hub->control_pipe, 540 433 port, USB_HUB_FEATURE_C_PORT_CONNECTION); 541 434 if(opResult != EOK){ 542 usb_log_warning("could not clear port-change-connection flag ");435 usb_log_warning("could not clear port-change-connection flag\n"); 543 436 } 544 437 /** \TODO remove device from device manager - not yet implemented in … … 559 452 */ 560 453 }else{ 561 usb_log_warning("this is strange, disconnected device had no address ");454 usb_log_warning("this is strange, disconnected device had no address\n"); 562 455 //device was disconnected before it`s port was reset - return default address 563 456 usb_hub_release_default_address(hub); … … 577 470 uint16_t port){ 578 471 int opResult; 579 opResult = usb_hub_clear_port_feature( &hub->endpoints.control,472 opResult = usb_hub_clear_port_feature(hub->control_pipe, 580 473 port, USB_HUB_FEATURE_PORT_POWER); 581 474 if(opResult!=EOK){ 582 usb_log_error("cannot power off port %d; %d ",475 usb_log_error("cannot power off port %d; %d\n", 583 476 port, opResult); 584 477 } … … 593 486 static void usb_hub_process_interrupt(usb_hub_info_t * hub, 594 487 uint16_t port) { 595 usb_log_debug("interrupt at port %d ", port);488 usb_log_debug("interrupt at port %d\n", port); 596 489 //determine type of change 597 usb_endpoint_pipe_t *pipe = &hub->endpoints.control;490 usb_endpoint_pipe_t *pipe = hub->control_pipe; 598 491 599 492 int opResult; … … 612 505 ); 613 506 if (opResult != EOK) { 614 usb_log_error("could not get port status ");507 usb_log_error("could not get port status\n"); 615 508 return; 616 509 } 617 510 if (rcvd_size != sizeof (usb_port_status_t)) { 618 usb_log_error("received status has incorrect size ");511 usb_log_error("received status has incorrect size\n"); 619 512 return; 620 513 } … … 622 515 if (usb_port_connect_change(&status)) { 623 516 if (usb_port_dev_connected(&status)) { 624 usb_log_info("some connection changed ");517 usb_log_info("some connection changed\n"); 625 518 usb_hub_init_add_device(hub, port, usb_port_speed(&status)); 626 519 } else { … … 634 527 usb_hub_over_current(hub,port); 635 528 }else{ 636 usb_log_info("over current condition was auto-resolved on port %d ",529 usb_log_info("over current condition was auto-resolved on port %d\n", 637 530 port); 638 531 } … … 642 535 usb_log_info("port reset complete"); 643 536 if (usb_port_enabled(&status)) { 644 usb_hub_finalize_add_device(hub, port, usb_port_ low_speed(&status));537 usb_hub_finalize_add_device(hub, port, usb_port_speed(&status)); 645 538 } else { 646 usb_log_warning("port reset, but port still not enabled ");539 usb_log_warning("port reset, but port still not enabled\n"); 647 540 } 648 541 } … … 653 546 usb_port_set_dev_connected(&status, false); 654 547 if (status>>16) { 655 usb_log_info("there was some unsupported change on port %d: %X ",548 usb_log_info("there was some unsupported change on port %d: %X\n", 656 549 port,status); 657 550 658 551 } 659 /// \TODO handle other changes - is there any?660 552 } 661 553 … … 668 560 int usb_hub_check_hub_changes(usb_hub_info_t * hub_info){ 669 561 int opResult; 670 opResult = usb_endpoint_pipe_start_session(&hub_info->endpoints.status_change); 562 opResult = usb_endpoint_pipe_start_session( 563 hub_info->status_change_pipe); 671 564 if(opResult != EOK){ 672 usb_log_error("could not initialize communication for hub; %d ",565 usb_log_error("could not initialize communication for hub; %d\n", 673 566 opResult); 674 567 return opResult; … … 686 579 */ 687 580 opResult = usb_endpoint_pipe_read( 688 &hub_info->endpoints.status_change,581 hub_info->status_change_pipe, 689 582 change_bitmap, byte_length, &actual_size 690 583 ); … … 692 585 if (opResult != EOK) { 693 586 free(change_bitmap); 694 usb_log_warning("something went wrong while getting status of hub ");695 usb_endpoint_pipe_end_session( &hub_info->endpoints.status_change);587 usb_log_warning("something went wrong while getting status of hub\n"); 588 usb_endpoint_pipe_end_session(hub_info->status_change_pipe); 696 589 return opResult; 697 590 } 698 591 unsigned int port; 699 opResult = usb_endpoint_pipe_start_session( &hub_info->endpoints.control);700 if(opResult!=EOK){ 701 usb_log_error("could not start control pipe session %d ", opResult);702 usb_endpoint_pipe_end_session( &hub_info->endpoints.status_change);592 opResult = usb_endpoint_pipe_start_session(hub_info->control_pipe); 593 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); 703 596 return opResult; 704 597 } 705 598 opResult = usb_hc_connection_open(&hub_info->connection); 706 599 if(opResult!=EOK){ 707 usb_log_error("could not start host controller session %d ",600 usb_log_error("could not start host controller session %d\n", 708 601 opResult); 709 usb_endpoint_pipe_end_session( &hub_info->endpoints.control);710 usb_endpoint_pipe_end_session( &hub_info->endpoints.status_change);602 usb_endpoint_pipe_end_session(hub_info->control_pipe); 603 usb_endpoint_pipe_end_session(hub_info->status_change_pipe); 711 604 return opResult; 712 605 } … … 722 615 } 723 616 usb_hc_connection_close(&hub_info->connection); 724 usb_endpoint_pipe_end_session( &hub_info->endpoints.control);725 usb_endpoint_pipe_end_session( &hub_info->endpoints.status_change);617 usb_endpoint_pipe_end_session(hub_info->control_pipe); 618 usb_endpoint_pipe_end_session(hub_info->status_change_pipe); 726 619 free(change_bitmap); 727 620 return EOK;
Note:
See TracChangeset
for help on using the changeset viewer.