Changeset 54464f6a in mainline for uspace/drv/bus/usb/usbhid/mouse/mousedev.c
- Timestamp:
- 2011-11-11T19:48:33Z (13 years ago)
- Branches:
- lfn, master, serial, ticket/834-toolchain-update, topic/msim-upgrade, topic/simplify-dev-export
- Children:
- 50a01a9
- Parents:
- c2e50d7 (diff), 747ef72 (diff)
Note: this is a merge changeset, the changes displayed below correspond to the merge itself.
Use the(diff)
links above to see all the changes relative to each parent. - File:
-
- 1 edited
Legend:
- Unmodified
- Added
- Removed
-
uspace/drv/bus/usb/usbhid/mouse/mousedev.c
rc2e50d7 r54464f6a 55 55 #define ARROWS_PER_SINGLE_WHEEL 3 56 56 57 #define NAME 57 #define NAME "mouse" 58 58 59 59 /*----------------------------------------------------------------------------*/ … … 77 77 78 78 /*----------------------------------------------------------------------------*/ 79 80 enum { 81 USB_MOUSE_BOOT_REPORT_DESCRIPTOR_SIZE = 63 82 }; 83 84 static const uint8_t USB_MOUSE_BOOT_REPORT_DESCRIPTOR[ 85 USB_MOUSE_BOOT_REPORT_DESCRIPTOR_SIZE] = { 79 static const uint8_t USB_MOUSE_BOOT_REPORT_DESCRIPTOR[] = { 86 80 0x05, 0x01, // USAGE_PAGE (Generic Desktop) 87 81 0x09, 0x02, // USAGE (Mouse) … … 123 117 ipc_callid_t icallid, ipc_call_t *icall) 124 118 { 125 usb_mouse_t *mouse_dev = (usb_mouse_t *)fun->driver_data;119 usb_mouse_t *mouse_dev = fun->driver_data; 126 120 127 121 if (mouse_dev == NULL) { 128 usb_log_debug("default_connection_handler: Missing " 129 "parameters.\n"); 122 usb_log_debug("%s: Missing parameters.\n", __FUNCTION__); 130 123 async_answer_0(icallid, EINVAL); 131 124 return; 132 125 } 133 126 134 usb_log_debug("default_connection_handler: fun->name: %s\n", 135 fun->name); 136 usb_log_debug("default_connection_handler: mouse_sess: %p, " 137 "wheel_sess: %p\n", mouse_dev->mouse_sess, mouse_dev->wheel_sess); 138 139 async_sess_t **sess_ptr = 140 (str_cmp(fun->name, HID_MOUSE_FUN_NAME) == 0) ? 127 usb_log_debug("%s: fun->name: %s\n", __FUNCTION__, fun->name); 128 usb_log_debug("%s: mouse_sess: %p, wheel_sess: %p\n", 129 __FUNCTION__, mouse_dev->mouse_sess, mouse_dev->wheel_sess); 130 131 async_sess_t **sess_ptr = (fun == mouse_dev->mouse_fun) ? 141 132 &mouse_dev->mouse_sess : &mouse_dev->wheel_sess; 142 133 … … 146 137 if (*sess_ptr == NULL) { 147 138 *sess_ptr = sess; 148 usb_log_debug("Console session to mouseset ok (%p).\n",149 sess);139 usb_log_debug("Console session to %s set ok (%p).\n", 140 fun->name, sess); 150 141 async_answer_0(icallid, EOK); 151 142 } else { 152 usb_log_ debug("default_connection_handler: Console "153 "session to mouse already set.\n");143 usb_log_error("Console session to %s already set.\n", 144 fun->name); 154 145 async_answer_0(icallid, ELIMIT); 155 146 } 156 147 } else { 157 usb_log_debug(" default_connection_handler: Invalid function.\n");148 usb_log_debug("%s: Invalid function.\n", __FUNCTION__); 158 149 async_answer_0(icallid, EINVAL); 159 }160 }161 162 /*----------------------------------------------------------------------------*/163 164 static usb_mouse_t *usb_mouse_new(void)165 {166 usb_mouse_t *mouse = calloc(1, sizeof(usb_mouse_t));167 if (mouse == NULL) {168 return NULL;169 }170 mouse->mouse_sess = NULL;171 mouse->wheel_sess = NULL;172 173 return mouse;174 }175 176 /*----------------------------------------------------------------------------*/177 178 static void usb_mouse_destroy(usb_mouse_t *mouse_dev)179 {180 assert(mouse_dev != NULL);181 182 // hangup session to the console183 if (mouse_dev->mouse_sess != NULL)184 async_hangup(mouse_dev->mouse_sess);185 186 if (mouse_dev->wheel_sess != NULL)187 async_hangup(mouse_dev->wheel_sess);188 int ret = ddf_fun_unbind(mouse_dev->mouse_fun);189 if (ret != EOK) {190 usb_log_error("Failed to unbind mouse function.\n");191 } else {192 ddf_fun_destroy(mouse_dev->mouse_fun);193 /* Prevent double free */194 mouse_dev->wheel_fun->driver_data = NULL;195 }196 197 ret = ddf_fun_unbind(mouse_dev->wheel_fun);198 if (ret != EOK) {199 usb_log_error("Failed to unbind wheel function.\n");200 } else {201 ddf_fun_destroy(mouse_dev->wheel_fun);202 150 } 203 151 } … … 215 163 } 216 164 217 int count = ((wheel < 0) ? -wheel : wheel) * ARROWS_PER_SINGLE_WHEEL; 218 int i; 219 220 for (i = 0; i < count; i++) { 165 const unsigned count = 166 ((wheel < 0) ? -wheel : wheel) * ARROWS_PER_SINGLE_WHEEL; 167 for (unsigned i = 0; i < count; i++) { 221 168 /* Send arrow press and release. */ 222 169 usb_log_debug2("Sending key %d to the console\n", key); … … 267 214 } 268 215 269 int shift_x = get_mouse_axis_move_value(hid_dev->report_id,216 const int shift_x = get_mouse_axis_move_value(hid_dev->report_id, 270 217 &hid_dev->report, USB_HIDUT_USAGE_GENERIC_DESKTOP_X); 271 int shift_y = get_mouse_axis_move_value(hid_dev->report_id,218 const int shift_y = get_mouse_axis_move_value(hid_dev->report_id, 272 219 &hid_dev->report, USB_HIDUT_USAGE_GENERIC_DESKTOP_Y); 273 int wheel = get_mouse_axis_move_value(hid_dev->report_id,220 const int wheel = get_mouse_axis_move_value(hid_dev->report_id, 274 221 &hid_dev->report, USB_HIDUT_USAGE_GENERIC_DESKTOP_WHEEL); 275 222 … … 277 224 async_exch_t *exch = 278 225 async_exchange_begin(mouse_dev->mouse_sess); 279 async_req_2_0(exch, MOUSEEV_MOVE_EVENT, shift_x, shift_y); 280 async_exchange_end(exch); 226 if (exch != NULL) { 227 async_req_2_0(exch, MOUSEEV_MOVE_EVENT, shift_x, shift_y); 228 async_exchange_end(exch); 229 } 281 230 } 282 231 … … 284 233 usb_mouse_send_wheel(mouse_dev, wheel); 285 234 286 /* 287 * Buttons 288 */ 235 /* Buttons */ 289 236 usb_hid_report_path_t *path = usb_hid_report_path(); 290 usb_hid_report_path_append_item(path, USB_HIDUT_PAGE_BUTTON, 0); 237 if (path == NULL) { 238 usb_log_warning("Failed to create USB HID report path.\n"); 239 return true; 240 } 241 int ret = 242 usb_hid_report_path_append_item(path, USB_HIDUT_PAGE_BUTTON, 0); 243 if (ret != EOK) { 244 usb_hid_report_path_free(path); 245 usb_log_warning("Failed to add buttons to report path.\n"); 246 return true; 247 } 291 248 usb_hid_report_path_set_report_id(path, hid_dev->report_id); 292 249 … … 298 255 usb_log_debug2(NAME " VALUE(%X) USAGE(%X)\n", field->value, 299 256 field->usage); 300 301 if (mouse_dev->buttons[field->usage - field->usage_minimum] == 0 302 && field->value != 0) { 257 assert(field->usage > field->usage_minimum); 258 const unsigned index = field->usage - field->usage_minimum; 259 assert(index < mouse_dev->buttons_count); 260 261 if (mouse_dev->buttons[index] == 0 && field->value != 0) { 303 262 async_exch_t *exch = 304 263 async_exchange_begin(mouse_dev->mouse_sess); 305 async_req_2_0(exch, MOUSEEV_BUTTON_EVENT, field->usage, 1); 306 async_exchange_end(exch); 307 308 mouse_dev->buttons[field->usage - field->usage_minimum] 309 = field->value; 310 } else if (mouse_dev->buttons[field->usage - field->usage_minimum] != 0 311 && field->value == 0) { 264 if (exch != NULL) { 265 async_req_2_0(exch, MOUSEEV_BUTTON_EVENT, 266 field->usage, 1); 267 async_exchange_end(exch); 268 mouse_dev->buttons[index] = field->value; 269 } 270 271 } else if (mouse_dev->buttons[index] != 0 && field->value == 0) { 312 272 async_exch_t *exch = 313 273 async_exchange_begin(mouse_dev->mouse_sess); 314 async_req_2_0(exch, MOUSEEV_BUTTON_EVENT, field->usage, 0); 315 async_exchange_end(exch); 316 317 mouse_dev->buttons[field->usage - field->usage_minimum] = 318 field->value; 274 if (exch != NULL) { 275 async_req_2_0(exch, MOUSEEV_BUTTON_EVENT, 276 field->usage, 0); 277 async_exchange_end(exch); 278 mouse_dev->buttons[index] = field->value; 279 } 319 280 } 320 281 … … 329 290 return true; 330 291 } 331 332 /*----------------------------------------------------------------------------*/ 333 292 /*----------------------------------------------------------------------------*/ 293 #define FUN_UNBIND_DESTROY(fun) \ 294 if (fun) { \ 295 if (ddf_fun_unbind((fun)) == EOK) { \ 296 (fun)->driver_data = NULL; \ 297 ddf_fun_destroy((fun)); \ 298 } else { \ 299 usb_log_error("Could not unbind function `%s', it " \ 300 "will not be destroyed.\n", (fun)->name); \ 301 } \ 302 } else (void)0 303 /*----------------------------------------------------------------------------*/ 334 304 static int usb_mouse_create_function(usb_hid_dev_t *hid_dev, usb_mouse_t *mouse) 335 305 { … … 339 309 /* Create the exposed function. */ 340 310 usb_log_debug("Creating DDF function %s...\n", HID_MOUSE_FUN_NAME); 341 ddf_fun_t *fun = ddf_fun_create(hid_dev->usb_dev->ddf_dev, fun_exposed, 311 ddf_fun_t *fun = ddf_fun_create(hid_dev->usb_dev->ddf_dev, fun_exposed, 342 312 HID_MOUSE_FUN_NAME); 343 313 if (fun == NULL) { 344 usb_log_error("Could not create DDF function node.\n"); 314 usb_log_error("Could not create DDF function node `%s'.\n", 315 HID_MOUSE_FUN_NAME); 345 316 return ENOMEM; 346 317 } … … 351 322 int rc = ddf_fun_bind(fun); 352 323 if (rc != EOK) { 353 usb_log_error("Could not bind DDF function: %s.\n", 354 str_error(rc)); 355 return rc; 356 } 357 358 usb_log_debug("Adding DDF function to category %s...\n", 359 HID_MOUSE_CATEGORY); 324 usb_log_error("Could not bind DDF function `%s': %s.\n", 325 fun->name, str_error(rc)); 326 fun->driver_data = NULL; 327 ddf_fun_destroy(fun); 328 return rc; 329 } 330 331 usb_log_debug("Adding DDF function `%s' to category %s...\n", 332 fun->name, HID_MOUSE_CATEGORY); 360 333 rc = ddf_fun_add_to_category(fun, HID_MOUSE_CATEGORY); 361 334 if (rc != EOK) { … … 363 336 "Could not add DDF function to category %s: %s.\n", 364 337 HID_MOUSE_CATEGORY, str_error(rc)); 338 FUN_UNBIND_DESTROY(fun); 365 339 return rc; 366 340 } … … 370 344 * Special function for acting as keyboard (wheel) 371 345 */ 372 usb_log_debug("Creating DDF function %s...\n", 346 usb_log_debug("Creating DDF function %s...\n", 373 347 HID_MOUSE_WHEEL_FUN_NAME); 374 fun = ddf_fun_create(hid_dev->usb_dev->ddf_dev, fun_exposed, 348 fun = ddf_fun_create(hid_dev->usb_dev->ddf_dev, fun_exposed, 375 349 HID_MOUSE_WHEEL_FUN_NAME); 376 350 if (fun == NULL) { 377 usb_log_error("Could not create DDF function node.\n"); 351 usb_log_error("Could not create DDF function node `%s'.\n", 352 HID_MOUSE_WHEEL_FUN_NAME); 353 FUN_UNBIND_DESTROY(mouse->mouse_fun); 354 mouse->mouse_fun = NULL; 378 355 return ENOMEM; 379 356 } … … 388 365 rc = ddf_fun_bind(fun); 389 366 if (rc != EOK) { 390 usb_log_error("Could not bind DDF function: %s.\n", 391 str_error(rc)); 367 usb_log_error("Could not bind DDF function `%s': %s.\n", 368 fun->name, str_error(rc)); 369 FUN_UNBIND_DESTROY(mouse->mouse_fun); 370 mouse->mouse_fun = NULL; 371 372 fun->driver_data = NULL; 373 ddf_fun_destroy(fun); 392 374 return rc; 393 375 } … … 400 382 "Could not add DDF function to category %s: %s.\n", 401 383 HID_MOUSE_WHEEL_CATEGORY, str_error(rc)); 384 385 FUN_UNBIND_DESTROY(mouse->mouse_fun); 386 mouse->mouse_fun = NULL; 387 FUN_UNBIND_DESTROY(fun); 402 388 return rc; 403 389 } … … 448 434 return highest_button; 449 435 } 450 451 /*----------------------------------------------------------------------------*/ 452 436 /*----------------------------------------------------------------------------*/ 453 437 int usb_mouse_init(usb_hid_dev_t *hid_dev, void **data) 454 438 { … … 461 445 } 462 446 463 usb_mouse_t *mouse_dev = usb_mouse_new();447 usb_mouse_t *mouse_dev = calloc(1, sizeof(usb_mouse_t)); 464 448 if (mouse_dev == NULL) { 465 449 usb_log_error("Error while creating USB/HID Mouse device " … … 484 468 } 485 469 486 487 // save the Mouse device structure into the HID device structure488 *data = mouse_dev;489 490 470 // set handler for incoming calls 491 471 mouse_dev->ops.default_handler = default_connection_handler; 492 472 493 473 // TODO: how to know if the device supports the request??? 494 usbhid_req_set_idle(&hid_dev->usb_dev->ctrl_pipe, 474 usbhid_req_set_idle(&hid_dev->usb_dev->ctrl_pipe, 495 475 hid_dev->usb_dev->interface_no, IDLE_RATE); 496 476 497 477 int rc = usb_mouse_create_function(hid_dev, mouse_dev); 498 478 if (rc != EOK) { 499 usb_mouse_destroy(mouse_dev); 500 return rc; 501 } 479 free(mouse_dev->buttons); 480 free(mouse_dev); 481 return rc; 482 } 483 484 /* Save the Mouse device structure into the HID device structure. */ 485 *data = mouse_dev; 502 486 503 487 return EOK; 504 488 } 505 506 /*----------------------------------------------------------------------------*/ 507 489 /*----------------------------------------------------------------------------*/ 508 490 bool usb_mouse_polling_callback(usb_hid_dev_t *hid_dev, void *data) 509 491 { 510 492 if (hid_dev == NULL || data == NULL) { 511 usb_log_error( "Missing argument to the mouse polling callback."512 " \n");493 usb_log_error( 494 "Missing argument to the mouse polling callback.\n"); 513 495 return false; 514 496 } 515 497 516 usb_mouse_t *mouse_dev = (usb_mouse_t *)data;517 498 usb_mouse_t *mouse_dev = data; 499 518 500 return usb_mouse_process_report(hid_dev, mouse_dev); 519 501 } 520 521 /*----------------------------------------------------------------------------*/ 522 502 /*----------------------------------------------------------------------------*/ 523 503 void usb_mouse_deinit(usb_hid_dev_t *hid_dev, void *data) 524 504 { 525 if (data != NULL) { 526 usb_mouse_destroy(data); 527 } 528 } 529 530 /*----------------------------------------------------------------------------*/ 531 505 if (data == NULL) 506 return; 507 508 usb_mouse_t *mouse_dev = data; 509 510 /* Hangup session to the console */ 511 if (mouse_dev->mouse_sess != NULL) { 512 const int ret = async_hangup(mouse_dev->mouse_sess); 513 if (ret != EOK) 514 usb_log_warning("Failed to hang up mouse session: " 515 "%p, %s.\n", mouse_dev->mouse_sess, str_error(ret)); 516 } 517 518 if (mouse_dev->wheel_sess != NULL) { 519 const int ret = async_hangup(mouse_dev->wheel_sess); 520 if (ret != EOK) 521 usb_log_warning("Failed to hang up wheel session: " 522 "%p, %s.\n", mouse_dev->wheel_sess, str_error(ret)); 523 } 524 525 FUN_UNBIND_DESTROY(mouse_dev->mouse_fun); 526 FUN_UNBIND_DESTROY(mouse_dev->wheel_fun); 527 528 free(mouse_dev->buttons); 529 free(mouse_dev); 530 } 531 /*----------------------------------------------------------------------------*/ 532 532 int usb_mouse_set_boot_protocol(usb_hid_dev_t *hid_dev) 533 533 { 534 534 int rc = usb_hid_parse_report_descriptor( 535 535 &hid_dev->report, USB_MOUSE_BOOT_REPORT_DESCRIPTOR, 536 USB_MOUSE_BOOT_REPORT_DESCRIPTOR_SIZE);536 sizeof(USB_MOUSE_BOOT_REPORT_DESCRIPTOR)); 537 537 538 538 if (rc != EOK) {
Note:
See TracChangeset
for help on using the changeset viewer.