Ignore:
File:
1 edited

Legend:

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

    r58563585 r56fd7cf  
    3434 * USB Mouse driver API.
    3535 */
     36
     37/* XXX Fix this */
     38#define _DDF_DATA_IMPLANT
    3639
    3740#include <usb/debug.h>
     
    254257                    "will not be destroyed.\n", ddf_fun_get_name(fun)); \
    255258        } \
    256 } else (void) 0
     259} else (void)0
     260
     261static 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}
    257300
    258301/** Get highest index of a button mentioned in given report.
     
    296339}
    297340
    298 static int mouse_dev_init(usb_mouse_t *mouse_dev, usb_hid_dev_t *hid_dev)
    299 {
     341int 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
    300358        // FIXME: This may not be optimal since stupid hardware vendor may
    301359        // use buttons 1, 2, 3 and 6000 and we would allocate array of
     
    315373
    316374        // TODO: how to know if the device supports the request???
    317         usbhid_req_set_idle(usb_device_get_default_pipe(hid_dev->usb_dev),
    318             usb_device_get_iface_number(hid_dev->usb_dev), IDLE_RATE);
    319         return EOK;
    320 }
    321 
    322 int 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 mouse 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 = usb_device_ddf_fun_create(hid_dev->usb_dev,
    335             fun_exposed, 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;
     375        usbhid_req_set_idle(&hid_dev->usb_dev->ctrl_pipe,
     376            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        }
    376384
    377385        /* Save the Mouse device structure into the HID device structure. */
     
    409417        }
    410418
     419        FUN_UNBIND_DESTROY(mouse_dev->mouse_fun);
     420
    411421        free(mouse_dev->buttons);
    412         FUN_UNBIND_DESTROY(mouse_dev->mouse_fun);
    413422}
    414423
     
    425434        }
    426435
    427         rc = usbhid_req_set_protocol(
    428             usb_device_get_default_pipe(hid_dev->usb_dev),
    429             usb_device_get_iface_number(hid_dev->usb_dev),
    430             USB_HID_PROTOCOL_BOOT);
     436        rc = usbhid_req_set_protocol(&hid_dev->usb_dev->ctrl_pipe,
     437            hid_dev->usb_dev->interface_no, USB_HID_PROTOCOL_BOOT);
    431438
    432439        if (rc != EOK) {
Note: See TracChangeset for help on using the changeset viewer.