Changeset 38b4a25 in mainline


Ignore:
Timestamp:
2012-12-22T19:25:56Z (12 years ago)
Author:
Jan Vesely <jano.vesely@…>
Branches:
lfn, master, serial, ticket/834-toolchain-update, topic/msim-upgrade, topic/simplify-dev-export
Children:
56a07e0
Parents:
1e2af6a9
Message:

usbhid, mouse: Reorganize init to avoid data_implant.

File:
1 edited

Legend:

Unmodified
Added
Removed
  • uspace/drv/bus/usb/usbhid/mouse/mousedev.c

    r1e2af6a9 r38b4a25  
    3434 * USB Mouse driver API.
    3535 */
    36 
    37 /* XXX Fix this */
    38 #define _DDF_DATA_IMPLANT
    3936
    4037#include <usb/debug.h>
     
    259256} else (void)0
    260257
    261 static int usb_mouse_create_function(usb_hid_dev_t *hid_dev, usb_mouse_t *mouse)
    262 {
    263         assert(hid_dev != NULL);
    264         assert(mouse != NULL);
    265 
    266         /* Create the exposed function. */
    267         usb_log_debug("Creating DDF function %s...\n", HID_MOUSE_FUN_NAME);
    268         ddf_fun_t *fun = ddf_fun_create(hid_dev->usb_dev->ddf_dev, fun_exposed,
    269             HID_MOUSE_FUN_NAME);
    270         if (fun == NULL) {
    271                 usb_log_error("Could not create DDF function node `%s'.\n",
    272                     HID_MOUSE_FUN_NAME);
    273                 return ENOMEM;
    274         }
    275 
    276         ddf_fun_set_ops(fun, &ops);
    277         ddf_fun_data_implant(fun, mouse);
    278 
    279         int rc = ddf_fun_bind(fun);
    280         if (rc != EOK) {
    281                 usb_log_error("Could not bind DDF function `%s': %s.\n",
    282                     ddf_fun_get_name(fun), str_error(rc));
    283                 ddf_fun_destroy(fun);
    284                 return rc;
    285         }
    286 
    287         usb_log_debug("Adding DDF function `%s' to category %s...\n",
    288             ddf_fun_get_name(fun), HID_MOUSE_CATEGORY);
    289         rc = ddf_fun_add_to_category(fun, HID_MOUSE_CATEGORY);
    290         if (rc != EOK) {
    291                 usb_log_error(
    292                     "Could not add DDF function to category %s: %s.\n",
    293                     HID_MOUSE_CATEGORY, str_error(rc));
    294                 FUN_UNBIND_DESTROY(fun);
    295                 return rc;
    296         }
    297         mouse->mouse_fun = fun;
    298         return EOK;
    299 }
    300 
    301258/** Get highest index of a button mentioned in given report.
    302259 *
     
    339296}
    340297
    341 int usb_mouse_init(usb_hid_dev_t *hid_dev, void **data)
    342 {
    343         usb_log_debug("Initializing HID/Mouse structure...\n");
    344 
    345         if (hid_dev == NULL) {
    346                 usb_log_error("Failed to init keyboard structure: no structure"
    347                     " given.\n");
    348                 return EINVAL;
    349         }
    350 
    351         usb_mouse_t *mouse_dev = calloc(1, sizeof(usb_mouse_t));
    352         if (mouse_dev == NULL) {
    353                 usb_log_error("Error while creating USB/HID Mouse device "
    354                     "structure.\n");
    355                 return ENOMEM;
    356         }
    357 
     298static int mouse_dev_init(usb_mouse_t *mouse_dev, usb_hid_dev_t *hid_dev)
     299{
    358300        // FIXME: This may not be optimal since stupid hardware vendor may
    359301        // use buttons 1, 2, 3 and 6000 and we would allocate array of
     
    375317        usbhid_req_set_idle(&hid_dev->usb_dev->ctrl_pipe,
    376318            hid_dev->usb_dev->interface_no, IDLE_RATE);
    377 
    378         int rc = usb_mouse_create_function(hid_dev, mouse_dev);
    379         if (rc != EOK) {
    380                 free(mouse_dev->buttons);
    381                 free(mouse_dev);
    382                 return rc;
    383         }
     319        return EOK;
     320}
     321
     322int usb_mouse_init(usb_hid_dev_t *hid_dev, void **data)
     323{
     324        usb_log_debug("Initializing HID/Mouse structure...\n");
     325
     326        if (hid_dev == NULL) {
     327                usb_log_error("Failed to init keyboard structure: no structure"
     328                    " given.\n");
     329                return EINVAL;
     330        }
     331
     332        /* Create the exposed function. */
     333        usb_log_debug("Creating DDF function %s...\n", HID_MOUSE_FUN_NAME);
     334        ddf_fun_t *fun = ddf_fun_create(hid_dev->usb_dev->ddf_dev, fun_exposed,
     335            HID_MOUSE_FUN_NAME);
     336        if (fun == NULL) {
     337                usb_log_error("Could not create DDF function node `%s'.\n",
     338                    HID_MOUSE_FUN_NAME);
     339                return ENOMEM;
     340        }
     341
     342        usb_mouse_t *mouse_dev = ddf_fun_data_alloc(fun, sizeof(usb_mouse_t));
     343        if (mouse_dev == NULL) {
     344                usb_log_error("Failed to alloc HID mouse device structure.\n");
     345                ddf_fun_destroy(fun);
     346                return ENOMEM;
     347        }
     348
     349        int ret = mouse_dev_init(mouse_dev, hid_dev);
     350        if (ret != EOK) {
     351                usb_log_error("Failed to init HID mouse device structure.\n");
     352                return ret;
     353        }
     354
     355        ddf_fun_set_ops(fun, &ops);
     356
     357        ret = ddf_fun_bind(fun);
     358        if (ret != EOK) {
     359                usb_log_error("Could not bind DDF function `%s': %s.\n",
     360                    ddf_fun_get_name(fun), str_error(ret));
     361                ddf_fun_destroy(fun);
     362                return ret;
     363        }
     364
     365        usb_log_debug("Adding DDF function `%s' to category %s...\n",
     366            ddf_fun_get_name(fun), HID_MOUSE_CATEGORY);
     367        ret = ddf_fun_add_to_category(fun, HID_MOUSE_CATEGORY);
     368        if (ret != EOK) {
     369                usb_log_error(
     370                    "Could not add DDF function to category %s: %s.\n",
     371                    HID_MOUSE_CATEGORY, str_error(ret));
     372                FUN_UNBIND_DESTROY(fun);
     373                return ret;
     374        }
     375        mouse_dev->mouse_fun = fun;
    384376
    385377        /* Save the Mouse device structure into the HID device structure. */
     
    417409        }
    418410
     411        free(mouse_dev->buttons);
    419412        FUN_UNBIND_DESTROY(mouse_dev->mouse_fun);
    420 
    421         free(mouse_dev->buttons);
    422413}
    423414
Note: See TracChangeset for help on using the changeset viewer.