1.. _writing-usb-driver: 2 3========================== 4Writing USB Device Drivers 5========================== 6 7:Author: Greg Kroah-Hartman 8 9Introduction 10============ 11 12The Linux USB subsystem has grown from supporting only two different 13types of devices in the 2.2.7 kernel (mice and keyboards), to over 20 14different types of devices in the 2.4 kernel. Linux currently supports 15almost all USB class devices (standard types of devices like keyboards, 16mice, modems, printers and speakers) and an ever-growing number of 17vendor-specific devices (such as USB to serial converters, digital 18cameras, Ethernet devices and MP3 players). For a full list of the 19different USB devices currently supported, see Resources. 20 21The remaining kinds of USB devices that do not have support on Linux are 22almost all vendor-specific devices. Each vendor decides to implement a 23custom protocol to talk to their device, so a custom driver usually 24needs to be created. Some vendors are open with their USB protocols and 25help with the creation of Linux drivers, while others do not publish 26them, and developers are forced to reverse-engineer. See Resources for 27some links to handy reverse-engineering tools. 28 29Because each different protocol causes a new driver to be created, I 30have written a generic USB driver skeleton, modelled after the 31pci-skeleton.c file in the kernel source tree upon which many PCI 32network drivers have been based. This USB skeleton can be found at 33drivers/usb/usb-skeleton.c in the kernel source tree. In this article I 34will walk through the basics of the skeleton driver, explaining the 35different pieces and what needs to be done to customize it to your 36specific device. 37 38Linux USB Basics 39================ 40 41If you are going to write a Linux USB driver, please become familiar 42with the USB protocol specification. It can be found, along with many 43other useful documents, at the USB home page (see Resources). An 44excellent introduction to the Linux USB subsystem can be found at the 45USB Working Devices List (see Resources). It explains how the Linux USB 46subsystem is structured and introduces the reader to the concept of USB 47urbs (USB Request Blocks), which are essential to USB drivers. 48 49The first thing a Linux USB driver needs to do is register itself with 50the Linux USB subsystem, giving it some information about which devices 51the driver supports and which functions to call when a device supported 52by the driver is inserted or removed from the system. All of this 53information is passed to the USB subsystem in the :c:type:`usb_driver` 54structure. The skeleton driver declares a :c:type:`usb_driver` as:: 55 56 static struct usb_driver skel_driver = { 57 .name = "skeleton", 58 .probe = skel_probe, 59 .disconnect = skel_disconnect, 60 .suspend = skel_suspend, 61 .resume = skel_resume, 62 .pre_reset = skel_pre_reset, 63 .post_reset = skel_post_reset, 64 .id_table = skel_table, 65 .supports_autosuspend = 1, 66 }; 67 68 69The variable name is a string that describes the driver. It is used in 70informational messages printed to the system log. The probe and 71disconnect function pointers are called when a device that matches the 72information provided in the ``id_table`` variable is either seen or 73removed. 74 75The fops and minor variables are optional. Most USB drivers hook into 76another kernel subsystem, such as the SCSI, network or TTY subsystem. 77These types of drivers register themselves with the other kernel 78subsystem, and any user-space interactions are provided through that 79interface. But for drivers that do not have a matching kernel subsystem, 80such as MP3 players or scanners, a method of interacting with user space 81is needed. The USB subsystem provides a way to register a minor device 82number and a set of :c:type:`file_operations` function pointers that enable 83this user-space interaction. The skeleton driver needs this kind of 84interface, so it provides a minor starting number and a pointer to its 85:c:type:`file_operations` functions. 86 87The USB driver is then registered with a call to usb_register(), 88usually in the driver's init function, as shown here:: 89 90 static int __init usb_skel_init(void) 91 { 92 int result; 93 94 /* register this driver with the USB subsystem */ 95 result = usb_register(&skel_driver); 96 if (result < 0) { 97 err("usb_register failed for the "__FILE__ "driver." 98 "Error number %d", result); 99 return -1; 100 } 101 102 return 0; 103 } 104 module_init(usb_skel_init); 105 106 107When the driver is unloaded from the system, it needs to deregister 108itself with the USB subsystem. This is done with usb_deregister() 109function:: 110 111 static void __exit usb_skel_exit(void) 112 { 113 /* deregister this driver with the USB subsystem */ 114 usb_deregister(&skel_driver); 115 } 116 module_exit(usb_skel_exit); 117 118 119To enable the linux-hotplug system to load the driver automatically when 120the device is plugged in, you need to create a ``MODULE_DEVICE_TABLE``. 121The following code tells the hotplug scripts that this module supports a 122single device with a specific vendor and product ID:: 123 124 /* table of devices that work with this driver */ 125 static struct usb_device_id skel_table [] = { 126 { USB_DEVICE(USB_SKEL_VENDOR_ID, USB_SKEL_PRODUCT_ID) }, 127 { } /* Terminating entry */ 128 }; 129 MODULE_DEVICE_TABLE (usb, skel_table); 130 131 132There are other macros that can be used in describing a struct 133:c:type:`usb_device_id` for drivers that support a whole class of USB 134drivers. See :ref:`usb.h <usb_header>` for more information on this. 135 136Device operation 137================ 138 139When a device is plugged into the USB bus that matches the device ID 140pattern that your driver registered with the USB core, the probe 141function is called. The :c:type:`usb_device` structure, interface number and 142the interface ID are passed to the function:: 143 144 static int skel_probe(struct usb_interface *interface, 145 const struct usb_device_id *id) 146 147 148The driver now needs to verify that this device is actually one that it 149can accept. If so, it returns 0. If not, or if any error occurs during 150initialization, an errorcode (such as ``-ENOMEM`` or ``-ENODEV``) is 151returned from the probe function. 152 153In the skeleton driver, we determine what end points are marked as 154bulk-in and bulk-out. We create buffers to hold the data that will be 155sent and received from the device, and a USB urb to write data to the 156device is initialized. 157 158Conversely, when the device is removed from the USB bus, the disconnect 159function is called with the device pointer. The driver needs to clean 160any private data that has been allocated at this time and to shut down 161any pending urbs that are in the USB system. 162 163Now that the device is plugged into the system and the driver is bound 164to the device, any of the functions in the :c:type:`file_operations` structure 165that were passed to the USB subsystem will be called from a user program 166trying to talk to the device. The first function called will be open, as 167the program tries to open the device for I/O. We increment our private 168usage count and save a pointer to our internal structure in the file 169structure. This is done so that future calls to file operations will 170enable the driver to determine which device the user is addressing. All 171of this is done with the following code:: 172 173 /* increment our usage count for the module */ 174 ++skel->open_count; 175 176 /* save our object in the file's private structure */ 177 file->private_data = dev; 178 179 180After the open function is called, the read and write functions are 181called to receive and send data to the device. In the ``skel_write`` 182function, we receive a pointer to some data that the user wants to send 183to the device and the size of the data. The function determines how much 184data it can send to the device based on the size of the write urb it has 185created (this size depends on the size of the bulk out end point that 186the device has). Then it copies the data from user space to kernel 187space, points the urb to the data and submits the urb to the USB 188subsystem. This can be seen in the following code:: 189 190 /* we can only write as much as 1 urb will hold */ 191 bytes_written = (count > skel->bulk_out_size) ? skel->bulk_out_size : count; 192 193 /* copy the data from user space into our urb */ 194 copy_from_user(skel->write_urb->transfer_buffer, buffer, bytes_written); 195 196 /* set up our urb */ 197 usb_fill_bulk_urb(skel->write_urb, 198 skel->dev, 199 usb_sndbulkpipe(skel->dev, skel->bulk_out_endpointAddr), 200 skel->write_urb->transfer_buffer, 201 bytes_written, 202 skel_write_bulk_callback, 203 skel); 204 205 /* send the data out the bulk port */ 206 result = usb_submit_urb(skel->write_urb); 207 if (result) { 208 err("Failed submitting write urb, error %d", result); 209 } 210 211 212When the write urb is filled up with the proper information using the 213:c:func:`usb_fill_bulk_urb` function, we point the urb's completion callback 214to call our own ``skel_write_bulk_callback`` function. This function is 215called when the urb is finished by the USB subsystem. The callback 216function is called in interrupt context, so caution must be taken not to 217do very much processing at that time. Our implementation of 218``skel_write_bulk_callback`` merely reports if the urb was completed 219successfully or not and then returns. 220 221The read function works a bit differently from the write function in 222that we do not use an urb to transfer data from the device to the 223driver. Instead we call the :c:func:`usb_bulk_msg` function, which can be used 224to send or receive data from a device without having to create urbs and 225handle urb completion callback functions. We call the :c:func:`usb_bulk_msg` 226function, giving it a buffer into which to place any data received from 227the device and a timeout value. If the timeout period expires without 228receiving any data from the device, the function will fail and return an 229error message. This can be shown with the following code:: 230 231 /* do an immediate bulk read to get data from the device */ 232 retval = usb_bulk_msg (skel->dev, 233 usb_rcvbulkpipe (skel->dev, 234 skel->bulk_in_endpointAddr), 235 skel->bulk_in_buffer, 236 skel->bulk_in_size, 237 &count, 5000); 238 /* if the read was successful, copy the data to user space */ 239 if (!retval) { 240 if (copy_to_user (buffer, skel->bulk_in_buffer, count)) 241 retval = -EFAULT; 242 else 243 retval = count; 244 } 245 246 247The :c:func:`usb_bulk_msg` function can be very useful for doing single reads 248or writes to a device; however, if you need to read or write constantly to 249a device, it is recommended to set up your own urbs and submit them to 250the USB subsystem. 251 252When the user program releases the file handle that it has been using to 253talk to the device, the release function in the driver is called. In 254this function we decrement our private usage count and wait for possible 255pending writes:: 256 257 /* decrement our usage count for the device */ 258 --skel->open_count; 259 260 261One of the more difficult problems that USB drivers must be able to 262handle smoothly is the fact that the USB device may be removed from the 263system at any point in time, even if a program is currently talking to 264it. It needs to be able to shut down any current reads and writes and 265notify the user-space programs that the device is no longer there. The 266following code (function ``skel_delete``) is an example of how to do 267this:: 268 269 static inline void skel_delete (struct usb_skel *dev) 270 { 271 kfree (dev->bulk_in_buffer); 272 if (dev->bulk_out_buffer != NULL) 273 usb_free_coherent (dev->udev, dev->bulk_out_size, 274 dev->bulk_out_buffer, 275 dev->write_urb->transfer_dma); 276 usb_free_urb (dev->write_urb); 277 kfree (dev); 278 } 279 280 281If a program currently has an open handle to the device, we reset the 282flag ``device_present``. For every read, write, release and other 283functions that expect a device to be present, the driver first checks 284this flag to see if the device is still present. If not, it releases 285that the device has disappeared, and a ``-ENODEV`` error is returned to the 286user-space program. When the release function is eventually called, it 287determines if there is no device and if not, it does the cleanup that 288the ``skel_disconnect`` function normally does if there are no open files 289on the device (see Listing 5). 290 291Isochronous Data 292================ 293 294This usb-skeleton driver does not have any examples of interrupt or 295isochronous data being sent to or from the device. Interrupt data is 296sent almost exactly as bulk data is, with a few minor exceptions. 297Isochronous data works differently with continuous streams of data being 298sent to or from the device. The audio and video camera drivers are very 299good examples of drivers that handle isochronous data and will be useful 300if you also need to do this. 301 302Conclusion 303========== 304 305Writing Linux USB device drivers is not a difficult task as the 306usb-skeleton driver shows. This driver, combined with the other current 307USB drivers, should provide enough examples to help a beginning author 308create a working driver in a minimal amount of time. The linux-usb-devel 309mailing list archives also contain a lot of helpful information. 310 311Resources 312========= 313 314The Linux USB Project: 315http://www.linux-usb.org/ 316 317Linux Hotplug Project: 318http://linux-hotplug.sourceforge.net/ 319 320linux-usb Mailing List Archives: 321https://lore.kernel.org/linux-usb/ 322 323Programming Guide for Linux USB Device Drivers: 324https://lmu.web.psi.ch/docu/manuals/software_manuals/linux_sl/usb_linux_programming_guide.pdf 325 326USB Home Page: https://www.usb.org 327