Ignore:
File:
1 edited

Legend:

Unmodified
Added
Removed
  • uspace/drv/bus/usb/usbhid/generic/hiddev.c

    r9d58539 r3e6a98c5  
    3535 */
    3636
     37/* XXX Fix this */
     38#define _DDF_DATA_IMPLANT
     39
    3740#include <usb/debug.h>
    3841#include <usb/classes/classes.h>
    3942#include <errno.h>
    4043#include <str_error.h>
    41 #include <bool.h>
     44#include <stdbool.h>
    4245
    4346#include <usbhid_iface.h>
     
    4649#include "usbhid.h"
    4750
    48 /*----------------------------------------------------------------------------*/
     51
    4952
    5053const usb_endpoint_description_t usb_hid_generic_poll_endpoint_description = {
     
    6063const char *HID_GENERIC_CLASS_NAME = "hid";
    6164
    62 /*----------------------------------------------------------------------------*/
     65
    6366static size_t usb_generic_hid_get_event_length(ddf_fun_t *fun);
    6467static int usb_generic_hid_get_event(ddf_fun_t *fun, uint8_t *buffer,
     
    6871static int usb_generic_get_report_descriptor(ddf_fun_t *fun, uint8_t *desc,
    6972    size_t size, size_t *actual_size);
    70 /*----------------------------------------------------------------------------*/
     73
    7174static usbhid_iface_t usb_generic_iface = {
    7275        .get_event = usb_generic_hid_get_event,
     
    7578        .get_report_descriptor = usb_generic_get_report_descriptor
    7679};
    77 /*----------------------------------------------------------------------------*/
     80
    7881static ddf_dev_ops_t usb_generic_hid_ops = {
    7982        .interfaces[USBHID_DEV_IFACE] = &usb_generic_iface,
    8083        .open = usb_generic_hid_client_connected
    8184};
    82 /*----------------------------------------------------------------------------*/
     85
     86/** Return hid_dev_t * for generic HID function node.
     87 *
     88 * For the generic HID subdriver the 'hid' function has usb_hid_gen_fun_t
     89 * as soft state. Through that we can get to the usb_hid_dev_t.
     90 */
     91static usb_hid_dev_t *fun_hid_dev(ddf_fun_t *fun)
     92{
     93        return ((usb_hid_gen_fun_t *)ddf_fun_data_get(fun))->hid_dev;
     94}
     95
    8396static size_t usb_generic_hid_get_event_length(ddf_fun_t *fun)
    8497{
    8598        usb_log_debug2("Generic HID: Get event length (fun: %p, "
    86             "fun->driver_data: %p.\n", fun, fun->driver_data);
    87 
    88         if (fun == NULL || fun->driver_data == NULL) {
    89                 return 0;
    90         }
    91 
    92         const usb_hid_dev_t *hid_dev = fun->driver_data;
     99            "fun->driver_data: %p.\n", fun, ddf_fun_data_get(fun));
     100
     101        const usb_hid_dev_t *hid_dev = fun_hid_dev(fun);
    93102
    94103        usb_log_debug2("hid_dev: %p, Max input report size (%zu).\n",
     
    97106        return hid_dev->max_input_report_size;
    98107}
    99 /*----------------------------------------------------------------------------*/
     108
    100109static int usb_generic_hid_get_event(ddf_fun_t *fun, uint8_t *buffer,
    101110    size_t size, size_t *act_size, int *event_nr, unsigned int flags)
     
    103112        usb_log_debug2("Generic HID: Get event.\n");
    104113
    105         if (fun == NULL || fun->driver_data == NULL || buffer == NULL
    106             || act_size == NULL || event_nr == NULL) {
     114        if (buffer == NULL || act_size == NULL || event_nr == NULL) {
    107115                usb_log_debug("No function");
    108116                return EINVAL;
    109117        }
    110118
    111         const usb_hid_dev_t *hid_dev = (usb_hid_dev_t *)fun->driver_data;
     119        const usb_hid_dev_t *hid_dev = fun_hid_dev(fun);
    112120
    113121        if (hid_dev->input_report_size > size) {
     
    127135        return EOK;
    128136}
    129 /*----------------------------------------------------------------------------*/
     137
    130138static size_t usb_generic_get_report_descriptor_length(ddf_fun_t *fun)
    131139{
    132140        usb_log_debug("Generic HID: Get report descriptor length.\n");
    133141
    134         if (fun == NULL || fun->driver_data == NULL) {
    135                 usb_log_debug("No function");
    136                 return EINVAL;
    137         }
    138 
    139         const usb_hid_dev_t *hid_dev = fun->driver_data;
     142        const usb_hid_dev_t *hid_dev = fun_hid_dev(fun);
    140143
    141144        usb_log_debug2("hid_dev->report_desc_size = %zu\n",
     
    144147        return hid_dev->report_desc_size;
    145148}
    146 /*----------------------------------------------------------------------------*/
     149
    147150static int usb_generic_get_report_descriptor(ddf_fun_t *fun, uint8_t *desc,
    148151    size_t size, size_t *actual_size)
     
    150153        usb_log_debug2("Generic HID: Get report descriptor.\n");
    151154
    152         if (fun == NULL || fun->driver_data == NULL) {
    153                 usb_log_debug("No function");
    154                 return EINVAL;
    155         }
    156 
    157         const usb_hid_dev_t *hid_dev = fun->driver_data;
     155        const usb_hid_dev_t *hid_dev = fun_hid_dev(fun);
    158156
    159157        if (hid_dev->report_desc_size > size) {
     
    166164        return EOK;
    167165}
    168 /*----------------------------------------------------------------------------*/
     166
    169167static int usb_generic_hid_client_connected(ddf_fun_t *fun)
    170168{
     
    172170        return EOK;
    173171}
    174 /*----------------------------------------------------------------------------*/
     172
    175173void usb_generic_hid_deinit(usb_hid_dev_t *hid_dev, void *data)
    176174{
     
    183181                return;
    184182        }
    185         usb_log_debug2("%s unbound.\n", fun->name);
    186         /* We did not allocate this, so leave this alone
    187          * the device would take care of it */
    188         fun->driver_data = NULL;
     183        usb_log_debug2("%s unbound.\n", ddf_fun_get_name(fun));
    189184        ddf_fun_destroy(fun);
    190185}
    191 /*----------------------------------------------------------------------------*/
     186
    192187int usb_generic_hid_init(usb_hid_dev_t *hid_dev, void **data)
    193188{
     189        usb_hid_gen_fun_t *hid_fun;
     190
    194191        if (hid_dev == NULL) {
    195192                return EINVAL;
     
    205202        }
    206203
    207         /* This is nasty, both device and this function have the same
    208          * driver data, thus destruction causes to double free */
    209         fun->driver_data = hid_dev;
    210         fun->ops = &usb_generic_hid_ops;
     204        /* Create softstate */
     205        hid_fun = ddf_fun_data_alloc(fun, sizeof(usb_hid_gen_fun_t));
     206        hid_fun->hid_dev = hid_dev;
     207        ddf_fun_set_ops(fun, &usb_generic_hid_ops);
    211208
    212209        int rc = ddf_fun_bind(fun);
     
    214211                usb_log_error("Could not bind DDF function: %s.\n",
    215212                    str_error(rc));
    216                 fun->driver_data = NULL;
    217213                ddf_fun_destroy(fun);
    218214                return rc;
    219215        }
    220216
    221         usb_log_debug("HID function created. Handle: %" PRIun "\n", fun->handle);
     217        usb_log_debug("HID function created. Handle: %" PRIun "\n",
     218            ddf_fun_get_handle(fun));
    222219        *data = fun;
    223220
    224221        return EOK;
    225222}
    226 /*----------------------------------------------------------------------------*/
     223
    227224bool usb_generic_hid_polling_callback(usb_hid_dev_t *hid_dev, void *data)
    228225{
Note: See TracChangeset for help on using the changeset viewer.