Ignore:
File:
1 edited

Legend:

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

    r9d58539 r56fd7cf  
    3535 */
    3636
     37/* XXX Fix this */
     38#define _DDF_DATA_IMPLANT
     39
    3740#include <usb/debug.h>
    3841#include <usb/classes/classes.h>
     
    5457#define NAME "mouse"
    5558
    56 /*----------------------------------------------------------------------------*/
     59static void default_connection_handler(ddf_fun_t *, ipc_callid_t, ipc_call_t *);
     60
     61static ddf_dev_ops_t ops = { .default_handler = default_connection_handler };
     62
    5763
    5864const usb_endpoint_description_t usb_hid_mouse_poll_endpoint_description = {
     
    7177static const uint8_t IDLE_RATE = 0;
    7278
    73 /*----------------------------------------------------------------------------*/
     79
    7480static const uint8_t USB_MOUSE_BOOT_REPORT_DESCRIPTOR[] = {
    7581        0x05, 0x01,                    // USAGE_PAGE (Generic Desktop)
     
    101107};
    102108
    103 /*----------------------------------------------------------------------------*/
     109
    104110
    105111/** Default handler for IPC methods not handled by DDF.
     
    112118    ipc_callid_t icallid, ipc_call_t *icall)
    113119{
    114         usb_mouse_t *mouse_dev = fun->driver_data;
     120        usb_mouse_t *mouse_dev = ddf_fun_data_get(fun);
    115121
    116122        if (mouse_dev == NULL) {
     
    120126        }
    121127
    122         usb_log_debug("%s: fun->name: %s\n", __FUNCTION__, fun->name);
     128        usb_log_debug("%s: fun->name: %s\n", __FUNCTION__, ddf_fun_get_name(fun));
    123129        usb_log_debug("%s: mouse_sess: %p\n",
    124130            __FUNCTION__, mouse_dev->mouse_sess);
     
    130136                        mouse_dev->mouse_sess = sess;
    131137                        usb_log_debug("Console session to %s set ok (%p).\n",
    132                             fun->name, sess);
     138                            ddf_fun_get_name(fun), sess);
    133139                        async_answer_0(icallid, EOK);
    134140                } else {
    135141                        usb_log_error("Console session to %s already set.\n",
    136                             fun->name);
     142                            ddf_fun_get_name(fun));
    137143                        async_answer_0(icallid, ELIMIT);
    138144                        async_hangup(sess);
     
    143149        }
    144150}
    145 /*----------------------------------------------------------------------------*/
     151
    146152static int get_mouse_axis_move_value(uint8_t rid, usb_hid_report_t *report,
    147153    int32_t usage)
     
    221227                assert(index < mouse_dev->buttons_count);
    222228
    223                 if (mouse_dev->buttons[index] == 0 && field->value != 0) {
     229                if (mouse_dev->buttons[index] != field->value) {
    224230                        async_exch_t *exch =
    225231                            async_exchange_begin(mouse_dev->mouse_sess);
    226232                        if (exch != NULL) {
    227233                                async_req_2_0(exch, MOUSEEV_BUTTON_EVENT,
    228                                     field->usage, 1);
    229                                 async_exchange_end(exch);
    230                                 mouse_dev->buttons[index] = field->value;
    231                         }
    232 
    233                 } else if (mouse_dev->buttons[index] != 0 && field->value == 0) {
    234                         async_exch_t *exch =
    235                             async_exchange_begin(mouse_dev->mouse_sess);
    236                         if (exch != NULL) {
    237                                 async_req_2_0(exch, MOUSEEV_BUTTON_EVENT,
    238                                     field->usage, 0);
     234                                    field->usage, (field->value != 0) ? 1 : 0);
    239235                                async_exchange_end(exch);
    240236                                mouse_dev->buttons[index] = field->value;
     
    252248        return true;
    253249}
    254 /*----------------------------------------------------------------------------*/
     250
    255251#define FUN_UNBIND_DESTROY(fun) \
    256252if (fun) { \
    257253        if (ddf_fun_unbind((fun)) == EOK) { \
    258                 (fun)->driver_data = NULL; \
    259254                ddf_fun_destroy((fun)); \
    260255        } else { \
    261256                usb_log_error("Could not unbind function `%s', it " \
    262                     "will not be destroyed.\n", (fun)->name); \
     257                    "will not be destroyed.\n", ddf_fun_get_name(fun)); \
    263258        } \
    264259} else (void)0
    265 /*----------------------------------------------------------------------------*/
     260
    266261static int usb_mouse_create_function(usb_hid_dev_t *hid_dev, usb_mouse_t *mouse)
    267262{
     
    279274        }
    280275
    281         fun->ops = &mouse->ops;
    282         fun->driver_data = mouse;
     276        ddf_fun_set_ops(fun, &ops);
     277        ddf_fun_data_implant(fun, mouse);
    283278
    284279        int rc = ddf_fun_bind(fun);
    285280        if (rc != EOK) {
    286281                usb_log_error("Could not bind DDF function `%s': %s.\n",
    287                     fun->name, str_error(rc));
    288                 fun->driver_data = NULL;
     282                    ddf_fun_get_name(fun), str_error(rc));
    289283                ddf_fun_destroy(fun);
    290284                return rc;
     
    292286
    293287        usb_log_debug("Adding DDF function `%s' to category %s...\n",
    294             fun->name, HID_MOUSE_CATEGORY);
     288            ddf_fun_get_name(fun), HID_MOUSE_CATEGORY);
    295289        rc = ddf_fun_add_to_category(fun, HID_MOUSE_CATEGORY);
    296290        if (rc != EOK) {
     
    302296        }
    303297        mouse->mouse_fun = fun;
    304 
    305298        return EOK;
    306299}
     
    345338        return highest_button;
    346339}
    347 /*----------------------------------------------------------------------------*/
     340
    348341int usb_mouse_init(usb_hid_dev_t *hid_dev, void **data)
    349342{
     
    379372        }
    380373
    381         // set handler for incoming calls
    382         mouse_dev->ops.default_handler = default_connection_handler;
    383 
    384374        // TODO: how to know if the device supports the request???
    385375        usbhid_req_set_idle(&hid_dev->usb_dev->ctrl_pipe,
     
    398388        return EOK;
    399389}
    400 /*----------------------------------------------------------------------------*/
     390
    401391bool usb_mouse_polling_callback(usb_hid_dev_t *hid_dev, void *data)
    402392{
     
    411401        return usb_mouse_process_report(hid_dev, mouse_dev);
    412402}
    413 /*----------------------------------------------------------------------------*/
     403
    414404void usb_mouse_deinit(usb_hid_dev_t *hid_dev, void *data)
    415405{
     
    430420
    431421        free(mouse_dev->buttons);
    432         free(mouse_dev);
    433 }
    434 /*----------------------------------------------------------------------------*/
     422}
     423
    435424int usb_mouse_set_boot_protocol(usb_hid_dev_t *hid_dev)
    436425{
Note: See TracChangeset for help on using the changeset viewer.