Changeset 6843a9c in mainline for uspace/drv/bus/usb/usbhid/main.c
- Timestamp:
- 2012-06-29T13:02:14Z (13 years ago)
- Branches:
- lfn, master, serial, ticket/834-toolchain-update, topic/msim-upgrade, topic/simplify-dev-export
- Children:
- 722912e
- Parents:
- ba72f2b (diff), 0bbd13e (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/main.c
rba72f2b r6843a9c 46 46 #include "usbhid.h" 47 47 48 /*----------------------------------------------------------------------------*/49 50 48 #define NAME "usbhid" 51 49 52 50 /** 53 * Function for adding a new device of type USB/HID/keyboard.51 * Callback for passing a new device to the driver. 54 52 * 55 * This functions initializes required structures from the device's descriptors 56 * and starts new fibril for polling the keyboard for events and another one for 57 * handling auto-repeat of keys. 53 * @note Currently, only boot-protocol keyboards are supported by this driver. 58 54 * 59 * During initialization, the keyboard is switched into boot protocol, the idle 60 * rate is set to 0 (infinity), resulting in the keyboard only reporting event 61 * when a key is pressed or released. Finally, the LED lights are turned on 62 * according to the default setup of lock keys. 63 * 64 * @note By default, the keyboards is initialized with Num Lock turned on and 65 * other locks turned off. 66 * @note Currently supports only boot-protocol keyboards. 67 * 68 * @param dev Device to add. 69 * 70 * @retval EOK if successful. 71 * @retval ENOMEM if there 72 * @return Other error code inherited from one of functions usb_kbd_init(), 73 * ddf_fun_bind() and ddf_fun_add_to_class(). 55 * @param dev Structure representing the new device. 56 * @return Error code. 74 57 */ 75 static int usb_hid_ try_add_device(usb_device_t *dev)58 static int usb_hid_device_add(usb_device_t *dev) 76 59 { 77 assert(dev != NULL);60 usb_log_debug("%s\n", __FUNCTION__); 78 61 79 /* Initialize device (get and process descriptors, get address, etc.) */ 80 usb_log_debug("Initializing USB/HID device...\n"); 62 if (dev == NULL) { 63 usb_log_error("Wrong parameter given for add_device().\n"); 64 return EINVAL; 65 } 81 66 67 if (dev->interface_no < 0) { 68 usb_log_error("Failed to add HID device: endpoints not found." 69 "\n"); 70 return ENOTSUP; 71 } 82 72 usb_hid_dev_t *hid_dev = 83 73 usb_device_data_alloc(dev, sizeof(usb_hid_dev_t)); 84 74 if (hid_dev == NULL) { 85 usb_log_error("Error while creating USB/HID device " 86 "structure.\n"); 75 usb_log_error("Failed to create USB/HID device structure.\n"); 87 76 return ENOMEM; 88 77 } 89 78 90 79 int rc = usb_hid_init(hid_dev, dev); 91 92 80 if (rc != EOK) { 93 81 usb_log_error("Failed to initialize USB/HID device.\n"); … … 98 86 usb_log_debug("USB/HID device structure initialized.\n"); 99 87 100 /*101 * 1) subdriver vytvori vlastnu ddf_fun, vlastne ddf_dev_ops, ktore da102 * do nej.103 * 2) do tych ops do .interfaces[DEV_IFACE_USBHID (asi)] priradi104 * vyplnenu strukturu usbhid_iface_t.105 * 3) klientska aplikacia - musi si rucne vytvorit telefon106 * (devman_device_connect() - cesta k zariadeniu (/hw/pci0/...) az107 * k tej fcii.108 * pouzit usb/classes/hid/iface.h - prvy int je telefon109 */110 111 88 /* Start automated polling function. 112 89 * This will create a separate fibril that will query the device 113 * for the data continuously 114 */ 90 * for the data continuously. */ 115 91 rc = usb_device_auto_poll(dev, 116 92 /* Index of the polling pipe. */ … … 119 95 usb_hid_polling_callback, 120 96 /* How much data to request. */ 121 dev->pipes[hid_dev->poll_pipe_index].pipe ->max_packet_size,97 dev->pipes[hid_dev->poll_pipe_index].pipe.max_packet_size, 122 98 /* Callback when the polling ends. */ 123 99 usb_hid_polling_ended_callback, … … 133 109 hid_dev->running = true; 134 110 135 /*136 * Hurrah, device is initialized.137 */138 return EOK;139 }140 141 /*----------------------------------------------------------------------------*/142 /**143 * Callback for passing a new device to the driver.144 *145 * @note Currently, only boot-protocol keyboards are supported by this driver.146 *147 * @param dev Structure representing the new device.148 *149 * @retval EOK if successful.150 * @retval EREFUSED if the device is not supported.151 */152 static int usb_hid_device_add(usb_device_t *dev)153 {154 usb_log_debug("usb_hid_device_add()\n");155 156 if (dev == NULL) {157 usb_log_warning("Wrong parameter given for add_device().\n");158 return EINVAL;159 }160 161 if (dev->interface_no < 0) {162 usb_log_warning("Device is not a supported HID device.\n");163 usb_log_error("Failed to add HID device: endpoints not found."164 "\n");165 return ENOTSUP;166 }167 168 int rc = usb_hid_try_add_device(dev);169 170 if (rc != EOK) {171 usb_log_warning("Device is not a supported HID device.\n");172 usb_log_error("Failed to add HID device: %s.\n",173 str_error(rc));174 return rc;175 }176 177 111 usb_log_info("HID device `%s' ready to use.\n", dev->ddf_dev->name); 178 112 179 113 return EOK; 180 114 } 181 182 115 /*----------------------------------------------------------------------------*/ 183 116 /** 117 * Callback for a device about to be removed from the driver. 118 * 119 * @param dev Structure representing the device. 120 * @return Error code. 121 */ 122 static int usb_hid_device_rem(usb_device_t *dev) 123 { 124 // TODO: Stop device polling 125 // TODO: Call deinit (stops autorepeat too) 126 return ENOTSUP; 127 } 128 /*----------------------------------------------------------------------------*/ 184 129 /** 185 130 * Callback for removing a device from the driver. 186 131 * 187 132 * @param dev Structure representing the device. 188 * 189 * @retval EOK if successful. 190 * @retval EREFUSED if the device is not supported. 133 * @return Error code. 191 134 */ 192 135 static int usb_hid_device_gone(usb_device_t *dev) 193 136 { 137 assert(dev); 138 assert(dev->driver_data); 194 139 usb_hid_dev_t *hid_dev = dev->driver_data; 195 unsigned tries = 10; 196 while (hid_dev->running) { 140 unsigned tries = 100; 141 /* Wait for fail. */ 142 while (hid_dev->running && tries--) { 197 143 async_usleep(100000); 198 if (!tries--) {199 usb_log_error("Can't remove hub, still running.\n");200 return EINPROGRESS;201 }144 } 145 if (hid_dev->running) { 146 usb_log_error("Can't remove hid, still running.\n"); 147 return EBUSY; 202 148 } 203 149 204 assert(!hid_dev->running);205 150 usb_hid_deinit(hid_dev); 206 151 usb_log_debug2("%s destruction complete.\n", dev->ddf_dev->name); 207 152 return EOK; 208 153 } 209 154 /*----------------------------------------------------------------------------*/ 210 155 /** USB generic driver callbacks */ 211 static usb_driver_ops_t usb_hid_driver_ops = {156 static const usb_driver_ops_t usb_hid_driver_ops = { 212 157 .device_add = usb_hid_device_add, 158 .device_rem = usb_hid_device_rem, 213 159 .device_gone = usb_hid_device_gone, 214 160 }; 215 216 161 /*----------------------------------------------------------------------------*/ 217 162 /** The driver itself. */ 218 static usb_driver_t usb_hid_driver = {163 static const usb_driver_t usb_hid_driver = { 219 164 .name = NAME, 220 165 .ops = &usb_hid_driver_ops, 221 166 .endpoints = usb_hid_endpoints 222 167 }; 223 224 168 /*----------------------------------------------------------------------------*/ 225 226 169 int main(int argc, char *argv[]) 227 170 { … … 232 175 return usb_driver_main(&usb_hid_driver); 233 176 } 234 235 177 /** 236 178 * @}
Note:
See TracChangeset
for help on using the changeset viewer.