As I dug my own way through the documentation of libusb 2.0 that ships
with FreeBSD 8+ as the OS'es own USB library API, I noticed there are
only few code examples around under /usr/src (namely, usbconfig
itself).
The libusb20(3) man page is a starting point, but it's a reference
manual, nothing less, nothing more. Using just a reference, it's not
very easy to start writing your own code based on that.
So I started writing my own examples, to "get a feeling" about how to
use the library. I covered two typical scenarios which are common for
a number of devices.
The first one is called "bulk", and uses bulk output (host to device)
and input transfers to talk to an USB device.
The second one is called "control", and can use both control output
and input transfers, as well as so-called interrupt transfers. The
latter are used for data that are being reported frequently or
repeatedly, like position updates from a pointing device (mouse).
Despite of its name, the host has to poll devices for their interrupt
transfers on each USB frame (i.e., each 1 ms).
Recommended reading is the USB 3.0 specification (the older 2.0 one
would do as well), to be found under
http://www.usb.org/developers/docs/
as well as documents for individual USB device classes where
appropriate.
Feel free to be liberal in the licensing of these examples: while the
beer-ware license mandates to keep the license notice, this only
applies to modifications of the original examples itself. For
copy&pasting (even a larger) piece of an example into your own work, I
won't imply you have to reproduce the beer-ware license text there.
Feel free to credit my name in your derived work if you want.
Dresden, July 2012
Joerg Wunsch <joerg@FreeBSD.org>
# $FreeBSD$