X-Git-Url: http://git.linex4red.de/pub/USBasp.git/blobdiff_plain/d1e52660368d34d693131f6aff3c8fd8584162e5..3d6508c9b9505cb3393b7c12df1a0c87f7828bbe:/LUFA/Drivers/USB/USB.h?ds=sidebyside diff --git a/LUFA/Drivers/USB/USB.h b/LUFA/Drivers/USB/USB.h index 3c8f06237..0d0a3f784 100644 --- a/LUFA/Drivers/USB/USB.h +++ b/LUFA/Drivers/USB/USB.h @@ -51,27 +51,97 @@ * - LUFA/Drivers/USB/HighLevel/ConfigDescriptor.c * * \section Module Description - * Functions, macros, variables, enums and types related to the management of USB communications. + * Driver and framework for the USB controller hardware on the USB series of AVR microcontrollers. This module + * consists of many submodules, and is designed to provide an easy way to configure and control USB host, device + * or OTG mode USB applications. + * + * The USB stack requires the sole control over the USB controller in the microcontroller only; i.e. it does not + * require any additional AVR timers, etc. to operate. This ensures that the USB stack requires as few resources + * as possible. + * + * The USB stack can be used in Device Mode for connections to USB Hosts (see \ref Group_Device), in Host mode for + * hosting of other USB devices (see \ref Group_Host), or as a dual role device which can either act as a USB host + * or device depending on what peripheral is connected (see \ref Group_OTG). Both modes also require a common set + * of USB management functions found \ref Group_USBManagement. */ +/** \ingroup Group_USB + * @defgroup Group_USBClassDrivers USB Class Drivers + * + * Drivers for both host and device mode of the standard USB classes, for rapid application development. + * Class drivers give a framework which sits on top of the low level library API, allowing for standard + * USB classes to be implemented in a project with minimal user code. These drivers can be used in + * conjunction with the library low level APIs to implement interfaces both via the class drivers and via + * the standard library APIs. + * + * Multiple device mode class drivers can be used within a project, including multiple instances of the + * same class driver. In this way, USB Hosts and Devices can be made quickly using the internal class drivers + * so that more time and effort can be put into the end application instead of the USB protocol. + * + * The available class drivers and their modes are listed below. + * + *
USB Class | + *Device Mode | + *Host Mode | + *
---|---|---|
Audio | + *Yes | + *No | + *
CDC | + *Yes | + *Yes | + *
HID | + *Yes | + *Yes | + *
MIDI | + *Yes | + *Yes | + *
Mass Storage | + *Yes | + *Yes | + *
Printer | + *No | +*Yes | + *
RNDIS | + *Yes | + *Yes | + *
Still Image | + *No | + *Yes | + *