]> git.donarmstrong.com Git - qmk_firmware.git/blob - lib/lufa/LUFA/DoxygenPages/ChangeLog.txt
Merge commit '60b30c036397cb5627fa374bb930794b225daa29' as 'lib/lufa'
[qmk_firmware.git] / lib / lufa / LUFA / DoxygenPages / ChangeLog.txt
1 /** \file
2  *
3  *  This file contains special DoxyGen information for the generation of the main page and other special
4  *  documentation pages. It is not a project source file.
5  */
6
7  /** \page Page_ChangeLog Project Changelog
8   *
9   *  \section Sec_ChangeLog170418 Version 170418
10   *  <b>New:</b>
11   *  - Core:
12   *   - Added support for the Pololu A-Star Micro board (thanks to Joh Schneider)
13   *   - Added new \c LUFA_VERSION_RELEASE_TYPE macro to the library version header, to determine release type (thanks to NicoHood)
14   *
15   *  <b>Fixed:</b>
16   *  - Core:
17   *   - The CALLBACK_USB_GetDescriptor() callback function into the user application erroneously had a uint8_t type for the wIndex
18   *     parameter, instead of uint16_t (thanks to Matlo)
19   *   - Fixed broken USE_RAM_DESCRIPTORS compile time option when the FIXED_NUM_CONFIGURATIONS compile time option is not enabled
20   *     in a user application (thanks to Matlo)
21   *   - Fixed missing \c va_end() calls in the HID bootloader CLI app which could cause portability issues
22   *   - Fixed void pointer arithmetic in the \c Serial_SendData() functions for AVR8 and XMEGA architectures
23   *   - Fixed void pointer arithmetic in the low level and class driver RNDIS demo protocol decoders
24   *   - Fixed low level RNDIS demo incorrectly setting the RNDIS state when a null packet filter was requested
25   *   - Fixed missing entries in several project's Atmel Studio integration files, such as driver INF files
26   *   - Fixed invalid endpoint indexes causing memory corruption in device Clear/Set Feature standard requests (thanks to Peter Popovec)
27   *   - Fixed incorrect serialization in USB_SetHIDReportItemInfo() function (thanks to e-chip)
28   *
29   *  <b>Changed:</b>
30   *   - Added signed alternative libUSB driver for the AVRISP-MKII clone project, to support Atmel Studio 7 (thanks to Atmel)
31   *   - Removed no longer required LIBUSB_DRIVER_COMPAT and RESET_TOGGLES_LIBUSB_COMPAT configuration options from the AVRISP-MKII
32   *     clone project, as the new libUSB driver works for AVRDUDE and Atmel Studio 7 under Windows
33   *   - Replaced the LUFA build system with its (compatible) successor, DMBS (Dean's Makefile Build System)
34   *   - Removed obsolete library TAR export and associated documentation
35   *   - Fixed incorrect HID_DESCRIPTOR_KEYBOARD() macro definition (thanks to Eric Tang)
36   *
37   *  \section Sec_ChangeLog151115 Version 151115
38   *  <b>New:</b>
39   *   - Added support for the Atmel Xplained-MINI series of development kits
40   *   - Added new PROGMEM variant send functions to the CDC class device driver (thanks to Stefan Hellermann)
41   *   - Added new PROGMEM variant send functions to the CDC class host driver
42   *   - Added additional Arduino Uno board definitions for the main processor reset (thanks to NicoHood)
43   *   - Added modified DocBook transforms to generate Atmel Studio 6/7 internal help documentation (thanks to Morten Engelhardt Olsen)
44   *
45   *  <b>Changed:</b>
46   *  - Core:
47   *   - The TWI peripheral driver's TWI_WritePacket() and TWI_ReadPacket() functions now takes a 16-bit Length rather than an 8-bit
48   *     length, for longer transfers
49   *  - Library Applications:
50   *   - The CDC, DFU, Mass Storage and Printer class bootloaders will no longer run the user application if the application reset
51   *     vector is blank (thanks to Alex Kazik)
52   *   - The CDC, DFU and Printer class bootloaders are now compatible with the original Atmel XPLAIN and Arduino Leonardo boards
53   *   - The CDC, DFU, Mass Storage and Printer class bootloaders are not compatible with devices with the BOOTRST fuse set and will
54   *     exit automatically unless an external reset was the last reset cause (thanks to Alex Kazik)
55   *   - Added missing force-inline attribute to the endianness utility functions (thanks to Stefan Hellermann)
56   *   - Updated the DFU build system module to use updated EEPROM programming command arguments for dfu-programmer 0.6.2 or newer
57   *
58   *  <b>Fixed:</b>
59   *   - Fixed broken XMEGA serial stream driver due to missing USART base pointer parameter (thanks to William Patterson)
60   *   - Fixed incorrect signature reported in the CDC/DFU bootloaders for the AT90USB82 (thanks to NicoHood)
61   *   - Fixed broken RNDIS demos on Linux machines whose DHCP hosts require a Lease Time option (thanks to Stefan Hellermann)
62   *   - Fixed broken LEDs_Disable() implementation for the Arduino Uno board (thanks to NicoHood)
63   *   - Fixed missing bounds checks and off-by-one in the DFU bootloader signature bytes (thanks to Reuti)
64   *
65   *  \section Sec_ChangeLog140928 Version 140928
66   *  <b>New:</b>
67   *  - Core:
68   *   - Updated the BUILD build system module to add a new COMPILER_PATH optional variable
69   *   - Added Serial_IsSendReady() and Serial_IsSendComplete() functions to the Serial hardware peripheral driver
70   *   - Added support for the Arduino Yun board (ATMEGA32U4 co-processor)
71   *   - Added support for the Arduino Micro board (thanks to Zoltán Szőke)
72   *  - Library Applications:
73   *   - Added new Dual MIDI class driver device demo
74   *
75   *  <b>Changed:</b>
76   *  - Core:
77   *   - The RNDIS device class driver now takes a user-supplied buffer and buffer length for the internal RNDIS
78   *     message management (thanks to Peter Mc Shane)
79   *
80   *  <b>Fixed:</b>
81   *  - Core:
82   *   - Fixed device class driver pipe configuration routines returning success with a partially constructed instance
83   *     when a pipe configuration failed (thanks to Helge Suess)
84   *   - Fixed incorrect XMEGA DFLL reference frequency (thanks to Martin Aakerberg)
85   *   - Fixed possible infinite loop in the control endpoint stream write function (thanks to Clayton Knight)
86   *   - Fixed missing HID report ID prefix on HID class driver GetReport request responses (thanks to Bert van Hall)
87   *   - Fixed incorrect XMEGA USB controller clock division factory for non-Full Speed operation (thanks to Bert van Hall)
88   *   - Fixed the LUFA build system to prevent incorrect code from being generated in newer toolchains when building for larger
89   *     FLASH memory devices (thanks to demultiplexer)
90   *   - Fixed missing parenthesis in the MIDI_EVENT() macro which could cause incorrect results (thanks to hexwab)
91   *   - Fixed mixed capitalization of TWI in the XMEGA TWI driver causing compilation failures (thanks to Jacob Schloss)
92   *   - Fixed broken AVR8 USART-SPI peripheral driver (thanks to Phil Zakielarz)
93   *  - Library Applications:
94   *   - Fixed spurious 0xFE USART byte sent in the USBtoSerial project when the baud rate is changed (thanks to Carl Kjeldsen)
95   *   - Fixed blocking USART reads causing low throughput on slow baud rates in the USBtoSerial project (thanks to Nevada Smith)
96   *   - Fixed USART reception overrun corrupting the internal buffers in the USBtoSerial project (thanks to Nevada Smith)
97   *   - Fixed broken LowLevel Audio Out demo sampling frequency configuration (thanks to Torsten Duwe)
98   *
99   *  \section Sec_ChangeLog140302 Version 140302
100   *  <b>New:</b>
101   *  - Library Applications:
102   *   - Added new Bulk Vendor low level device demo
103   *   - Added new libUSB host Python and NodeJS application examples for the Class driver GenericHID demo (thanks to Laszlo Monda)
104   *   - Added new AVR8 USB option to keep 3.3V regulator enabled (thanks to Michael Hanselmann)
105   *   - Added new USB_STRING_DESCRIPTOR() and USB_STRING_DESCRIPTOR_ARRAY() convenience macros (thanks to Laszlo Monda)
106   *
107   *  <b>Changed:</b>
108   *  - Library Applications:
109   *   - Refactored out USB interface IDs in the demo applications into enums (thanks to Laszlo Monda)
110   *   - AVRISP-MKII Clone Project PDI/TPI frequency increased from 250KHz to 2MHz as it is now stable
111   *   - Increased TPI/PDI handshake delay to 100us from 1us to support targets with high amounts of capacitance on their
112   *     /RESET lines (thanks to Paul Duke)
113   *   - Changed the VERSION_BCD() macro to accept the major/minor/revision values as separate parameters
114   *
115   *  <b>Fixed:</b>
116   *  - Core:
117   *   - Fixed MIDI device class driver MIDI_Device_ReceiveEventPacket() for the XMEGA architecture
118   *  - Library Applications:
119   *   - Fixed incorrect signature bytes returned in the DFU bootloader
120   *
121   *  \section Sec_ChangeLog130901 Version 130901
122   *  <b>New:</b>
123   *  - Core:
124   *   - Added additional MIDI command definitions to the MIDI class driver (thanks to Daniel Dreibrodt)
125   *   - Added new CONCAT() and CONCAT_EXPANDED() convenience macros
126   *   - Added new Printer Device Class driver
127   *   - Added support for the XMEGA C3 Xplained board
128   *   - Added support for the U2S board (thanks to megal0maniac)
129   *   - Added TWI Master driver for the XMEGA architecture (thanks to Michael Janssen)
130   *  - Library Applications:
131   *   - Added new Printer class bootloader
132   *   - Added new Mass Storage class bootloader
133   *   - Added XMEGA support for class driver device demos (where applicable)
134   *   - Added Python host application example for the Generic HID class driver device demo
135   *   - Added Python alternative host application for the HID class bootloader
136   *
137   *  <b>Changed:</b>
138   *  - Core:
139   *   - Updated the BUILD build system module to produce binary BIN files in addition to Intel HEX files
140   *   - Updated the Android Accessory Class to accept version 2 protocol devices (with version 1 functionality)
141   *   - All board drivers now implement dummy functions and constants when BOARD is set to NONE
142   *   - Added missing LEDs to the XMEGA A3BU Xplained board LED driver (thanks to Michael Janssen)
143   *   - Changed board Dataflash drivers to automatically configure the appropriate SPI interface for the selected board
144   *  - Library Applications:
145   *   - Re-added Set Control Line State request handling to the CDC class bootloader to prevent issues with the .NET serial
146   *     class (thanks to Erik Lins)
147   *   - TemperatureDataLogger project dummy RTC mode now tracks real time (thanks to David Lazarus)
148   *
149   *  <b>Fixed:</b>
150   *  - Core:
151   *   - Fixed Low Speed USB devices broken when using the library HID Class driver (thanks to Michael)
152   *   - Fixed possible register corruption in USB Host mode on AVR8 devices when ORDERED_EP_CONFIG is used (thanks to Martin Aakerberg)
153   *   - Fixed Pipe_GetBoundEndpointAddress() returning invalid endpoint directions on AVR8 architecture devices (thanks to decerri)
154   *     under some circumstances
155   *   - Fixed incorrect USB device state set when a suspended LUFA device is woken while addressed but not configured (thanks to Balaji Krishnan)
156   *   - Fixed broken USART SPI driver for the AVR8 architecture due to incorrect initialization
157   *   - Fixed re-enumeration issue of XMEGA architecture targets (thanks to Jaroslav Jedlinsky)
158   *   - Fixed error receiving PIMA events via the Still Image Host class driver
159   *  - Library Applications:
160   *   - Added handler for SCSI_CMD_START_STOP_UNIT in demos using the Mass Storage class, to prevent ejection errors on *nix systems due to an
161   *     unknown SCSI command
162   *   - Fixed incorrect HID report descriptor generated for 16-bit axis ranges by the HID_DESCRIPTOR_MOUSE() and HID_DESCRIPTOR_JOYSTICK()
163   *     macros (thanks to Armory)
164   *   - Fixed incorrect HID report descriptor generated for button multiples of 8 by the HID_DESCRIPTOR_MOUSE() and HID_DESCRIPTOR_JOYSTICK()
165   *     macros
166   *   - Fixed race condition in the DFU class bootloader causing failed device reprogramming in some circumstances (thanks to Luis Mendes)
167   *   - Fixed incorrect time/date configuration data order in the TempDataLogger host application (thanks to David Lazarus)
168   *
169   *  \section Sec_ChangeLog130303 Version 130303
170   *  <b>New:</b>
171   *  - Core:
172   *   - Added support for the Arduino Leonardo board
173   *   - Added support for the Atmel UC3-A3 Xplained board
174   *   - Added support for the Xevelabs USB2AX revision 3.1 board
175   *   - Added support for the Dimex Stange-ISP board (thanks to Gerhard Wesser)
176   *   - Added new \c doxygen_upgrade and \c doxygen_create targets to the DOXYGEN build system module
177   *   - Added new Board Hardware Information board driver
178   *  - Library Applications:
179   *   - Added a different device serial number when the AVRISP-MKII Clone project is in libUSB compatibility mode, so that
180   *     both the libUSB and Jungo drivers can be installed at the same time without having to use a filter driver
181   *
182   *  <b>Changed:</b>
183   *  - Core:
184   *   - Added workaround for broken VBUS detection on AVR8 devices when a bootloader starts the application
185   *     via a software jump without first turning off the OTG pad (thanks to Simon Inns)
186   *  - Library Applications:
187   *   - Increased throughput in the USBtoSerial project now that data transmission is non-blocking (thanks to Joseph Lacerte)
188   *   - Updated bootloader makefiles to remove dependency on the \c bc command line calculator tool
189   *   - Updated AVRISP-MKII Clone Programmer project so that the SCK clock period is saved in EEPROM (thanks to Gerhard Wesser)
190   *   - Changed all *_SendByte() function prototypes to accept a void pointer for the input buffer (thanks to Simon Kuppers)
191   *
192   *  <b>Fixed:</b>
193   *  - Core:
194   *   - Fixed incorrectly issuing STALL response to unsupported control request SETUP packets, rather than in the data/status stage
195   *   - Fixed inverted LEDs_GetLEDs() function implementation for the Benito, Minimus and Arduino UNO boards
196   *   - Fixed missing Windows 32-bit compatibility sections in the LUFA INF driver files (thanks to Christan Beharrell)
197   *   - Fixed logic hole breaking USB operations on a USB controller with only one supported USB mode and no USB_DEVICE_ONLY or USB_HOST_ONLY
198   *     configuration token set
199   *   - Fixed possible rounding in the VERSION_BCD() macros for some 0.01 step increments (thanks to Oliver Zander)
200   *   - Fixed incorrect Dataflash functionality in the USBKEY board if the driver is modified for a single Dataflash chip (thanks to Jonathan Oakley)
201   *   - Fixed incorrect definitions of \c HID_KEYBOARD_LED_KANA, \c HID_KEYBOARD_SC_KEYPAD_EQUAL_SIGN and \c HID_KEYBOARD_SC_KEYPAD_EQUAL_SIGN_AS400
202   *     and added a missing definition for \c HID_KEYBOARD_SC_APPLICATION (thanks to David Monro)
203   *   - Fixed maximum allowed keyboard key code usage of \c 0x65 rather than \c 0xFF for the \c HID_DESCRIPTOR_KEYBOARD() macro (thanks to David Monro)
204   *   - Fixed hardware race condition that could cause failed device enumerations for AVR8 and UC3 architectures (thanks to Mike Beyhs)
205   *   - Fixed incorrect Minimus board LED definitions (thanks to Joonas Lahtinen)
206   *   - Fixed incorrect ordering of the linker options in the build system causing link failures in some cases
207   *   - Fixed bug in the TWI peripheral driver for the AVR8 devices causing incorrect failure codes to be returned in some cases (thanks to Peter K)
208   *   - Fixed swapped LED3 and LED4 masks for the Olimex-32U4 development board LED driver
209   *   - Fixed potential NULL pointer dereference in the HID Host mode Class Driver (thanks to Pavel Kuzmin)
210   *  - Library Applications:
211   *   - Fixed broken RESET_TOGGLES_LIBUSB_COMPAT compile time option in the AVRISP-MKII project
212   *   - Fixed incompatibility in the CDC class bootloader on some systems (thanks to Sylvain Munaut)
213   *   - Fixed lengthy timeouts in the USBtoSerial project if no application on the host is consuming data (thanks to Nicolas Saugnier)
214   *   - Fixed lengthy automatic data flushing in the CDC and MIDI device class drivers
215   *   - Fixed incorrect LED masks for received data display in the Device GenericHID demos (thanks to Denys Berkovskyy)
216   *   - Fixed incorrect output in the HIDReportViewer project when no device is connected (thanks to Pavel Kuzmin)
217   *
218   *  \section Sec_ChangeLog120730 Version 120730
219   *  <b>New:</b>
220   *  - Core:
221   *   - Added new, revamped modular build system with new makefile templates
222   *   - Added support for the BitWizard Multio and Big-Multio boards
223   *   - Added support for the DorkbotPDX Duce board
224   *   - Added support for the Olimex AVR-USB-32U4 board
225   *   - Added support for the Olimex AVR-USB-T32U4 board
226   *   - Added support for the Olimex AVR-ISP-MK2 board
227   *   - Added new Endpoint_ConfigureEndpointTable() function
228   *   - Added new Pipe_ConfigurePipeTable() function
229   *   - Added build test to verify correct compilation of all board drivers using all driver APIs
230   *   - Added build test to verify correct compilation of all bootloaders using all supported devices
231   *   - Added build test to verify that there are no detectable errors in the codebase via static analysis
232   *   - Added new JTAG_ENABLE() macro for the AVR8 architecture
233   *  - Library Applications:
234   *   - Modified the CDC Host demos to set a default CDC Line Encoding on enumerated devices
235   *   - Added Dataflash operational checks and aborts to all projects using the Dataflash to ensure it is working correctly before use
236   *   - Added new SerialToLCD user project contributed by Simon Foster
237   *   - Added new RESET_TOGGLES_LIBUSB_COMPAT compile time option to the AVRISP-MKII clone programmer project (thanks to Robert Spitzenpfeil)
238   *
239   *  <b>Changed:</b>
240   *  - Core:
241   *   - Android Accessory Host property strings changed from a struct of pointer to an array to prevent unaligned access on greater than 8-bit architectures
242   *   - Audio Device Class driver changed to also require the index of the Audio Control interface within the device, for SET/GET/CUR/MIN/MAX/RES property adjustments
243   *   - Removed variable axis support from the HID_DESCRIPTOR_JOYSTICK() macro due to OS incompatibilities, replaced with fixed 3-axis joystick report structure
244   *   - Removed the old pseudo-scheduler from the library as it was unused and deprecated since the 090810 release
245   *   - Endpoint indexes are now specified as full endpoint addresses within the device in device mode, rather than a logical index
246   *   - The Endpoint_ConfigureEndpoint() function no longer takes an endpoint direction as a parameter, as this is now deduced from the specified full endpoint
247   *     address and type
248   *   - The Endpoint_ConfigureEndpoint() function no longer takes a number of banks as a special mask; the number of banks is now specified as an integer parameter
249   *   - Endpoints are now configured via instances of a new struct USB_Endpoint_Table_t in all device mode class drivers, rather than a list of endpoint parameters
250   *   - Pipe indexes are now specified as full pipe addresses within the host in host mode, rather than a logical index
251   *   - The Pipe_ConfigurePipe() function no longer takes an pipe token as a parameter, as this is now deduced from the specified full pipe address and type
252   *   - The Pipe_ConfigurePipe() function no longer takes a number of banks as a special mask; the number of banks is now specified as an integer parameter
253   *   - Pipes are now configured via instances of a new struct USB_Pipe_Table_t in all host mode class drivers, rather than a list of pipe parameters
254   *   - Added support for various assert and debugging macros for the UC3 devices
255   *   - Changed MIDI event structure MIDI_EventPacket_t to use a single field for the combined virtual cable index and command ID, to prevent bitfield packing issues
256   *     on some architectures (thanks to Darren Gibbs)
257   *   - Changed board LED driver implementations of LEDs_ToggleLEDs() for the AVR8 architecture to use the fast PIN register toggle alternative function for speed
258   *  - Library Applications:
259   *   - Raised the guard bits in the AVRISP-MKII clone project when in PDI and TPI to 32, to prevent communication errors on low quality connections to a target
260   *   - Added additional bootloader API data to expose the bootloader start address and class to the DFU and CDC class bootloaders
261   *   - Reverted AVRISP-MKII clone project watchdog based command timeout patch in favour of a hardware timer, to allow for use in devices with WDTRST fuse programmed
262   *   - The library bootloaders will now correctly start the user application after a watchdog-based application start, even if the /HWB line is held low externally
263   *     during the reset phase
264   *   - Increased endpoint polling interval for all demos and projects to 5ms, as 1ms was causing some enumeration issues on some machines (thanks to Riku Salminen)
265   *
266   *  <b>Fixed:</b>
267   *  - Core:
268   *   - Fixed possible enumeration error if the user application selects a pipe other than the default Control pipe between the Powered and Default states of
269   *     the host state machine
270   *   - Fixed incorrect call to the user callback CALLBACK_Audio_Device_GetSetInterfaceProperty() in the Audio Class device driver (thanks to Tiit Ratsep)
271   *   - Fixed compile error for the UC3 architecture when INTERRUPT_CONTROL_ENDPOINT is specified (thanks to Andrus Aaslaid)
272   *   - Fixed compile error if LEDs_Disable() is called and BOARD=NONE is set (thanks to Sam Lin)
273   *   - Fixed inverted LED logic in the OLIMEX162 board LED driver
274   *   - Fixed incorrect response to GET STATUS requests in device mode if NO_DEVICE_SELF_POWER or NO_DEVICE_REMOTE_WAKEUP tokens are defined (thanks to Georg Glock)
275   *   - Fixed inverted LED logic in the USB2AX board LED driver
276   *   - Fixed possible deadlock in the CDC device driver if the USB connection is dropped while the CDC_REQ_SetLineEncoding control request is being processed by
277   *     the stack (thanks to Jonathan Hudgins)
278   *   - Fixed broken MIDI host driver MIDI_Host_ReceiveEventPacket() function due to not unfreezing the MIDI data IN pipe before use (thanks to Michael Brown)
279   *   - Fixed swapped Little Endian/Big Endian endpoint and pipe write code for the UC3 devices (thanks to Andrew Chu)
280   *   - Fixed the JTAG_DISABLE() macro clearing all other bits in MCUSR when called
281   *   - Fixed incorrect Micropendous board LED driver LEDs_SetAllLEDs() and LEDs_ChangeLEDs() function implementations (thanks to MitchJS)
282   *   - Fixed endianess issues in the RNDIS host class driver for UC3 devices (thanks to Andrew Chu)
283   *  - Library Applications:
284   *   - Fixed error in the AVRISP-MKII programmer when ISP mode is used at 64KHz (thanks to Ben R. Porter)
285   *   - Fixed AVRISP-MKII programmer project failing to compile for the U4 chips when VTARGET_ADC_CHANNEL is defined to an invalid channel and NO_VTARGET_DETECT is
286   *     defined (thanks to Steven Morehouse)
287   *   - Fixed AVRISP-MKII programmer project reset line polarity inverted when the generated EEP file is loaded into the USB AVR's EEPROM and avr-dude is used
288   *   - Fixed CDC and DFU bootloaders failing to compile when the bootloader section size is 8KB or more (thanks to Georg Glock)
289   *   - Fixed CDC and DFU bootloaders API function offsets incorrect on some devices (thanks to Rod DeMay)
290   *   - Fixed incorrect DFU version number reported to the host in the  DFU bootloader descriptors (thanks to Georg Glock)
291   *   - Fixed incorrect version hundredths value encoding in VERSION_BCD() macro (thanks to Georg Glock)
292   *   - Fixed invalid configuration descriptor in the low level KeyboardMouse device demo (thanks to Jun Wako)
293   *   - Fixed CDC and DFU bootloaders API page erase and write function failures (thanks to Martin Lambert)
294   *
295   *  \section Sec_ChangeLog120219 Version 120219
296   *  <b>New:</b>
297   *  - Core:
298   *   - Added support for the XMEGA A3BU Xplained board
299   *   - Added support for the new B series XMEGA devices
300   *   - Added support for version 2 of the Teensy boards (thanks to Christoph Redecker)
301   *   - Added support for the USB2AX boards, hardware revision 1-3
302   *   - Added new Android Accessory Host class driver
303   *   - Added new USB_Host_GetDescriptor(), USB_Host_GetDeviceConfiguration() and USB_Host_GetInterfaceAltSetting() functions
304   *   - Added new CALLBACK_Audio_Device_GetSetInterfaceProperty() callback to the Audio Device Class driver
305   *   - Added new LEDs_Disable(), Buttons_Disable() and Joystick_Disable() functions to the board hardware drivers
306   *   - Added support for the Micropendous family of boards (Arduino-like revisions 1 and 2, DIP, 32U2, A, 1, 2, 3 and 4)
307   *   - Added INVERTED_VBUS_ENABLE_LINE and NO_AUTO_VBUS_MANAGEMENT compile time options (thanks to Opendous Inc.)
308   *   - Added support for the Atmel XMEGA B1 Xplained board
309   *   - Added Serial USART peripheral driver for the XMEGA architecture
310   *   - Added Master Mode SPI USART peripheral driver for the XMEGA and AVR8 architectures
311   *   - Added build test to verify correct compilation of as many modules as possible under as many architectures as possible under the C and C++ languages
312   *   - Added build test to verify correct compilation of the USB driver when forced into single USB mode under as many architectures as possible
313   *  - Library Applications:
314   *   - Added User Application APIs to the CDC and DFU class bootloaders
315   *   - Added INVERTED_ISP_MISO compile time option to the AVRISP-MKII clone project (thanks to Chuck Rohs)
316   *   - Added new Android Accessory Host demo (thanks to Opendous Inc.)
317   *
318   *  <b>Changed:</b>
319   *  - Core:
320   *   - When automatic PLL management mode is enabled on the U4 series AVR8 chips, the PLL is now configured for 48MHz and not
321   *     a divided 96MHz, to lower power consumption and to keep the system within the datasheet specs for 3.3V operation (thanks to Scott Vitale)
322   *   - Added Class, ClassDevice, ClassHost and ClassCommon to the internal class driver source filenames to prevent ambiguities
323   *   - Altered the Mass Storage Host class driver so that SCSI data STALLs from the attached device can be recovered from automatically without
324   *     having to reset the Mass Storage interface
325   *   - USB_CONFIG_ATTR_BUSPOWERED constant renamed to USB_CONFIG_ATTR_RESERVED, as this was misnamed (thanks to NXP Semiconductors)
326   *   - Reordered board name definition indexes so that a misspelled BOARD compile option will default to BOARD_USER rather than BOARD_USBKEY
327   *   - Altered the HID class driver to only try to construct at maximum one packet per USB frame, to reduce CPU usage
328   *   - All USB Class Driver configuration struct values are now non-const, to allow for run-time modifications if required before configuring an instance
329   *  - Library Applications:
330   *   - Altered the Mass Storage Host LowLevel demo so that SCSI data STALLs from the attached device can be recovered from automatically without
331   *     having to reset the Mass Storage interface
332   *   - Updated the AVRISP-MKII Clone programmer project to be compatible with the latest version of AVR Studio (version 5.1)
333   *   - Changed the AVRISP-MKII Clone programmer project to report a fixed 3.3V VTARGET voltage on USB AVRs lacking an ADC instead of 5V to prevent
334   *     warnings in AVR Studio 5.1 when programming XMEGA devices
335   *   - Allow serial strings to be generated on the older AVR8 devices which do not explicitly state they contain unique values in the datasheet,
336   *     as this appears to be implemented in hardware
337   *
338   *  <b>Fixed:</b>
339   *  - Core:
340   *   - Fixed ring buffer size limited to 255 elements, instead of the intended 65535 elements.
341   *   - Fixed CDC class drivers not saving and sending all 16-bits of the control line states (thanks to Matthew Swabey)
342   *   - Fixed race conditions in the CDC, HID and Mass Storage class drivers when processing some control requests
343   *   - Fixed misspelled HID_KEYBOARD_MODIFIER_* macros in the HID class driver (thanks to Laszlo Monda)
344   *   - Fixed broken AVR32 endpoint/pipe communications when ORDERED_EP_CONFIG compile time option is not enabled (thanks to Matthias Jahr)
345   *   - Fixed broken compilation for the AVR32 devices if the NO_SOF_EVENTS compile time option was not enabled (thanks to Matthias Jahr)
346   *   - Fixed compiler warning on GCC with \c -wundef compile flag is used (thanks to Georg Glock)
347   *   - Fixed incorrect implementation of LEDs_ToggleLEDs() for the Adafruit-U4 board (thanks to Caroline Saliman)
348   *   - Fixed broken compilation of LUFA under C++ compilers when the Serial peripheral module header file is included in a C++ source file
349   *   - Fixed missing semicolon in the UC3 architecture host pipe functions
350   *   - Fixed failed compilation for the XMEGA architecture if USB_DEVICE_ONLY us not specified
351   *   - Fixed UC3 architecture ignoring the pipe size when Pipe_ConfigurePipe() is called
352   *  - Library Applications:
353   *   - Added reliability patches to the AVRISP-MKII Clone project's PDI/TPI protocols (thanks to Justin Mattair)
354   *   - Fixed AVRISP-MKII Clone compile warning on AVR8 U4 targets even when NO_VTARGET_DETECT is enabled
355   *   - Fixed AVRISP-MKII Clone failing to start application firmware once a TPI programming session is exited
356   *   - Fixed DFU class bootloader not resetting the LED pins as high impedance inputs when a software jump to the user applications is requested
357   *   - Fixed AVRISP-MKII Clone timing out on long programming commands such as programming the EEPROM on an ATMEGA8 (thanks to Martin Kelling)
358   *   - Fixed invalid PID value used in the TempDataLogger project host application (thanks to Anupam Pathak)
359   *
360   *  \section Sec_ChangeLog111009 Version 111009
361   *  <b>New:</b>
362   *  - Core:
363   *   - Added USE_LUFA_CONFIG_HEADER compile time option to include a LUFAConfig.h header in the user director for LUFA configuration
364   *     tokens as an alternative to tokens defined in the project makefile
365   *   - Added new USB_Host_SetInterfaceAltSetting() convenience function for the selection of an interface's alternative setting
366   *   - Added Audio class control request definitions
367   *   - Added new CALLBACK_Audio_Device_GetSetEndpointProperty() callback to the Audio Device Class driver to allow for endpoint control manipulations
368   *     such as data sample rates
369   *   - Added support for the Audio class GET STATUS request in the Audio Device Class driver so that it is correctly ACKed when sent by the host
370   *   - Added new EVENT_Audio_Device_StreamStartStop() event to the Audio Device Class driver to detect stream start/stop events
371   *   - Added board driver support for the Busware TUL board
372   *   - Added board hardware driver support for the EVK1100 board
373   *   - Added board hardware driver support for the EVK1104 board
374   *   - Added new Host mode Audio Class driver
375   *   - Added new SPI_GetCurrentMode() function to the SPI peripheral driver
376   *   - Added RingBuffer_GetFreeCount() function to the Ring Buffer driver
377   *   - Added new HID_Host_SetIdlePeriod() function to the HID Host Class driver
378   *   - Added new USB_Host_ConfigurationNumber global variable to indicate the selected configuration in an attached device
379   *   - Added new USB_Host_GetDeviceStatus() function to the host standard request function set
380   *   - Added AVR USB XMEGA architecture port (currently incomplete/experimental)
381   *   - Added new STRINGIFY() and STRINGIFY_EXPANDED() convenience macros
382   *   - Added new JTAG_DISABLE() macro for the AVR8 architecture
383   *   - Added Device Qualifier standard descriptor structure definitions USB_StdDescriptor_DeviceQualifier_t and USB_Descriptor_DeviceQualifier_t
384   *  - Library Applications:
385   *   - Added RNDIS device mode to the Webserver project
386   *   - Added new incomplete AndroidAccessoryHost Host LowLevel demo
387   *   - Added new HIDReportViewer project
388   *   - Added new MediaControl project
389   *   - Added new AudioInputHost Host ClassDriver demo
390   *   - Added new AudioOutputHost Host ClassDriver demo
391   *   - Added new AudioInputHost Host LowLevel demo
392   *   - Added new AudioOutputHost Host LowLevel demo
393   *   - Added new "checksource" target to all library project makefiles
394   *   - Added new VTARGET_USE_INTERNAL_REF configuration option to the AVRISP-MKII clone project (thanks to Volker Bosch)
395   *
396   *  <b>Changed:</b>
397   *  - Core:
398   *   - Altered the definition of the USB_Audio_Descriptor_Format_t descriptor so that the user is now responsible for supplying
399   *     the supported audio sampling rates, to allow for multiple audio interfaces with different numbers of supported rates and/or
400   *     continuous sample rates
401   *   - Pipe_BoundEndpointNumber() has been renamed to Pipe_GetBoundEndpointAddress(), and now returns the correct endpoint direction
402   *     as part of the endpoint address
403   *   - Renamed global state variables that are specific to a certain USB mode to clearly indicate which mode the variable relates to,
404   *     by changing the USB_* prefix to USB_Device_* or USB_Host_*
405   *   - Removed the HOST_STATE_WaitForDeviceRemoval and HOST_STATE_Suspended host state machine states, as these are no longer required
406   *   - Altered the USB_Host_SetDeviceConfiguration() function to update the global Host state machine state and the new
407   *     USB_Host_ConfigurationNumber global as required
408   *   - Added endian correcting code to the library USB class drivers for multiple architecture support
409   *   - Removed the ENDPOINT_DESCRIPTOR_DIR_* macros, replaced by ENDPOINT_DIR_* instead
410   *   - Renamed the JTAG_DEBUG_ASSERT() macro to JTAG_ASSERT()
411   *   - Added variable number of axis to HID_DESCRIPTOR_JOYSTICK() for multi-axis joysticks above just X and Y
412   *   - Renamed USB_Host_ClearPipeStall() to USB_Host_ClearEndpointStall() as the function works on an endpoint address within the attached device,
413   *     and not a Pipe within the host
414   *   - The MS_Host_ResetMSInterface() now performs a full Mass Storage reset sequence to prevent data corruption in the event of a device
415   *     lock up or timeout (thanks to David Lyons)
416   *   - Added endian-correction to the CDC driver's Line Encoding control request handlers.
417   *  - Library Applications:
418   *   - Modified the Low Level and Class Driver AudioInput and AudioOutput demos to support multiple audio sample rates
419   *   - Updated all host mode demos and projects to use the EVENT_USB_Host_DeviceEnumerationComplete() event callback for device configuration
420   *     instead of manual host state machine manipulations in the main application task
421   *   - Changed the reports in the GenericHID device demos to control the board LEDs, to reduce user confusion over the callback routines
422   *   - Added reliability patches to the AVRISP-MKII Clone project's ISP and PDI/TPI protocols (thanks to Justin Mattair)
423   *
424   *  <b>Fixed:</b>
425   *  - Core:
426   *   - Large number of documentation and code comment corrections (thanks to Andrey from Microsin.ru)
427   *   - Fixed possibility of the AVR's SPI interface being pulled out of master mode if the /SS pin is a input and pulled low (thanks
428   *     to Andrey from Microsin.ru)
429   *   - Fixed compile error when FIXED_CONTROL_ENDPOINT_SIZE compile time option was disabled, and a USE_*_DESCRIPTORS compile time
430   *     option was not enabled on the AVR8s
431   *   - Fixed lack of C++ compatibility in some internal header files causing compile errors when using LUFA in C++ projects
432   *   - Fixed error in the pipe unordered allocation algorithm for the AVR8 devices breaking compatibility with some devices
433   *   - Fixed USB_USBTask not being called internally in stream transfers between packets when Partial Stream Transfers are used
434   *   - Fixed swapped TWI_ADDRESS_READ and TWI_ADDRESS_WRITE values
435   *   - Fixed TWI_ReadPacket() not releasing the TWI bus on read completion
436   *   - Fixed optimization error in the HID Parser item value USB_SetHIDReportItemInfo() and USB_GetHIDReportItemInfo() routines if the report item was
437   *     \c NULL (which should be allowable according to the API)
438   *   - Fixed HID Parser CALLBACK_HIDParser_FilterHIDReportItem() callback function not being passed a cacheable report item pointer
439   *   - Fixed HID Parser's largest report size bit count not including the size of the last parsed report item
440   *   - Fixed HID host driver's largest HID report size count corrupt when the number of report bits exceeds 255
441   *  - Library Applications:
442   *   - Fixed incorrect signature in the CDC and DFU class bootloaders for the ATMEGA8U2
443   *   - Fixed KeyboardHost and KeyboardHostWithParser demos displaying incorrect values when numerical keys were pressed
444   *   - Fixed compile errors in the incomplete BluetoothHost demo application (thanks to Timo Lindfors)
445   *   - Fixed incorrect Dataflash buffer use in the DataflashManager_WriteBlocks_RAM() function of several demos/projects (thanks to Jeremy Willden)
446   *   - Fixed incorrect logging interval (always 500ms longer than requested) in the TempDataLogger project
447   *   - Fixed incorrect buffer size check in the USBtoSerial project (thanks to Yuri A Nikiforov)
448   *   - Fixed port state table corruption in the TCP layer of the RNDIS Ethernet device demos
449   *
450   *  \section Sec_ChangeLog110528 Version 110528
451   *  <b>New:</b>
452   *  - Core:
453   *   - Added new ORDERED_EP_CONFIG compile time option to restrict endpoint/pipe configuration to ascending order
454   *     in exchange for a smaller compiled program binary size
455   *   - Added a new general RingBuff.h miscellaneous ring buffer library driver header
456   *   - Added new GCC_FORCE_POINTER_ACCESS() macro to correct GCC's mishandling of struct pointer accesses
457   *   - Added new GCC_MEMORY_BARRIER() macro to prevent instruction reordering across boundaries
458   *   - Added basic driver example use code to the library documentation
459   *   - Added new Endpoint_Null_Stream() and Pipe_Null_Stream() functions
460   *   - Added new ADC_GET_CHANNEL_MASK() convenience macro
461   *   - Added new HID report item macros (with HID_RI_ prefix) to allow for easy creation and editing of HID report descriptors
462   *   - Added new HID_DESCRIPTOR_MOUSE(), HID_DESCRIPTOR_KEYBOARD(), HID_DESCRIPTOR_JOYSTICK() and HID_DESCRIPTOR_VENDOR() macros
463   *     for easy automatic creation of basic USB HID device reports
464   *   - Added new MAX() and MIN() convenience macros
465   *   - Added new Serial_SendData() function to the Serial driver
466   *   - Added board driver support for the Sparkfun ATMEGA8U2 breakout board
467   *   - Added TWI baud rate prescaler and bit length parameters to the TWI_Init() function (thanks to Thomas Herlinghaus)
468   *   - Internal restructuring for eventual multiple architecture ports
469   *   - Added AVR32 UC3 architecture port (currently incomplete/experimental)
470   *   - Added new architecture independent functions to enable, disable, save and restore the Global Interrupt Enable flags
471   *   - Added new RNDIS Device Class Driver packet send and receive functions
472   *  - Library Applications:
473   *   - Added ability to write protect Mass Storage disk write operations from the host OS
474   *   - Added new MIDIToneGenerator project
475   *   - Added new KeyboardMouseMultiReport Device ClassDriver demo
476   *   - Added new VirtualSerialMassStorage Device ClassDriver demo
477   *   - Added HID class bootloader, compatible with a modified version of the command line Teensy loader from PJRC.com
478   *   - Added LED flashing to the CDC and DFU class bootloaders to indicate when they are running
479   *
480   *  <b>Changed:</b>
481   *  - Core:
482   *   - Unordered Endpoint/Pipe configuration is now allowed once again by default via the previous reconfig workaround
483   *   - Refactored Host mode Class Driver *_Host_ConfigurePipes() routines to be more space efficient when compiled
484   *   - Added new *_ENUMERROR_PipeConfigurationFailed error codes for the *_Host_ConfigurePipes() routines
485   *   - The USARTStream global is now public and documented in the SerialStream module, allowing for the serial USART
486   *     stream to be accessed via its handle rather than via the implicit stdout and stdin streams
487   *   - The FAST_STREAM_TRANSFERS compile time option has been removed due to lack of use and low cost/benefit ratio
488   *   - Altered all endpoint/pipe stream transfers so that the new BytesProcessed parameter now points to a location
489   *     where the number of bytes in the transfer that have been completed can be stored (or NULL if entire transaction
490   *     should be performed in one chunk)
491   *   - The NO_STREAM_CALLBACKS compile time option has now been removed due to the new partial stream transfer feature
492   *   - Changed over all project and demo HID report descriptors to use the new HID report item macros
493   *   - Moved the HIDParser.c source file to the LUFA/Drivers/USB/Class/Common/ directory from the LUFA/Drivers/USB/Class/Host/
494   *   - Added support to the HID parser for extended USAGE items that contain the usage page as well as the usage index
495   *   - Removed the SerialStream driver, rolled functionality into the regular Serial peripheral driver via the new
496   *     Serial_CreateStream() and Serial_CreateBlockingStream() functions
497   *   - Renamed the low level Serial byte send/receive functions, to be consistent with the CDC class driver byte functions
498   *   - Altered the behaviour of the serial byte reception function so that is is non-blocking, and now returns a negative
499   *     value if no character is received (to remain consistent with the CDC class driver byte reception routines)
500   *   - Renamed the PRNT_Host_SendString(), CDC_Host_SendString() and CDC_Device_SendString() functions to *_SendData(), and
501   *     added new versions of the *_SendString() routines that expect a null terminated string instead
502   *   - Renamed all driver termination *_ShutDown() functions to the more logical name *_Disable()
503   *   - Reduced latency for executing the Start-Of-Frame events (if enabled in the user application)
504   *   - Removed Pipe_ClearErrorFlags(), pipe error flags are now automatically cleared when Pipe_ClearError() is called
505   *   - Endpoint_ResetFIFO() renamed to Endpoint_ResetEndpoint(), to be consistent with the Pipe_ResetPipe() function name
506   *   - Implemented on-demand PLL clock generation for the U4, U6 and U7 series USB AVRs when automatic PLL mode is specified
507   *   - F_CLOCK changed to F_USB to be more descriptive, and applicable on future architecture ports
508   *   - Renamed all low level Endpoint_Read_*, Endpoint_Write_* and Endpoint_Discard_* functions to use the number of bits instead of
509   *     a symbolic size (Byte, Word, DWord) so that the function names are applicable and correct across all architectures
510   *   - Renamed all low level Pipe_Read_*, Pipe_Write_* and Pipe_Discard_* functions to use the number of bits instead of
511   *     a symbolic size (Byte, Word, DWord) so that the function names are applicable and correct across all architectures
512   *   - Separated out board drivers by architecture in the library internals for better organisation
513   *  - Library Applications:
514   *   - Changed the XPLAINBridge software UART to use the regular timer CTC mode instead of the alternative CTC mode
515   *     via the Input Capture register, to reduce user confusion
516   *   - Combined page and word ISP programming mode code in the AVRISP-MKII clone project to reduce compiled size and
517   *     increase maintainability of the code
518   *   - Changed over library projects to use the new general ring buffer library driver module
519   *   - Added new high level TWI packet read/write commands, altered behaviour of the TWI_StartTransmission() function
520   *   - Changed TempDataLogger project's DS1307 driver to simplify the function interface and prevent a possible race condition
521   *   - Changed AVRISP-MKII project to use the Watchdog interrupt for command timeouts, to reduce CPU usage and free timer 0
522   *     for other uses
523   *   - Updated the software USART code in the XPLAIN Bridge application so that the incoming bits are sampled at their mid-point
524   *     instead of starting point, to give maximum reliability (thanks to Anton Staaf)
525   *
526   *  <b>Fixed:</b>
527   *  - Core:
528   *   - Fixed broken USBFOO board drivers due to missing BOARD_USBFOO define
529   *   - Fixed HID host class driver incorrectly binding to HID devices that do not have an OUT endpoint
530   *   - Fixed incorrect definition of the HID_KEYBOARD_SC_D constant in the HID class driver (thanks to Opendous Inc.)
531   *   - Fixed incorrect definition of the HID_KEYBOARD_SC_RIGHT_ARROW constant in the HID class driver (thanks to Joby Taffey)
532   *   - Fixed incorrect endpoint initialisation order in the several device demos (thanks to Rick Drolet)
533   *   - Fixed inverted Minimus board LEDs
534   *   - Fixed incorrect byte ordering in the Audio_Device_WriteSample24 function (thanks to WZab)
535   *   - Fixed several functions in the Host mode Still Image Class driver returning an error code from the incorrect
536   *     error code enum (thanks to Daniel Seibert)
537   *   - Fixed ReportID not being removed from the feature/out report data array in the HID class driver when Report IDs are used
538   *   - Fixed incorrect BUTTONS_BUTTON1 definition for the Minimus board
539   *   - Fixed Still Image Host class driver exiting the descriptor search routine prematurely if the data pipes (but not event pipe)
540   *     is found
541   *   - Fixed missing call to Pipe_SetInfiniteINRequests() in the Pipe_ConfigurePipe() routine
542   *   - Fixed Remote Wakeup broken on the AVRs due to the mechanism only operating when the SUSPI bit is set (thanks to Holger Steinhaus)
543   *   - Fixed possible invalid program execution when in host mode if corrupt descriptor lengths are supplied by the attached device
544   *  - Library Applications:
545   *   - Fixed Benito project discarding incoming data from the USB virtual serial port when the USART is busy
546   *   - Fixed broken DFU bootloader, added XPLAIN support for bootloader start when XCK jumpered to ground
547   *   - Fixed broken HID_REQ_GetReport request handler in the Low Level GenericHID demo
548   *   - Fixed possible lost data in the XPLAINBridge, USBtoSerial and Benito projects when the host exceeds the packet
549   *     timeout period on received packets as set by USB_STREAM_TIMEOUT_MS (thanks to Justin Rajewski)
550   *   - Fixed possible programming problem in the AVRISP-MKII clone project when programming specific patterns into a target
551   *     memory space that is only byte (not page) addressable
552   *   - Fixed errors in the incomplete Test and Measurement device demo preventing proper operation (thanks to Pavel Plotnikov)
553   *   - Fixed programming errors in the AVRISP-MKII project when the programming packet is a round multiple of the endpoint bank
554   *     size under avrdude (thanks to Steffan Woltjer)
555   *
556   *
557   *  \section Sec_ChangeLog101122 Version 101122
558   *  <b>New:</b>
559   *  - Core:
560   *    - Added new SCSI_ASENSE_NOT_READY_TO_READY_CHANGE constant to the Mass Storage class driver, to indicate when a previously
561   *      not ready removable medium has now become ready for the host's use (thanks to Martin Degelsegger)
562   *    - Moved the Pipe and Endpoint stream related code to two new USB library core source files EndpointStream.c and PipeStream.c
563   *    - Added new USB_Device_GetFrameNumber() and USB_Host_GetFrameNumber() functions to retrieve the current USB frame number
564   *    - Added new USB_Host_EnableSOFEvents(), USB_Host_DisableSOFEvents() and EVENT_USB_Host_StartOfFrame() for the user application
565   *      handling of USB Start of Frame events while in USB Host mode
566   *    - Added new PRNT_Host_BytesReceived(), PRNT_Host_ReceiveByte(), PRNT_Host_SendByte() and PRNT_Host_Flush() functions to the
567   *      Print Host Class driver
568   *    - Added class specific descriptor alternative struct type defines with standard USB-IF element naming
569   *    - Added new project makefile template to the library and moved board driver stub files into in a new "CodeTemplates" directory
570   *    - Added board hardware driver support for the Adafruit U4 breakout board
571   *    - Added board hardware driver support for the Arduino Uno development board
572   *    - Added board hardware driver support for the Blackcat USB JTAG board (thanks to the PSGroove team)
573   *    - Added board hardware driver support for the Busware BUI development board
574   *    - Added board hardware driver support for the Busware CUL V3 868MHZ radio board (thanks to Dirk Tostmann)
575   *    - Added board hardware driver support for the Kernel Concepts USBFOO development board
576   *    - Added board hardware driver support for the Linnix UDIP development board
577   *    - Added board hardware driver support for the Olimex AVR-USB-162 development board (thanks to Steve Fawcett)
578   *    - Added board hardware driver support for the Maximus board (thanks to the PSGroove team)
579   *    - Added board hardware driver support for the Microsin AVR-USB162 breakout board
580   *    - Added board hardware driver support for the Minimus board (thanks to the PSGroove team)
581   *    - Added new NO_CLASS_DRIVER_AUTOFLUSH compile time option to disable automatic flushing of interfaces when the USB management
582   *      tasks for each driver is called
583   *    - Added standard keyboard HID report scan-code defines (thanks to Laszlo Monda)
584   *    - Added new Pipe_GetBusyBanks(), Endpoint_GetBusyBanks() and Endpoint_AbortPendingIN() functions
585   *  - Library Applications:
586   *    - Added default test tone generation mode to the Device mode AudioInput demos
587   *    - Added new NO_BLOCK_SUPPORT, NO_EEPROM_BYTE_SUPPORT, NO_FLASH_BYTE_SUPPORT and NO_LOCK_BYTE_WRITE_SUPPORT compile time options to the
588   *      CDC class bootloader
589   *    - Added new XCK_RESCUE_CLOCK_ENABLE compile time option to the AVRISP-MKII clone programmer project (thanks to Tom Light)
590   *
591   *  <b>Changed:</b>
592   *  - Core:
593   *    - Removed complicated logic for the Endpoint_ConfigureEndpoint() function to use inlined or function called versions
594   *      depending of if the given bank size is a compile time constant, as the compiler does a better job of optimizing
595   *      with basic code
596   *    - Changed the signature of the CALLBACK_USB_GetDescriptor() callback function so that the descriptor pointer is const, to remove
597   *      the need for extra casting inside the callback (thanks to Jonathan Kollasch)
598   *    - Reduced HOST_DEVICE_SETTLE_DELAY_MS to 1000ms down from 1500ms to improve device compatibility while in USB Host mode
599   *    - Removed the EVENT_USB_InitFailure() event, not specifying a USB mode correctly now defaults to UID selection mode
600   *    - Renamed and moved class driver common constant definitions to make the naming scheme more uniform
601   *    - Moved the USB mode specifier constants into a new enum, so that they are semantically related to one another
602   *    - Renamed ENDPOINT_DOUBLEBANK_SUPPORTED() to ENDPOINT_BANKS_SUPPORTED() and changed it to return the maximum number of supported banks for
603   *      the given endpoint
604   *    - Better algorithm to extract and convert the internal device serial number into a string descriptor (if present)
605   *    - All USB class drivers are now automatically included when LUFA/Drivers/USB.h is included, and no longer need to be separately included
606   *    - The MIDI class drivers now automatically flushes the MIDI interface when the MIDI class driver's USBTask() function is called
607   *    - Renamed the EVENT_USB_Device_UnhandledControlRequest() event to EVENT_USB_Device_ControlRequest() as it is now fired before the library
608   *      request handlers, not afterwards
609   *  - Library Applications:
610   *    - Changed over all device demos to use a clearer algorithm for the configuring of the application's endpoints
611   *    - Added missing DataflashManager_CheckDataflashOperation() function to the MassStorageKeyboard demo, removed redundant
612   *      SCSI_Codes.h file as these values are part of the MassStorage Class Driver
613   *    - Added compile time error to the AVRISP-MKII project when built for the U4 chips, as the default VTARGET detection ADC channel
614   *      does not exist on these chips (thanks to Marco)
615   *    - Changed all Device mode LowLevel demos and Device Class drivers so that the control request is acknowledged and any data
616   *      transferred as quickly as possible without any processing in between sections, so that long callbacks or event handlers will
617   *      not break communications with the host by exceeding the maximum control request stage timeout period
618   *    - Changed over all demos, drivers and internal functions to use the current frame number over the Start of Frame flag where possible
619   *      to free up the Start of Frame flag for interrupt use in the user application
620   *    - All project makefiles now correctly clean intermediate build files from assembly and C++ sources (thanks to Daniel Czigany)
621   *    - Changed default value for the reset polarity parameter in the AVRISP-MKII project so that it defaults to active low drive
622   *    - Changed configuration descriptor parser for all host mode projects and class drivers to ensure better compatibility with devices
623   *    - All LowLevel demos changed to use the constants and types defined in the USB class drivers
624   *    - Changed AudioInput and AudioOutput demos to reload the next sample via an interrupt rather than polling the sample timer
625   *    - Rescue clock of the AVRISP-MKII moved to the AVR's OCR1A pin, so that the clock can be generated at all times
626   *    - Changed ClassDriver MIDI demos to process all incoming events in a loop until the bank becomes empty rather than one at a time
627   *    - Changed LowLevel MIDI demos to only clear the incoming event bank once it has become empty to support packed event packets
628   *
629   *  <b>Fixed:</b>
630   *  - Core:
631   *    - Fixed USB_GetHIDReportItemInfo() function modifying the given report item's data when the report item does not exist
632   *      within the supplied report of a multiple report HID device
633   *    - Fixed critical pipe/endpoint memory allocation issue where the bank memory address space could be silently overlapped
634   *      in the USB controller if the endpoints or pipes were allocated in anything other than ascending order (thanks to Martin Degelsegger)
635   *    - Added LEDs_ToggleLEDs() function to several board LED drivers which were missing it (thanks to Andrei Krainev)
636   *    - Fixed SET FEATURE and CLEAR FEATURE control requests directed at an unconfigured endpoint causing request timeouts
637   *    - Fixed USB_Host_ClearPipeStall() incorrectly determining the endpoint direction from the currently selected pipe
638   *    - Fixed JTAG_DEBUG_POINT() and JTAG_DEBUG_BREAK() macros not compiling under pure C99 standards mode
639   *    - Fixed endpoint selection within the CALLBACK_HID_Device_CreateHIDReport() callback function causing broken GET REPORT requests
640   *    - Fixed incorrect command name for EEPROM memory programming in the makefile dfu-ee target
641   *    - Fixed incorrect LEDs_ChangeLEDs() function in the Benito board LED driver
642   *    - Fixed incorrect USB_DeviceState value when unconfiguring the device without an address set
643   *    - Fixed SPI driver not explicitly setting /SS and MISO pins as inputs when SPI_Init() is called
644   *    - Fixed random enumeration failure while in device mode due to interrupts causing the Set Address request to exceed maximum timings
645   *    - Fixed MIDI_Host_Flush() not aborting early when the specified MIDI host interface was not configured
646   *    - Fixed MIDI class driver send routines silently discarding packets if the endpoint or pipe is busy (thanks to Robin Green)
647   *  - Library Applications:
648   *    - Fixed MassStorage based demos and projects resetting the SCSI sense values before the command is executed, leading to
649   *      missed SCSI sense values when the host retrieves the sense key (thanks to Martin Degelsegger)
650   *    - Fixed USBtoSerial and Benito project SetLineEncoding calls failing if the USART is busy, due to the RX ISR delaying the control
651   *      request handler
652   *    - Fixed LowLevel PrinterHost demo not sending control requests to the attached printer with the correct printer interface wIndex value
653   *    - Fixed incorrect signature reported in the CDC class bootloader for the ATMEGA32U2
654   *    - Fixed BootloaderCDC project failing on some operating systems due to removed Line Encoding options (thanks to Alexey Belyaev)
655   *    - Fixed broken FLASH/EEPROM programming in the AVRISP-MKII clone project when writing in non-paged mode and the polling byte cannot be used
656   *    - Fixed ISR definition conflict in the XPLAIN bridge between the software UART and the AVRISP-MKII ISP modules
657   *    - Fixed USBtoSerial and XPLAINBridge demos discarding data from the PC if the send buffer becomes full
658   *    - Fixed broken input in the MagStripe reader project due to an incorrect HID report descriptor
659   *    - Fixed incorrect PollingIntervalMS values in the demo/project/bootloader endpoint descriptors (thanks to MCS Electronics)
660   *    - Fixed AVRISP-MKII clone project not starting the target's program automatically after exiting TPI programming mode
661   *
662   *
663   *  \section Sec_ChangeLog100807 Version 100807
664   *  <b>New:</b>
665   *  - Added new ADC_DisableChannel() function (thanks to Mich Davis)
666   *  - Added new VTARGET_REF_VOLTS and VTARGET_SCALE_FACTOR compile time defines to the AVRISP-MKII programmer project to set
667   *    the VTARGET reference voltage and scale factor
668   *  - Added new pgm_read_ptr() macro to Common.h for reading of pointers out of flash memory space
669   *  - Added new SWAPENDIAN_16() and SWAPENDIAN_32() macros to Common.h for statically initialized variables at compile time
670   *  - Added new Drivers/USB/LowLevel/Device.c file to house Device mode specific functions that are more complicated than simple macros
671   *  - Added new AVRStudio 4 project files for all library demos, projects and bootloaders
672   *  - Added ability to set the serial baud rate via the user's terminal in the XPLAINBridge project
673   *  - Added new LUFA module variables for the different source modules in the core library makefile to simplify project makefiles
674   *  - Added start of a new Test and Measurement class demo (thanks to Peter Lawrence)
675   *  - Added new SPI_ORDER_* data order masks to the SPI peripheral driver
676   *  - Added support to the AVRISP-MKII project for ISP speeds slower than 125KHz via a new software SPI driver
677   *  - Added support for the new button/LED on the latest model USBTINY-MKII
678   *
679   *  <b>Changed:</b>
680   *  - The RingBuff library code has been replaced in the XPLAINBridge, Benito and USBtoSerial projects with an ultra lightweight
681   *    ring buffer to help improve the reliability of the projects
682   *  - The EEPROM stream read/write functions now use eeprom_update_byte() instead of eeprom_write_byte(), so that only
683   *    changed bytes are written to EEPROM to preserve its lifespan
684   *  - Changed over the AVRISP-MKII and TemperatureDataLogger projects to use eeprom_update_byte() when writing non-volatile
685   *    parameters to EEPROM to preserve its lifespan
686   *  - Removed unused line encoding data and control requests from the CDC Bootloader code, to save space
687   *  - Renamed SERIAL_STREAM_ASSERT() macro to STDOUT_ASSERT()
688   *  - The USB_Device_IsRemoteWakeupSent() and USB_Device_IsUSBSuspended() macros have been deleted, as they are now obsolete
689   *  - Rewrote the implementation of the SwapEndian_16() and SwapEndian_32() functions so that they compile down in most instances to
690   *    minimal loads and stores rather than complicated shifts
691   *  - The software UART in the XPLAINBridge has been largely altered to try to improve upon its performance and reliability
692   *  - The USBtoSerial and Benito projects now flushes received data via a flush timer, so that several bytes can be transmitted at once
693   *  - Removed the automated checking of event names in the demo, project and bootloader makefiles due to inconsistencies between the
694   *    behaviour of the command line tools used to perform the check on each platform
695   *  - Internal USB driver source files renamed and moved to ease future possible architecture ports
696   *  - All internal pseudo-function macros have been converted to true inline functions for type-safety and readability
697   *  - Changed LED indicator masks for the AVRISP-MKII project, so that there are defined roles for each LED
698   *  - Altered the CDC Device and Host Class drivers' receive byte routines, so that no data is indicated by the function returning a
699   *    negative value (thanks to Andreas Paulin)
700   *  - Added auto flushing of OUT data to the CDC Host Class driver's USBTask function to automatically flush the send pipe buffer
701   *
702   *  <b>Fixed:</b>
703   *  - Fixed AVRISP project sending a LOAD EXTENDED ADDRESS command to 128KB AVRs after programming or reading from
704   *    the last page of FLASH (thanks to Gerard Sexton)
705   *  - Fixed AVRISP project not sending a full erase-and-write EEPROM command to XMEGA targets when writing to the EEPROM
706   *    instead of the split write-only command (thanks to Tim Margush)
707   *  - Fixed RNDISEthernet demos crashing when calculating checksums for Ethernet/TCP packets of more than ~500 bytes due to
708   *    an overflow in the checksum calculation loop (thanks to Kevin Malec)
709   *  - Fixed XPLAINBridge project not correctly reading the XMEGA's supply voltage when reporting back to the host
710   *  - Fixed incorrect signature for the ATMEGA32U2 in the DFU bootloader (thanks to Axel Rohde)
711   *  - Fixed internal device serial not being accessible on the ATMEGAXXU2 AVRs (thanks to Axel Rohde)
712   *  - Fixed void pointer arithmetic in ConfigDescriptor.h breaking C++ compatibility (thanks to Michael Hennebry)
713   *  - Fixed broken PDI EEPROM Section Erase functionality in the AVRISP-MKII project
714   *  - Fixed USB_Device_SendRemoteWakeup() not working when the USB clock was frozen during USB bus suspend (thanks to Brian Dickman)
715   *  - Fixed occasional lockup of the AVRISP project due to the timeout extension code incorrectly extending the timeout in
716   *    PDI and TPI programming modes infinitely
717   *  - Fixed HID device class driver still using PrevReportINBuffer for GetReport control requests even when it has been
718   *    set to NULL by the user application (thanks to Axel Rohde)
719   *  - Fixed MIDI_Device_SendEventPacket() not correctly waiting for the endpoint to become ready (thanks to Robin Green)
720   *  - Fixed Benito and USBtoSerial projects not turning off the USART before reconfiguring it, which could cause incorrect
721   *    operation to occur (thanks to Bob Paddock)
722   *  - Fixed Serial peripheral driver not turning off the USART before reconfiguring it, which would cause incorrect operation
723   *    to occur (thanks to Bob Paddock)
724   *  - Fixed software application start command broken in the DFU class bootloader when dfu-programmer is used due to application
725   *    start address corruption
726   *
727   *
728   *  \section Sec_ChangeLog100513 Version 100513
729   *  <b>New:</b>
730   *  - Added incomplete MIDIToneGenerator project
731   *  - Added new Relay Controller Board project (thanks to OBinou)
732   *  - Added board hardware driver support for the Teensy, USBTINY MKII, Benito and JM-DB-U2 lines of third party USB AVR boards
733   *  - Added new ATTR_NO_INIT variable attribute for global variables that should not be automatically cleared on startup
734   *  - Added new ENDPOINT_*_BusSuspended error code to the Endpoint function, so that the stream functions early-abort if the bus
735   *    is suspended before or during a transfer
736   *  - Added new EVENT_CDC_Device_BreakSent() event and CDC_Host_SendBreak() function to the Device and Host CDC Class drivers
737   *  - Added ReportType parameter to the HID device class driver CALLBACK_HID_Device_ProcessHIDReport() function so that FEATURE
738   *    reports from the host to the device can be correctly processed
739   *  - Added ReportType parameter to the HID host class driver HID_Host_SendReportByID() function so that FEATURE reports can be
740   *    issued to the attached device
741   *
742   *  <b>Changed:</b>
743   *  - AVRISP programmer project now has a more robust timeout system
744   *  - Added a timeout value to the TWI_StartTransmission() function, within which the addressed device must respond
745   *  - Webserver project now uses the board LEDs to indicate the current IP configuration state
746   *  - Added ENABLE_TELNET_SERVER compile time option to the Webserver project to disable the TELNET server if desired
747   *  - Increased throughput of the USBtoSerial demo on systems that send multiple bytes per packet (thanks to Opendous Inc.)
748   *  - Double bank CDC endpoints in the XPLAIN Bridge project, re-enable JTAG once the mode selection pin has been sampled.
749   *  - Standardized the naming scheme given to configuration descriptor sub-elements in the Device mode demos, bootloaders
750   *    and projects
751   *  - All Class Driver Host mode demos now correctly set the board LEDs to READY once the enumeration process has completed
752   *  - Added LIBUSB_FILTERDRV_COMPAT compile time option to the AVRISP programmer project to make the code compatible with Windows
753   *    builds of avrdude at the expense of AVRStudio compatibility
754   *  - Removed two-step endpoint/pipe bank clear and switch sequence for smaller, faster endpoint/pipe code
755   *  - The USB_Init() function no longer calls sei() - the user is now responsible for enabling interrupts when they are ready
756   *    for them to be enabled (thanks to Andrei Krainev)
757   *  - The Audio_Device_IsSampleReceived() and Audio_Device_IsReadyForNextSample() functions are now inline, to reduce overhead
758   *  - Removed the cast to uint16_t on the set baud rate in the USBtoSerial project, so that the higher >1M baud rates can be
759   *    selected (thanks to Steffan Woltjer)
760   *  - Removed software PDI and TPI emulation from the AVRISP-MKII clone project as it was very buggy and slow - PDI and TPI must
761   *    now be implemented via separate programming headers
762   *  - The CDC class bootloader now uses a watchdog reset rather than a soft-reset when exited to ensure that all hardware is
763   *    properly reset to their defaults
764   *  - Device mode class driver callbacks are now fired before the control request status stage is sent to prevent the host from
765   *    timing out if another request is immediately fired and the device has a lengthy callback routine
766   *  - The TeensyHID bootloader has been removed, per request from Paul at PJRC
767   *  - The LIBUSB_FILTERDRV_COMPAT compile time option in the XPLAINBridge and AVRISP-MKII projects has been renamed
768   *    LIBUSB_DRIVER_COMPAT, as it applies to all software on all platforms using the libUSB driver
769   *
770   *  <b>Fixed:</b>
771   *  - Fixed possible device lockup when INTERRUPT_CONTROL_ENDPOINT is enabled and the control endpoint is not properly
772   *    selected when the ISR completes
773   *  - Fixed AVRISP-MKII clone project not correctly issuing LOAD EXTENDED ADDRESS commands when the extended address
774   *    boundary is crossed during programming or read back (thanks to Gerard Sexton)
775   *  - Fixed warnings when building the AVRISP-MKII clone project with the ENABLE_XPROG_PROTOCOL compile time option disabled
776   *  - Fixed software PDI/TPI programming mode in the AVRISP project not correctly toggling just the clock pin
777   *  - Fixed TWI_StartTransmission() corrupting the contents of the GPIOR0 register
778   *  - Fixed TWI driver not aborting when faced with no response after attempting to address a device on the bus
779   *  - Fixed ADC routines not correctly returning the last result when multiple channels were read
780   *  - Fixed ADC routines failing to read the extended channels (Channels 8 to 13, Internal Temperature Sensor) on the
781   *    U4 series USB AVR parts
782   *  - Fixed LowLevel MassStorage demo broken on the U2 series USB AVRs due to unsupported double-banked endpoint modes used
783   *  - Fixed compilation error in the AudioInput demos when MICROPHONE_BIASED_TO_HALF_RAIL is defined (thanks to C. Scott Ananian)
784   *  - Fixed incorrect definition of HID_ALIGN_DATA() causing incorrect HID report item data alignment
785   *  - Fixed Still Image Host class driver not resetting the transaction ID when a new session is opened, fixed driver not sending
786   *    a valid session ID to the device
787   *  - Removed invalid dfu and flip related targets from the bootloaders - bootloaders can only be replaced with an external programmer
788   *  - Fixed Set/Clear Feature requests directed to a non-configured endpoint not returning a stall to the host
789   *  - Fixed HID Device Class Driver not allocating a temporary buffer when the host requests a report via the control endpoint and the
790   *    user has set the PrevReportINBuffer driver configuration element to NULL (thanks to Lars Noschinski)
791   *  - Fixed device state not being reset to DEVICE_STATE_Default if the host sets a 0x00 device address
792   *  - Fixed device not stalling configuration requests before the device's address has been set
793   *  - Fixed possibility of internal signature retrieval being corrupted if an interrupt occurs during a signature byte
794   *    read (thanks to Andrei Krainev)
795   *  - Fixed device state not being reset back to the default state if the host sets the address to 0
796   *  - Fixed Set Configuration requests not being stalled until the host has set the device's address
797   *  - Fixed Host mode HID class driver not sending the correct report type when HID_Host_SendReportByID() was called and the
798   *    HID_HOST_BOOT_PROTOCOL_ONLY compile time option is set
799   *  - Fixed INTERRUPT_CONTROL_ENDPOINT compile time option preventing other interrupts from occurring while the control endpoint
800   *    request is being processed, causing possible lockups if a USB interrupt occurs during a transfer
801   *  - Remove incorrect Abstract Call Management class specific descriptor from the CDC demos, bootloaders and projects
802   *
803   *
804   *  \section Sec_ChangeLog100219 Version 100219
805   *
806   *  <b>New:</b>
807   *  - Added TPI programming support for 6-pin ATTINY devices to the AVRISP programmer project (thanks to Tom Light)
808   *  - Added command timeout counter to the AVRISP project so that the device no longer freezes when incorrectly connected
809   *    to a target
810   *  - Added new TemperatureDataLogger application, a USB data logger which writes to the device's dataflash and appears to
811   *    the host as a standard Mass Storage device when inserted
812   *  - Added MIDI event packing support to the MIDI Device and Host mode Class drivers, allowing for multiple MIDI events to
813   *    sent or received in packed form in a single USB packet
814   *  - Added new MIDI send buffer flush routines to the MIDI Device and Host mode Class drivers, to flush packed events
815   *  - Added master mode hardware TWI driver for easy TWI peripheral control
816   *  - Added ADC MUX masks for the standard ADC input channels on all AVR models with an ADC, altered demos to use these masks
817   *    as on some models, the channel number is not identical to its single-ended ADC MUX mask
818   *  - New Webserver project, a RNDIS host USB webserver using the open source uIP TCP/IP network stack and FatFS library
819   *  - New BOARD value option BOARD_NONE (equivalent to not specifying BOARD) which will remove all board hardware drivers which
820   *    do not adversely affect the code operation (currently only the LEDs driver)
821   *  - Added keyboard modifier masks (HID_KEYBOARD_MODIFER_*) and LED report masks (KEYBOARD_LED_*) to the HID class driver and
822   *    Keyboard demos
823   *  - Added .5MHz recovery clock to the AVRISP programmer project when in ISP programming mode to correct mis-set fuses
824   *
825   *  <b>Changed:</b>
826   *  - Slowed down software USART carried PDI programming in the AVRISP project to prevent transmission errors
827   *  - Renamed the AVRISP project folder to AVRISP-MKII to reduce confusion
828   *  - Renamed the RESET_LINE_* makefile tokens in the AVRISP MKII Project to AUX_LINE_*, as they are not always used for target
829   *    reset
830   *  - Changed over the MassStorageKeyboard Class driver device demo to use Start of Frame events rather than a timer to keep track
831   *    of elapsed milliseconds
832   *  - Inlined currently unused (but standardized) maintenance functions in the Device and Host Class drivers to save space
833   *  - The XPLAINBridge project now selects between a USB to Serial bridge and a PDI programmer on startup, reading the JTAG port's
834   *    TDI pin to determine which mode to use
835   *  - Removed the stream example code from the Low Level VirtualSerial demos, as they were buggy and only served to add clutter
836   *
837   *  <b>Fixed:</b>
838   *  - Fixed AVRISP project not able to enter programming mode when ISP protocol is used
839   *  - Fixed AVRISP PDI race condition where the guard time between direction changes could be interpreted as a start bit
840   *  - Fixed ADC_IsReadingComplete() returning an inverted result
841   *  - Fixed blocking CDC streams not aborting when the host is disconnected
842   *  - Fixed XPLAIN board Dataflash driver broken due to incorrect preprocessor commands
843   *  - Fixed inverted XPLAIN LED driver output (LED turned on when it was supposed to be turned off, and vice-versa)
844   *  - Fixed Class Driver struct interface numbers in the KeyboardMouse and VirtualSerialMouse demos (thanks to Renaud Cerrato)
845   *  - Fixed invalid USB controller PLL prescaler values for the ATMEGAxxU2 controllers
846   *  - Fixed lack of support for the ATMEGA32U2 in the DFU and CDC class bootloaders
847   *  - Fixed Benito project not resetting the target AVR automatically when programming has completed
848   *  - Fixed DFU bootloader programming not discarding the correct number of filler bytes from the host when non-aligned programming
849   *    ranges are specified (thanks to Thomas Bleeker)
850   *  - Fixed CDC and RNDIS host demos and class drivers - bidirectional endpoints should use two separate pipes, not one half-duplex pipe
851   *  - Fixed Pipe_IsEndpointBound() not taking the endpoint's direction into account
852   *  - Fixed EEPROM and FLASH ISP programming in the AVRISP project
853   *  - Fixed incorrect values of USB_CONFIG_ATTR_SELFPOWERED and USB_CONFIG_ATTR_REMOTEWAKEUP tokens (thanks to Claus Christensen)
854   *  - Fixed SerialStream driver blocking while waiting for characters to be received instead of returning EOF
855   *  - Fixed SerialStream driver not setting stdin to the created serial stream (thanks to Mike Alexander)
856   *  - Fixed USB_GetHIDReportSize() returning the number of bits in the specified report instead of bytes
857   *  - Fixed AVRISP project not extending the command delay after each successful page/word/byte program
858   *  - Fixed accuracy of the SERIAL_UBBRVAL() and SERIAL_2X_UBBRVAL() macros for higher baud rates (thanks to Renaud Cerrato)
859   *
860   *
861   *  \section Sec_ChangeLog091223 Version 091223
862   *
863   *  <b>New:</b>
864   *  - Added activity LED indicators to the AVRISP project to indicate when the device is busy processing a command
865   *  - The USB target family and allowable USB mode tokens are now public and documented (USB_CAN_BE_*, USB_SERIES_*_AVR)
866   *  - Added new XPLAIN USB to Serial Bridge project (thanks to John Steggall for initial proof-of-concept, David Prentice
867   *    and Peter Danneger for revised software USART code)
868   *  - Added new RNDIS Ethernet Host LowLevel demo
869   *  - Added new RNDIS Ethernet Host Class Driver
870   *  - Added new RNDIS Ethernet Host ClassDriver demo
871   *  - Added CDC_Host_Flush() function to the CDC Host Class driver to flush sent data to the attached device
872   *  - Added PDI programming support for XMEGA devices to the AVRISP programmer project (thanks to Justin Mattair)
873   *  - Added support for the XPLAIN board Dataflash, with new XPLAIN_REV1 board target for the different Dataflash used
874   *    on the first revision boards compared to the one mounted on later revisions
875   *  - Added new HID_ALIGN_DATA() macro to return the pre-retrieved value of a HID report item, left-aligned to a given datatype
876   *  - Added new PreviousValue to the HID Report Parser report item structure, for easy monitoring of previous report item values
877   *  - Added new EVK527 board target
878   *  - Added new USB_Host_GetDeviceStringDescriptor() convenience function
879   *  - Added new LEDNotification project to the library, to give a visual LED notification on new events from the host
880   *  - Added new NO_DEVICE_REMOTE_WAKEUP and NO_DEVICE_SELF_POWER compile time options
881   *
882   *  <b>Changed:</b>
883   *  - Removed code in the Keyboard demos to send zeroed reports between two reports with differing numbers of key codes
884   *    as this relied on non-standard OS driver behaviour to repeat key groups
885   *  - The SCSI_Request_Sense_Response_t and SCSI_Inquiry_Response_t type defines are now part of the Mass Storage Class
886   *    driver common defines, rather than being defined in the Host mode Class driver section only
887   *  - The USB_MODE_HOST token is now defined even when host mode is not available
888   *  - The CALLBACK_HID_Device_CreateHIDReport() HID Device Class driver callback now has a new ReportType parameter to
889   *    indicate the report type to generate
890   *  - All Class Drivers now return false or the "DeviceDisconnected" error code of their respective error enums when a function
891   *    is called when no host/device is connected where possible
892   *  - The HOST_SENDCONTROL_DeviceDisconnect enum value has been renamed to HOST_SENDCONTROL_DeviceDisconnected to be in line
893   *    with the rest of the library error codes
894   *  - Make MIDI device demos also turn off the on board LEDs if MIDI Note On messages are sent with a velocity of zero,
895   *    which some devices use instead of Note Off messages (thanks to Robin Green)
896   *  - The CDC demos are now named "VirtualSerial" instead to indicate the demos' function rather than its implemented USB class,
897   *    to reduce confusion and to be in line with the rest of the LUFA demos
898   *  - The SImage_Host_SendBlockHeader() and SImage_Host_ReceiveBlockHeader() Still Image Host Class driver functions are now public
899   *
900   *  <b>Fixed:</b>
901   *  - Added missing CDC_Host_CreateBlockingStream() function code to the CDC Host Class driver
902   *  - Fixed incorrect values for REPORT_ITEM_TYPE_* enum values causing corrupt data in the HID Host Parser
903   *  - Fixed misnamed SI_Host_USBTask() and SI_Host_ConfigurePipes() functions
904   *  - Fixed broken USB_GetNextDescriptor() function causing the descriptor to jump ahead double the expected amount
905   *  - Fixed Pipe_IsEndpointBound() not masking the given Endpoint Address against PIPE_EPNUM_MASK
906   *  - Fixed host state machine not enabling Auto VBUS mode when HOST_DEVICE_SETTLE_DELAY_MS is set to zero
907   *  - Fixed misnamed Pipe_SetPipeToken() macro for setting a pipe's direction
908   *  - Fixed CDCHost failing on devices with bidirectional endpoints
909   *  - Fixed USB driver failing to define the PLL prescaler mask for the ATMEGA8U2 and ATMEGA16U2
910   *  - Fixed HID Parser not distributing the Usage Min and Usage Max values across an array of report items
911   *  - Fixed Mass Storage Host Class driver and Low Level demo not clearing the error condition if an attached device returns a
912   *    STALL to a GET MAX LUN request (thanks to Martin Luxen)
913   *  - Fixed TeensyHID bootloader not properly shutting down the USB interface to trigger a disconnection on the host before resetting
914   *  - Fixed MassStorageHost Class driver demo not having USB_STREAM_TIMEOUT_MS compile time option set properly to prevent slow
915   *    devices from timing out the data pipes
916   *  - Fixed the definition of the Endpoint_BytesInEndpoint() macro for the U4 series AVR parts
917   *  - Fixed MIDI host Class driver MIDI_Host_SendEventPacket() routine not properly checking for Pipe ready before writing
918   *  - Fixed use of deprecated struct initializers, removed library unused parameter warnings when compiled with -Wextra enabled
919   *  - Fixed Still Image Host Class driver truncating the PIMA response code (thanks to Daniel Seibert)
920   *  - Fixed USB_CurrentMode not being reset to USB_MODE_NONE when the USB interface is shut down and both Host and Device modes can be
921   *    used (thanks to Daniel Levy)
922   *  - Fixed TeensyHID bootloader not enumerating to the host correctly (thanks to Clint Fisher)
923   *  - Fixed AVRISP project timeouts not checking for the correct timeout period (thanks to Carl Ott)
924   *  - Fixed STK525 Dataflash driver using incorrect bit-shifting for Dataflash addresses (thanks to Tim Mitchell)
925   *
926   *
927   *  \section Sec_ChangeLog091122 Version 091122
928   *
929   *  <b>New:</b>
930   *  - Added new Dual Role Keyboard/Mouse demo
931   *  - Added new HID_HOST_BOOT_PROTOCOL_ONLY compile time token to reduce the size of the HID Host Class driver when
932   *    Report protocol is not needed
933   *  - Added new MIDI LowLevel and ClassDriver Host demo, add new MIDI Host Class driver
934   *  - Added new CDC/Mouse ClassDriver device demo
935   *  - Added new Joystick Host ClassDriver and LowLevel demos
936   *  - Added new Printer Host mode Class driver
937   *  - Added new Printer Host mode ClassDriver demo
938   *  - Added optional support for double banked endpoints and pipes in the Device and Host mode Class drivers
939   *  - Added new stream creation function to the CDC Class drivers, to easily make standard I/O streams from CDC Class driver instances
940   *
941   *  <b>Changed:</b>
942   *  - Removed mostly useless "TestApp" demo, as it was mainly useful only for checking for syntax errors in the library
943   *  - MIDI device demos now receive MIDI events from the host and display note ON messages via the board LEDs
944   *  - Cleanups to the Device mode Mass Storage demo application SCSI routines
945   *  - Changed Audio Class driver sample read/write functions to be inline, to reduce the number of cycles needed to transfer
946   *    samples to and from the device (allowing more time for sample processing and output)
947   *  - Audio class Device mode demos now work at both 16MHz and 8MHz, rather than just at 8MHz
948   *  - The previous USBtoSerial demo has been moved into the projects directory, as it was just a modified CDC demo
949   *  - The Endpoint/Pipe functions now use the const qualifier on the input buffer
950   *  - Changed the CALLBACK_HIDParser_FilterHIDReportItem() callback to pass a HID_ReportItem_t rather than just the current
951   *    item's attributes, to expose more information on the item (including it's type, collection path, etc.)
952   *  - Changed MouseHostWithParser demos to check that the report items have a Mouse usage collection as a parent at some point,
953   *    to prevent Joysticks from enumerating with the demo
954   *  - Corrected the name of the misnamed USB_GetDeviceConfigDescriptor() function to USB_Host_GetDeviceConfigDescriptor().
955   *  - Keyboard LowLevel/ClassDriver demos now support multiple simultaneous key presses (up to 6) per report
956   *
957   *  <b>Fixed:</b>
958   *  - Fixed PrinterHost demo returning invalid Device ID data when the attached device does not have a
959   *    device ID (thanks to Andrei Krainev)
960   *  - Changed LUFA_VERSION_INTEGER define to use BCD values, to make comparisons easier
961   *  - Fixed issue in the HID Host class driver's HID_Host_SendReportByID() routine using the incorrect mode (control/pipe)
962   *    to send report to the attached device
963   *  - Fixed ClassDriver AudioOutput device demo not selecting an audio output mode
964   *  - Fixed incorrect SampleFrequencyType value in the AudioInput and AudioOutput ClassDriver demos' descriptors
965   *  - Fixed incorrect event name rule in demo/project/bootloader makefiles
966   *  - Fixed HID device class driver not reselecting the correct endpoint once the user callback routines have been called
967   *  - Corrected HID descriptor in the Joystick Device demos - buttons should be placed outside the pointer collection
968   *  - Fixed HID report parser collection paths invalid due to misplaced semicolon in the free path item search loop
969   *  - Fixed HID host Class driver report send/receive report broken when issued through the control pipe
970   *  - Fixed HOST_STATE_AS_GPIOR compile time option being ignored when in host mode (thanks to David Lyons)
971   *  - Fixed LowLevel Keyboard demo not saving the issues report only after it has been sent to the host
972   *  - Fixed Endpoint_Write_Control_Stream_* functions not sending a terminating IN when given data Length is zero
973   *
974   *
975   *  \section Sec_ChangeLog090924 Version 090924
976   *
977   *  <b>New:</b>
978   *  - Added new host mode class drivers and matching demos to the library for rapid application development
979   *  - Added flag to the HID report parser to indicate if a device has multiple reports
980   *  - Added new EVENT_USB_Device_StartOfFrame() event, controlled by the new USB_Device_EnableSOFEvents() and
981   *    USB_Device_DisableSOFEvents() macros to give bus-synchronized millisecond interrupts when in USB device mode
982   *  - Added new Endpoint_SetEndpointDirection() macro for bidirectional endpoints
983   *  - Added new AVRISP project, a LUFA powered clone of the Atmel AVRISP-MKII programmer
984   *  - Added ShutDown() functions for all hardware peripheral drivers, so that peripherals can be turned off after use
985   *  - Added new CDC_Device_Flush() command to the device mode CDC Class driver to flush Device->Host data
986   *  - Added extra masks to the SPI driver, changed SPI_Init() so that the clock polarity and sample modes can be set
987   *  - Added new callback to the HID report parser, so that the user application can filter only the items it is interested
988   *    in to be stored into the HIDReportInfo structure to save RAM
989   *  - Added support for the officially recommended external peripheral layout for the BUMBLEB board (thanks to Dave Fletcher)
990   *  - Added new Pipe_IsFrozen() macro to determine if the currently selected pipe is frozen
991   *  - Added new USB_GetHIDReportSize() function to the HID report parser to retrieve the size of a given report by its ID
992   *  - Added new combined Mass Storage and Keyboard demo (thanks to Matthias Hullin)
993   *
994   *  <b>Changed:</b>
995   *  - SetIdle requests to the HID device driver with a 0 idle period (send changes only) now only affect the requested
996   *    HID interface within the device, not all HID interfaces
997   *  - Added explicit attribute masks to the device mode demos' descriptors
998   *  - Added return values to the CDC and MIDI class driver transmit functions
999   *  - Optimized Endpoint_Read_Word_* and Pipe_Read_Word_* macros to reduce compiled size
1000   *  - Added non-null function parameter pointer restrictions to USB Class drivers to improve user code reliability
1001   *  - Added new "Common" section to the class drivers, to hold all mode-independent definitions for clarity
1002   *  - Moved SCSI command/sense constants into the Mass Storage Class driver, instead of the user-code
1003   *  - Altered the SCSI commands in the LowLevel Mass Storage Host to save on FLASH space by reducing function calls
1004   *  - Changed the parameters and behaviour of the USB_GetDeviceConfigDescriptor() function so that it now performs size checks
1005   *    and data validations internally, to simplify user code
1006   *  - Changed HIDParser to only zero out important values in the Parsed HID Report Item Information structure to save cycles
1007   *  - The HID report parser now always processed FEATURE items - HID_ENABLE_FEATURE_PROCESSING token now has no effect
1008   *  - The HID report parser now always ignores constant-data items, HID_INCLUDE_CONSTANT_DATA_ITEMS token now has no effect
1009   *  - The Benito Programmer project now has its own unique VID/PID pair allocated from the Atmel donated LUFA VID/PID pool
1010   *  - Add in new invalid event hook check targets to project makefiles to produce compilation errors when invalid event names
1011   *    are used in a project
1012   *  - The HID Report Parser now gives information on the total length of each report within a HID interface
1013   *  - The USE_NONSTANDARD_DESCRIPTOR_NAMES compile time token has been removed - there are now separate USB_Descriptor_* and
1014   *    USB_StdDescriptor_* structures for both the LUFA and standardized element naming conventions so both may be used
1015   *
1016   *  <b>Fixed:</b>
1017   *  - Fixed possible lockup in the CDC device class driver, when the host sends data that is a multiple of the
1018   *    endpoint's bank
1019   *  - Fixed swapped parameters in the HID state memory copy call while processing a HID PUSH item in the HID report parser
1020   *  - Fixed memory corruption HID report parser when too many COLLECTION or PUSH items were processed
1021   *  - Fixed HID report parser not resetting the FEATURE item count when a REPORT ID item is encountered
1022   *  - Fixed USBtoSerial demos not reading in UDR1 when the USART receives data but the USB interface is not enumerated,
1023   *    causing continuous USART receive interrupts
1024   *  - Fixed misspelled event name in the Class driver USBtoSerial demo, preventing correct operation
1025   *  - Fixed invalid data being returned when a GetStatus request is issued in Device mode with an unhandled data recipient
1026   *  - Added hardware USART receive interrupt and software buffering to the Benito project to ensure received data is not
1027   *    missed or corrupted
1028   *  - Fixed Device mode HID Class driver always sending IN packets, even when nothing to report
1029   *  - Fixed Device mode HID Class driver not explicitly initializing the ReportSize parameter to zero before calling callback
1030   *    routine, so that ignored callbacks don't cause incorrect data to be sent
1031   *  - Fixed StillImageHost not correctly freezing and unfreezing data pipes while waiting for a response block header
1032   *  - Fixed error in the PrinterHost demo preventing the full page data from being sent to the attached device (thanks to John Andrews)
1033   *  - Fixed CDC based demos and projects' INF driver files under 64 bit versions of Windows (thanks to Ronny Hanson, Thomas Bleeker)
1034   *  - Re-add in missing flip, flip-ee, dfu and dfu-ee targets to project makefiles (thanks to Opendous Inc.)
1035   *  - Fix allowable F_CPU values comment in project makefiles to more accurately reflect the allowable values on the USB AVRs
1036   *  - Fixed DFU and CDC class bootloaders on the series 2 USB AVRs, corrected invalid signatures, added support for the new
1037   *    ATMEGAxx2 series 2 variant AVRs to the DFU bootloader
1038   *  - Fixed Low Level USBtoSerial demo not storing received characters (thanks to Michael Cooper)
1039   *  - Fixed MIDI Device Class driver not sending/receiving MIDI packets of the correct size (thanks to Thomas Bleeker)
1040   *
1041   *
1042   *  \section Sec_ChangeLog090810 Version 090810
1043   *
1044   *  <b>New:</b>
1045   *  - Added new device class drivers and matching demos to the library for rapid application development
1046   *  - Added new PrinterHost demo (thanks to John Andrews)
1047   *  - Added USB Missile Launcher project, submitted by Dave Fletcher
1048   *  - Added new Benito Arduino Programmer project
1049   *  - Added incomplete device and host mode demos for later enhancement
1050   *  - Updated MassStorage device block write routines to use ping-pong Dataflash buffering to increase throughput by around 30%
1051   *  - Error status LEDs shown when device endpoint configuration fails to complete in all demos and projects
1052   *  - Added new USB_Host_SetDeviceConfiguration() convenience function for easy configuration selection of devices while in USB
1053   *    host mode
1054   *  - Added new USB_Host_ClearPipeStall() convenience function to clear a stall condition on an attached device's endpoint
1055   *  - Added new USB_Host_GetDeviceDescriptor() convenience function to retrieve the attached device's Device descriptor
1056   *  - Added new Endpoint_ClearStatusStage() convenience function to assist with the status stages of control transfers
1057   *  - Added new USE_INTERNAL_SERIAL define for using the unique serial numbers in some AVR models as the USB device's serial number,
1058   *    added NO_INTERNAL_SERIAL compile time option to turn off new serial number reading code
1059   *  - Added new DATAFLASH_CHIP_MASK() macro to the Dataflash driver, which returns the Dataflash select mask for the given chip index
1060   *  - Added new HOST_STATE_WaitForDeviceRemoval host state machine state for non-blocking disabling of device communications until the
1061   *    device has been removed (for use when an error occurs or communications with the device have completed)
1062   *  - Added new FAST_STREAM_TRANSFERS compile time option for faster stream transfers via multiple bytes copied per stream loop
1063   *  - Added stdio stream demo code to the CDC device demos, to show how to create standard streams out of the virtual serial ports
1064   *  - Added new EEPROM and FLASH buffer versions of the Endpoint and Pipe stream functions
1065   *  - Added new USE_FLASH_DESCRIPTORS and FIXED_NUM_CONFIGURATIONS compile time options
1066   *  - Added support for the new ATMEGA32U2, ATMEGA16U2 and ATMEGA8U2 AVR models
1067   *  - Added new USB_DeviceState variable to keep track of the current Device mode USB state
1068   *  - Added new LEDs_ToggleLEDs() function to the LEDs driver
1069   *  - Added new Pipe_BoundEndpointNumber() and Pipe_IsEndpointBound() functions
1070   *  - Added new DEVICE_STATE_AS_GPIOR and HOST_STATE_AS_GPIOR compile time options
1071   *  - Added 404 Not Found errors to the webserver in the RNDIS demos to indicate invalid URLs
1072   *
1073   *  <b>Changed:</b>
1074   *  - Deprecated pseudo-scheduler and removed dynamic memory allocator from the library (first no longer needed and second unused)
1075   *  - The device-mode CALLBACK_USB_GetDescriptor() function now has an extra parameter so that the memory space in which the requested
1076   *    descriptor is located can be specified. This means that descriptors can now be located in multiple memory spaces within a device.
1077   *  - Removed vague USB_IsConnected global - test USB_DeviceState or USB_HostState explicitly to gain previous functionality
1078   *  - Removed USB_IsSuspended global - test USB_DeviceState against DEVICE_STATE_Suspended instead
1079   *  - Extended USB_GetDeviceConfigDescriptor() routine to require the configuration number within the device to fetch
1080   *  - Dataflash_WaitWhileBusy() now always ensures that the dataflash is ready for the next command immediately after returning,
1081   *    no need to call Dataflash_ToggleSelectedChipCS() afterwards
1082   *  - Low level API MIDI device demo no longer blocks if a note change event is sent while the endpoint is not ready
1083   *  - Pipe_GetErrorFlags() now returns additional error flags for overflow and underflow errors
1084   *  - Pipe stream functions now automatically set the correct pipe token, so that bidirectional pipes can be used
1085   *  - Pipe_ConfigurePipe() now automatically defaults IN pipes to accepting infinite IN requests, this can still be changed by calling
1086   *    the existing Pipe_SetFiniteINRequests() function
1087   *  - Changed F_USB entries in project makefiles to alias to F_CPU by default, as this is the most common case
1088   *  - Host mode demos now use sane terminal escape codes, so that text is always readable and events/program output is visually distinguished
1089   *    from one another using foreground colours
1090   *  - Internal per-device preprocessing conditions changed to per-device series rather than per-controller group for finer-grain
1091   *    internal control
1092   *  - Interrupts are no longer disabled during the processing of Control Requests on the default endpoint while in device mode
1093   *  - AudioOutput demos now always output to board LEDs, regardless of output mode (removed AUDIO_OUT_LEDS project option)
1094   *  - Removed SINGLE_DEVICE_CONFIGURATION compile time option in favor of the new FIXED_NUM_CONFIGURATIONS option so that the exact number
1095   *    of device configurations can be defined statically
1096   *  - Removed VBUS events, as they are already exposed to the user application via the regular device connection and disconnection events
1097   *  - Renamed and altered existing events to properly separate out Host and Device mode events
1098   *  - All demos switched over from GNU99 standards mode to C99 standards mode, to reduce the dependencies on GCC-only language extensions
1099   *
1100   *  <b>Fixed:</b>
1101   *  - Changed bootloaders to use FLASHEND rather than the existence of RAMPZ to determine if far FLASH pointers are needed to fix
1102   *    bootloaders on some of the USB AVR devices where avr-libc erroneously defines RAMPZ
1103   *  - Fixes to MassStorageHost for better device compatibility (increase command timeout, change MassStore_WaitForDataReceived()
1104   *    to only unfreeze and check one data pipe at a time) to prevent incorrect device enumerations and freezes while transferring data
1105   *  - Make Pipe_ConfigurePipe() mask the given endpoint number against PIPE_EPNUM_MASK to ensure the endpoint IN direction bit is
1106   *    cleared to prevent endpoint type corruption
1107   *  - Fixed issue opening CDC-ACM ports on hosts when the CDC device tries to send data before the host has set the line encoding
1108   *  - Fixed USB_OPT_MANUAL_PLL option being ignored during device disconnects on some models (thanks to Brian Dickman)
1109   *  - Fixed documentation mentioning Pipe_GetCurrentToken() function when correct function name is Pipe_GetPipeToken()
1110   *  - Fixed ADC driver for the ATMEGA32U4 and ATMEGA16U4 (thanks to Opendous Inc.)
1111   *  - Fixed CDCHost demo unfreezing the pipes at the point of configuration, rather than use
1112   *  - Fixed MassStorage demo not clearing the reset flag when a Mass Storage Reset is issued while not processing a command
1113   *  - Fixed USB_Host_SendControlRequest() not re-suspending the USB bus when initial device ready-wait fails
1114   *  - Fixed USB Pad regulator not being disabled on some AVR models when the USB_OPT_REG_DISABLED option is used
1115   *  - Fixed Host mode to Device mode UID change not causing a USB Disconnect event when a device was connected
1116   *  - Fixed Mouse/Keyboard demos not performing the correct arithmetic on the Idle period at the right times (thanks to Brian Dickman)
1117   *  - Fixed GenericHID failing HID class tests due to incorrect Logical Minimum and Logical Maximum values (thanks to Soren Greiner)
1118   *  - Fixed incorrect PIPE_EPNUM_MASK mask causing pipe failures on devices with endpoint addresses of 8 and above (thanks to John Andrews)
1119   *  - Fixed report data alignment issues in the MouseHostWithParser demo when X and Y movement data size is not a multiple of 8 bits
1120   *  - Fixed HID Report Descriptor Parser not correctly resetting internal states when a REPORT ID element is encountered
1121   *  - Fixed incorrect BUTTONS_BUTTON1 for the STK526 target
1122   *  - Fixed RNDIS demos freezing when more than one connection was attempted simultaneously, causing memory corruption
1123   *  - Fixed USBtoSerial demo receiving noise from the USART due to pull-up not being enabled
1124   *
1125   *
1126   *  \section Sec_ChangeLog090605 Version 090605
1127   *
1128   *  - Fixed bug in RNDISEthernet and DualCDC demos not using the correct USB_ControlRequest structure for control request data
1129   *  - Fixed documentation showing incorrect USB mode support on the supported AVRs list
1130   *  - Fixed RNDISEthernet not working under Linux due to Linux requiring an "optional" RNDIS request which was unhandled
1131   *  - Fixed Mouse and Keyboard device demos not acting in accordance with the HID specification for idle periods (thanks to Brian Dickman)
1132   *  - Removed support for endpoint/pipe non-control interrupts; these did not act in the way users expected, and had many subtle issues
1133   *  - Fixed Device Mode not handling Set Feature and Clear Feature Chapter 9 requests that are addressed to the device (thanks to Brian Dickman)
1134   *  - Moved control endpoint interrupt handling into the library itself, enable via the new INTERRUPT_CONTROL_ENDPOINT token
1135   *  - Fixed CDCHost not clearing configured pipes and resetting configured pipes mask when a partially enumerated invalid CDC
1136   *    interface is skipped
1137   *  - Clarified the size of library tokens which accept integer values in the Compile Time Tokens page, values now use the smallest datatype
1138   *    inside the library that is able to hold their defined value to save space
1139   *  - Removed DESCRIPTOR_ADDRESS() macro as it was largely superfluous and only served to obfuscate code
1140   *  - Rewritten event system to remove all macros, to make user code clearer
1141   *  - Fixed incorrect ENDPOINT_EPNUM_MASK mask preventing endpoints above EP3 from being selected (thanks to Jonathan Oakley)
1142   *  - Removed STREAM_CALLBACK() macro - callbacks now use regular function definitions to clarify user code
1143   *  - Removed DESCRIPTOR_COMPARATOR() macro - comparators should now use regular function definitions to clarify user code
1144   *  - USB_IsConnected is now cleared before the USB_Disconnect() event is fired in response to VBUS being removed
1145   *  - Fixed incorrect PID value being used in the USBtoSerial project (thanks to Phill)
1146   *  - Deleted StdDescriptors.c, renamed USB_GetDescriptor() to CALLBACK_USB_GetDescriptor, moved ConfigDescriptor.c/.h from the
1147   *    LUFA/Drivers/USB/Class/ directory to LUFA/Drivers/USB/HighLevel/ in preparation for the new USB class APIs
1148   *  - Moved out each demos' functionality library files (e.g. Ring Buffer library) to /Lib directories for a better directory structure
1149   *  - Removed Tx interrupt from the USBtoSerial demo; now sends characters via polling to ensure more time for the Rx interrupt
1150   *  - Fixed possible enumeration errors from spin-loops which may fail to exit if the USB connection is severed before the exit condition
1151   *    becomes true
1152   *
1153   *
1154   *  \section Sec_ChangeLog090510 Version 090510
1155   *
1156   *  - Added new GenericHIDHost demo
1157   *  - Corrections to the KeyboardHost and MouseHost demos' pipe handling to freeze and unfreeze the data pipes at the point of use
1158   *  - KeyboardHost, MouseHost and GenericHIDHost demos now save and restore the currently selected pipe inside the pipe ISR
1159   *  - Changed GenericHID device demo to use the LUFA scheduler, added INTERRUPT_DATA_ENDPOINT and INTERRUPT_CONTROL_ENDPOINT compile
1160   *    time options
1161   *  - All comments in the library, bootloaders, demos and projects have now been spell-checked and spelling mistakes/typos corrected
1162   *  - Added new PIMA_DATA_SIZE() define to the Still Image Host demo
1163   *  - Add call to MassStore_WaitForDataReceived() in MassStore_GetReturnedStatus() to ensure that the CSW has been received in the
1164   *    extended MSC timeout period before continuing, to prevent long processing delays from causing the MassStore_GetReturnedStatus()
1165   *    to early-abort (thanks to Dmitry Maksimov)
1166   *  - Move StdRequestType.h, StreamCallbacks.h, USBMode.h from the LowLevel USB driver directory to the HighLevel USB driver directory,
1167   *    where they are more suited
1168   *  - Removed all binary constants and replaced with decimal or hexadecimal constants so that unpatched GCC compilers can still build the
1169   *    code without having to be itself patched and recompiled first
1170   *  - Added preprocessor checks and documentation to the bootloaders giving information about missing SIGNATURE_x defines due to
1171   *    outdated avr-libc versions.
1172   *  - Added support to the CDCHost demo for devices with multiple CDC interfaces which are not the correct ACM type preceding the desired
1173   *    ACM CDC interface
1174   *  - Fixed GenericHID demo not starting USB and HID management tasks when not using interrupt driven modes (thanks to Carl Kjeldsen)
1175   *  - Fixed RNDISEthenet demo checking the incorrect message field for packet size constraints (thanks to Jonathan Oakley)
1176   *  - Fixed WriteNextReport code in the GenericHIDHost demo using incorrect parameter types and not selecting the correct endpoint
1177   *  - Adjusted sample CTC timer calculations in the AudioOutput and AudioInput demos to match the CTC calculations in the AVR datasheet,
1178   *    and to fix instances where rounding caused the endpoint to underflow (thanks to Robin Theunis)
1179   *  - The USB_Host_SendControlRequest() function no longer automatically selects the Control pipe (pipe 0), so that other control type
1180   *    pipes can be used with the function
1181   *  - The USB Host management task now saves and restores the currently selected pipe before and after the task completes
1182   *  - Fixed GenericHIDHost demo report write routine incorrect for control type requests (thanks to Andrei Krainev)
1183   *  - Removed Endpoint_ClearCurrentBank() and Pipe_ClearCurrentBank() in favor of new Endpoint_ClearIN(), Endpoint_ClearOUT(),
1184   *    Pipe_ClearIN() and Pipe_ClearOUT() macros (done to allow for the detection of packets of zero length)
1185   *  - Renamed *_ReadWriteAllowed() macros to *_IsReadWriteAllowed() to remain consistent with the rest of the LUFA API
1186   *  - Endpoint_IsSetupReceived() macro has been renamed to Endpoint_IsSETUPReceived(), Endpoint_ClearSetupReceived() macro has been
1187   *    renamed to Endpoint_ClearSETUP(), the Pipe_IsSetupSent() macro has been renamed to Pipe_IsSETUPSent() and the
1188   *    Pipe_ClearSetupSent() macro is no longer applicable and should be removed - changes made to compliment the new endpoint and pipe
1189   *    bank management API
1190   *  - Updated all demos, bootloaders and projects to use the new endpoint and pipe management APIs (thanks to Roman Thiel from Curetis AG)
1191   *  - Updated library Doxygen documentation, added groups, changed documentation macro functions to real functions for clarity
1192   *  - Removed old endpoint and pipe aliased read/write/discard routines which did not have an explicit endian specifier for clarity
1193   *  - Removed the ButtLoadTag.h header file, as no one used for its intended purpose anyway
1194   *  - Renamed the main Drivers/AT90USBXXX directory to Drivers/Peripheral, renamed the Serial_Stream driver to SerialStream
1195   *  - Fixed CDC and USBtoSerial demos freezing where buffers were full while still transmitting or receiving (thanks to Peter Hand)
1196   *  - Removed "Host_" section of the function names in ConfigDescriptor.h, as most of the routines can now be used in device mode on the
1197   *    device descriptor
1198   *  - Renamed functions in the HID parser to have a "USB_" prefix and the acronym "HID" in the name
1199   *  - Fixed incorrect HID interface class and subclass values in the Mouse and KeyboardMouse demos (thanks to Brian Dickman)
1200   *  - Capitalized the "Descriptor_Search" and "Descriptor_Search_Comp" prefixes of the values in the DSearch_Return_ErrorCodes_t and
1201   *    DSearch_Comp_Return_ErrorCodes_t enums
1202   *  - Removed "ERROR" from the enum names in the endpoint and pipe stream error code enums
1203   *  - Renamed the USB_PowerOnErrorCodes_t enum to USB_InitErrorCodes_t, renamed the POWERON_ERROR_NoUSBModeSpecified enum value to
1204   *    USB_INITERROR_NoUSBModeSpecified
1205   *  - Renamed USB_PowerOnFail event to USB_InitFailure
1206   *  - Renamed OTG.h header functions to be more consistent with the rest of the library API
1207   *  - Changed over all deprecated GCC structure tag initializers to the standardized C99 format (thanks to Mike Alexander)
1208   *  - USB_HostRequest renamed to USB_ControlRequest, entire control request header is now read into USB_ControlRequest in Device mode
1209   *    rather than having the library pass only partially read header data to the application
1210   *  - The USB_UnhandledControlPacket event has had its parameters removed, in favor of accessing the new USB_ControlRequest structure
1211   *  - The Endpoint control stream functions now correctly send a ZLP to the host when less data than requested is sent
1212   *  - Fixed USB_RemoteWakeupEnabled flag never being set (the REMOTE WAKEUP Set Feature request was not being handled)
1213   *  - Renamed the FEATURELESS_CONTROL_ONLY_DEVICE compile-time token to CONTROL_ONLY_DEVICE
1214   *  - Endpoint configuration is now refined to give better output when all configurations have static inputs - removed the now useless
1215   *    STATIC_ENDPOINT_CONFIGURATION compile time token
1216   *  - Fixed SPI driver init function not clearing SPI2X bit when not needed
1217   *  - Fixed PREVENT ALLOW MEDIUM REMOVAL command issuing in the MassStorageHost demo using incorrect parameters (thanks to Mike Alex)
1218   *  - Fixed MassStorageHost demo broken due to an incorrect if statement test in MassStore_GetReturnedStatus()
1219   *  - Fixed reversed signature byte ordering in the CDC bootloader (thanks to Johannes Raschke)
1220   *  - Changed PIPE_CONTROLPIPE_DEFAULT_SIZE from 8 to 64 to try to prevent problems with faulty devices which do not respect the given
1221   *    wLength value when reading in the device descriptor
1222   *  - Fixed missing semicolon in the ATAVRUSBRF01 LED board driver code (thanks to Morten Lund)
1223   *  - Changed LED board driver code to define dummy LED masks for the first four board LEDs, so that user code can be compiled for boards
1224   *    with less than four LEDs without code modifications (thanks to Morten Lund)
1225   *  - Changed HWB board driver to Buttons driver, to allow for the support of future boards with more than one mounted GPIO button
1226   *  - Serial driver now correctly calculates the baud register value when in double speed mode
1227   *  - Init function of the Serial driver is now static inline to product smaller code for the common-case of static init values
1228   *
1229   *
1230   *  \section Sec_ChangeLog090401 Version 090401
1231   *
1232   *  - Fixed MagStripe project configuration descriptor containing an unused (blank) endpoint descriptor
1233   *  - Incorporated makefile changes by Denver Gingerich to retain compatibility with stock (non-WinAVR) AVR-GCC installations
1234   *  - Fixed makefile EEPROM programming targets programming FLASH data in addition to EEPROM data
1235   *  - LUFA devices now enumerate correctly with LUFA hosts
1236   *  - Fixed Configuration Descriptor search routine freezing when a comparator returned a failure
1237   *  - Removed HID report item serial dump in the MouseHostWithParser and KeyboardHostWithParser - useful only for debugging, and
1238   *    slowed down the enumeration of HID devices too much
1239   *  - Increased the number of bits per track which can be read in the MagStripe project to 8192 when compiled for the AT90USBXXX6/7
1240   *  - Fixed KeyboardMouse demo discarding the wIndex value in the REQ_GetReport request
1241   *  - USBtoSerial demo now discards all Rx data when not connected to a USB host, rather than buffering characters for transmission
1242   *    next time the device is attached to a host.
1243   *  - Added new F_USB compile time constant to the library and makefiles, to give the raw input clock (used to feed the PLL before any
1244   *    clock prescaling is performed) frequency, so that the PLL prescale mask can be determined
1245   *  - Changed stream wait timeout counter to be 16-bit, so that very long timeout periods can be set for correct communications with
1246   *    badly designed hosts or devices which greatly exceed the USB specification limits
1247   *  - Mass Storage Host demo now uses a USB_STREAM_TIMEOUT_MS of two seconds to maintain compatibility with poorly designed devices
1248   *  - Function attribute ATTR_ALWAYSINLINE renamed to ATTR_ALWAYS_INLINE to match other function attribute macro naming conventions
1249   *  - Added ATTR_ALWAYS_INLINE attribute to several key inlined library components, to ensure they are inlined in all circumstances
1250   *  - Removed SetSystemClockPrescaler() macro, the clock_prescale_set() avr-libc macro has been corrected in recent avr-libc versions
1251   *  - Fixed incorrect/missing control status stage transfers on demos, bootloaders and applications (thanks to Nate Lawson)
1252   *  - The NO_CLEARSET_FEATURE_REQUEST compile time token has been renamed to FEATURELESS_CONTROL_ONLY_DEVICE, and its function expanded
1253   *    to also remove parts of the Get Status chapter 9 request to further reduce code usage
1254   *  - Makefile updated to include output giving the currently selected BOARD parameter value
1255   *  - Board Dataflash driver now allows for dataflash ICs which use different shifts for setting the current page/byte address (thanks
1256   *    to Kenneth Clubb)
1257   *  - Added DataflashManager_WriteBlocks_RAM() and DataflashManager_ReadBlocks_RAM() functions to the MassStorage demo, to allow for easy
1258   *    interfacing with a FAT library for dataflash file level access
1259   *  - Corrected CDC class bootloader to fix a few bugs, changed address counter to store x2 addresses for convenience
1260   *  - Fixed typos in the SPI driver SPI_SPEED_FCPU_DIV_64 and SPI_SPEED_FCPU_DIV_128 masks (thanks to Markus Zocholl)
1261   *  - Keyboard and Mouse device demos (normal, data interrupt and fully interrupt driven) combined into unified keyboard and mouse demos
1262   *  - Keyboard and Mouse host demos (normal and data interrupt driven) combined into unified keyboard and mouse demos
1263   *  - Removed AVRISP_Programmer project due to code quality concerns
1264   *  - Fixed CDC demo not sending an empty packet after each transfer to prevent the host from buffering incoming data
1265   *  - Fixed documentation typos and preprocessor checks relating to misspellings of the USE_RAM_DESCRIPTORS token (thanks to Ian Gregg)
1266   *  - Fixed USBTask.h not conditionally including HostChapter9.h only when USB_CAN_BE_HOST is defined (thanks to Ian Gregg)
1267   *  - Fixed incorrect ADC driver init register manipulation (thanks to Tobias)
1268   *  - Added new GenericHID device demo application
1269   *  - Fixed Still Image Host SImage_SendData() function not clearing the pipe bank after sending data
1270   *
1271   *
1272   *  \section Sec_ChangeLog090209 Version 090209
1273   *
1274   *  - PWM timer mode in AudioOut demo changed to Fast PWM for speed
1275   *  - Updated Magstripe project to work with the latest hardware revision
1276   *  - Fixed library not responding to the BCERRI flag correctly in host mode, leading to device lockups
1277   *  - Fixed library handling Get Descriptor requests when not addressed as standard requests to the device or interface (thanks to
1278   *    Nate Lawson)
1279   *  - Fixed serious data corruption issue in MassStorage demo dataflash write routine
1280   *  - Added new NO_CLEARSET_FEATURE_REQUEST compile time token
1281   *  - USB task now restores previous global interrupt state after execution, rather than forcing global interrupts to be enabled
1282   *  - Fixed USB_DeviceEnumerationComplete event firing after each configuration change, rather than once after the initial configuration
1283   *  - Added ENDPOINT_DOUBLEBANK_SUPPORTED() macros to Endpoint.h, altered ENDPOINT_MAX_SIZE() to allow user to specify endpoint
1284   *  - ENDPOINT_MAX_ENDPOINTS changed to ENDPOINT_TOTAL_ENDPOINTS, PIPE_MAX_PIPES changed to PIPE_TOTAL_PIPES
1285   *  - Endpoint and Pipe non-control stream functions now ensure endpoint or pipe is ready before reading or writing
1286   *  - Changed Teensy bootloader to use a watchdog reset when exiting rather than a software jump
1287   *  - Fixed integer promotion error in MassStorage and MassStorageHost demos, corrupting read/write transfers
1288   *  - SPI_SendByte is now SPI_TransferByte, added new SPI_SendByte and SPI_ReceiveByte functions for fast one-way transfer
1289   *  - MassStorage demo changed to use new fast one-way SPI transfers to increase throughput
1290   *  - MassStorage handling of Mass Storage Reset class request improved
1291   *  - Altered MassStorage demo dataflash block read code for speed
1292   *  - Added USB_IsSuspended global flag
1293   *  - Simplified internal Dual Mode (OTG) USB library code to reduce code size
1294   *  - Extended stream timeout period to 100ms from 50ms
1295   *  - Mass Storage Host demo commands now all return an error code from the Pipe_Stream_RW_ErrorCodes_t enum
1296   *  - Added SubErrorCode parameter to the USB_DeviceEnumerationFailed event
1297   *  - VBUS drop interrupt now disabled during the manual-to-auto VBUS delivery handoff
1298   *  - Simplified low level backend so that device/host mode initialization uses the same code paths
1299   *  - Added workaround for faulty Mass Storage devices which do not implement the required GET_MAX_LUN request
1300   *  - Removed buggy Telnet application from the RNDIS demo
1301   *  - Moved Mass Storage class requests in the Mass Storage Host demo to wrapper functions in MassStoreCommands.c
1302   *  - Fixed incorrect SCSI command size value in the Request Sense command in MassStoreCommands.c
1303   *  - Added SetProtocol request to HID class non-parser Mouse and Keyboard demos to force devices to use the correct Boot Protocol
1304   *  - Added new "dfu" and "flip" programming targets to project makefiles
1305   *  - HID_PARSE_Sucessful enum member typo corrected to HID_PARSE_Successful
1306   *  - Changed COLLECTION item structures in the HID descriptor parser to include the collection's Usage Page value
1307   *  - Serial driver now sets Tx line as output, enables pull-up on Rx line
1308   *  - Fixed smaller USB AVRs raising multiple connection and disconnection events when NO_LIMITED_CONTROLLER_CONNECT is disabled
1309   *  - Added HOST_DEVICE_SETTLE_DELAY_MS to give the host delay after a device is connected before it is enumerated
1310   *  - Fixed KeyboardHostWithParser demo linking against the wrong global variables
1311   *  - Completed doxygen documentation of remaining library bootloaders, demos and projects
1312   *  - Fixed incorrect bootloader start address in the TeensyHID bootloader
1313   *  - Added HWB button whole-disk ASCII dump functionality to MassStoreHost demo
1314   *  - Replaced printf_P(PSTR("%c"), {Variable}) calls with putchar(<Variable>) for speed and size savings
1315   *  - Serial driver now accepts baud rates over 16-bits in size, added double speed flag option
1316   *  - Fixed incorrect callback abort return value in Pipe.c
1317   *  - Added new flip-ee and dfu-ee makefile targets (courtesy of Opendous Inc.)
1318   *  - Removed reboot-on-disconnect code from the TeensyHID bootloader, caused problems on some systems
1319   *  - Fixed AudioOutput and AudioInput demos looping on the endpoint data, rather than processing a sample at a time and returning
1320   *    each time the task runs to allow for other tasks to execute
1321   *  - Added support for the Atmel ATAVRUSBRF01 board
1322   *  - Added AVRISP Programmer Project, courtesy of Opendous Inc.
1323   *  - Fixed CDC Host demo not searching through both CDC interfaces for endpoints
1324   *  - Fixed incorrect Product String descriptor length in the DFU class bootloader
1325   *
1326   *
1327   *  \section Sec_ChangeLog081224 Version 081224
1328   *
1329   *  - MyUSB name changed to LUFA, the Lightweight USB Framework for AVRs
1330   *  - Fixed Mass Storage Host demo's MassStore_SendCommand() delay in the incorrect place
1331   *  - Fixed USBtoSerial demo not calling ReconfigureUSART() after a change in the line encoding
1332   *  - Fixed infinite loop in host mode Host-to-Device control transfers with data stages
1333   *  - HID report parser now supports devices with multiple reports in one interface via Report IDs
1334   *  - Fixed RZUSBSTICK board LED driver header incorrect macro definition order causing compile errors
1335   *  - Calling USB_Init() when the USB interface is already configured now forces a complete interface reset
1336   *    and re-enumeration - fixes MyUSB DFU bootloader not switching to app code correctly when soft reset used
1337   *  - Fixed "No newline at end of file" warning when stream callbacks are enabled
1338   *  - DFU bootloader now uses fixed signature bytes per device, rather than reading them out dynamically for size
1339   *  - Added new FIXED_CONTROL_ENDPOINT_SIZE and USE_SINGLE_DEVICE_CONFIGURATION switches to statically define certain values to
1340   *    reduce compiled binary size
1341   *  - Added new NO_LIMITED_CONTROLLER_CONNECT switch to prevent the library from trying to determine bus connection
1342   *    state from the suspension and wake up events on the smaller USB AVRs
1343   *  - Added summary of all library compile time tokens to the documentation
1344   *  - Added overview of the LUFA scheduler to the documentation
1345   *  - Removed MANUAL_PLL_CONTROL compile time token, replaced with a mask for the USB_Init() Options parameter
1346   *  - CDC bootloader now uses the correct non-far or far versions of the pgm_* functions depending on if RAMPZ is defined
1347   *  - Doxygen documentation now contains documentation on all the projects, bootloaders and most demos included with the library
1348   *  - CDC bootloader now runs user application when USB disconnected rather than waiting for a hard reset
1349   *  - MouseHostWithParser and KeyboardHostWithParser now support multiple-report devices
1350   *  - RNDIS demo can now close connections correctly using the new TCP_APP_CLOSECONNECTION() macro - used in Webserver
1351   *  - Fixed the DFU bootloader, no longer freezes up when certain files are programmed into an AVR, made reading/writing faster
1352   *  - Fixed mouse/joystick up/down movements reversed - HID mouse X/Y coordinates use a left-handed coordinate system, not a normal
1353   *    right-handed system
1354   *  - Added stub code to the CDC and USBtoSerial demos showing how to read and set the RS-232 handshake lines - not currently used in
1355   *    the demos, but the example code and supporting defines are now in place
1356   *  - Interrupts are now disabled when processing a control request in device mode, to avoid exceeding the strict control request
1357   *    timing requirements.
1358   *  - All demos now use a central StatusUpdate() function rather than direct calls to the board LED functions, so that the demos can
1359   *    easily be altered to show different LED combinations (or do something else entirely) as the demo's status changes
1360   *  - Removed LED commands from the CDC bootloader, unused by most AVR910 programming software
1361   *  - Fixed RNDIS demo ICMP ping requests echoing back incorrect data
1362   *  - Added DHCP server code to RNDIS demo, allowing for hands-free auto configuration on any PC
1363   *  - Fixed DFU bootloader PID value for the ATMEGA16U4 AVR
1364   *  - Endpoint and Pipe configuration functions now return an error code indicating success or failure
1365   *  - USB Reset in device mode now resets and disables all device endpoints
1366   *  - Added intermediate states to the host mode state machine, reducing the USB task blocking time to no more than 1ms explicitly per
1367   *    invocation when in host mode
1368   *  - Added support for the ATMEGA32U6 microcontroller
1369   *  - Added STATIC_ENDPOINT_CONFIGURATION compile time option, enabled in the bootloaders to minimize space usage
1370   *  - Removed redundant code from the USB device GetStatus() chapter 9 processing routine
1371   *  - Added new TeensyHID bootloader, compatible with the Teensy HID protocol (http://www.pjrc.com/teensy/)
1372   *  - Versions are now numbered by release dates, rather than arbitrary major/minor revision numbers
1373   *  - USB_RemoteWakeupEnabled is now correctly set and cleared by SetFeature and ClearFeature requests from the host
1374   *  - Changed prototype of GetDescriptor, so that it now returns the descriptor size (or zero if the descriptor doesn't exist)
1375   *    rather than passing the size back to the caller through a parameter and returning a boolean
1376   *
1377   *
1378   *  \section Sec_ChangeLog153 Version 1.5.3 (081002)
1379   *
1380   *  - Fixed CDC bootloader using pgmspace macros for some descriptors inappropriately
1381   *  - Updated all Mouse and Keyboard device demos to include boot protocol support (now works in BIOS)
1382   *  - Renamed bootloader directories to remove spaces, which were causing build problems on several OSes
1383   *  - Removed serial number strings from all but the MassStore demo where it is required - users were not
1384   *    modifying the code to either omit the descriptor or use a unique serial per device causing problems
1385   *    when multiple units of the same device were plugged in at the same time
1386   *  - AudioOutput and AudioInput demos now correctly silence endpoints when not enabled by the host
1387   *  - Added KeyboardMouse demo (Keyboard and Mouse functionality combined into a single demo)
1388   *  - Added DriverStubs directory to house board level driver templates, to make MyUSB compatible custom board
1389   *    driver creation easier
1390   *  - Extended MassStorage demo to support multiple LUNs, 2 by default
1391   *  - Fixed incorrect device address mask, preventing the device from enumerating with addresses larger than 63
1392   *  - Fixed incorrect data direction mask in the GetStatus standard request, preventing it from being handled
1393   *  - Fixed incorrect GetStatus standard request for endpoints, now returns the endpoint STALL status correctly
1394   *  - Added in new USB_RemoteWakeupEnabled and USB_CurrentlySelfPowered flags rather than using fixed values
1395   *  - Added DualCDC demo to demonstrate the use of Interface Association Descriptors
1396   *  - Added pipe NAK detection and clearing API
1397   *  - Added pipe status change (NAK, STALL, etc.) interrupt API
1398   *  - Fixed MassStorageHost demo so that it no longer freezes randomly when issuing several commands in a row
1399   *  - Host demos configuration descriptor routines now return a unique error code when the returned data does
1400   *    not have a valid configuration descriptor header
1401   *  - Added Endpoint_WaitUntilReady() and Pipe_WaitUntilReady() functions
1402   *  - Stream functions now have software timeouts, timeout period can be set by the USB_STREAM_TIMEOUT_MS token
1403   *  - All demos now pass the USB.org automated Chapter 9 device compliance tests
1404   *  - All HID demos now pass the USB.org automated HID compliance tests
1405   *  - Polling interval of the interrupt endpoint in the CDC based demos changed to 0xFF to fix problems on Linux systems
1406   *  - Changed stream functions to accept a new callback function, with NO_STREAM_CALLBACKS used to disable all callbacks
1407   *  - Mass Storage demo Dataflash management routines changed to use the endpoint stream functions
1408   *  - Added AVRStudio project files for each demo in addition to the existing Programmer's Notepad master project file
1409   *  - Re-added call to ReconfigureUSART() in USBtoSerial SetLineCoding request, so that baud rate changes
1410   *    are reflected in the hardware (change was previously lost)
1411   *
1412   *
1413   *  \section Sec_ChangeLog152 Version 1.5.2 (080731)
1414   *
1415   *  - Fixed SwapEndian_32() function in Common.h so that it now works correctly (wrong parameter types)
1416   *  - Updated RNDIS demo - notification endpoint is no longer blocking so that it works with faulty Linux RNDIS
1417   *    implementations (where the notification endpoint is ignored in favor of polling the control endpoint)
1418   *  - Fixed incorrect Vendor Description string return size in RNDIS demo for the OID_GEN_VENDOR_DESCRIPTION OID token
1419   *  - Added very basic TCP/IP stack and HTTP/TELNET servers to RNDIS demo
1420   *  - Fixed DFU bootloader exit causing programming software to complain about failed writes
1421   *  - Fixed DFU bootloader EEPROM programming mode wiping first flash page
1422   *  - Fixed Clear/Set Feature device standard request processing code (fixing MassStorage demo in the process)
1423   *  - Added support for the ATMEGA16U4 AVR microcontroller
1424   *  - Library license changed from LGPLv3 to MIT license
1425   *
1426   *
1427   *  \section Sec_ChangeLog151 Version 1.5.1 (080707)
1428   *
1429   *  - Changed host demos to enable the host function task on the firing of the USB_DeviceEnumerationComplete event
1430   *    rather than the USB_DeviceAttached event
1431   *  - HID Usage Stack now forcefully cleared after an IN/OUT/FEATURE item has been completely processed to remove
1432   *    any referenced but not created usages
1433   *  - Changed USB_INT_DisableAllInterrupts() and USB_INT_ClearAllInterrupts(), USB_Host_GetNextDescriptorOfType(),
1434   *    USB_Host_GetNextDescriptorOfTypeBefore(), USB_Host_GetNextDescriptorOfTypeAfter() to normal functions (from inline)
1435   *  - Fixed USBtoSerial demo not sending data, only receiving
1436   *  - Fixed main makefile to make all by default, fixed MagStripe directory case to prevent case-sensitive path problems
1437   *  - ConfigDescriptor functions made normal, instead of static inline
1438   *  - Pipe/Endpoint *_Ignore_* functions changed to *_Discard_*, old names still present as aliases
1439   *  - Fixed ENDPOINT_MAX_SIZE define to be correct on limited USB controller AVRs
1440   *  - Changed endpoint and pipe size translation routines to use previous IF/ELSE IF cascade code, new algorithmic
1441   *    approach was buggy and caused problems
1442   *  - Bootloaders now compile with -fno-inline-small-functions option to reduce code size
1443   *  - Audio demos now use correct endpoint sizes for full and limited controller USB AVRs, double banking in all cases
1444   *    to be in line with the specification (isochronous endpoints MUST be double banked)
1445   *  - Added Interface Association descriptor to StdDescriptors.h, based on the relevant USB2.0 ECN
1446   *  - Fixed MIDI demo, corrected Audio Streaming descriptor to follow the MIDI-specific AS structure
1447   *  - Fixed HID class demo descriptors so that the HID interface's protocol is 0x00 (required for non-boot protocol HID
1448   *    devices) to prevent problems on hosts expecting the boot protocol functions to be supported
1449   *  - Added read/write control stream functions to Endpoint.h
1450   *  - Fixed AudioOut demo not setting port pins to inputs on USB disconnect properly
1451   *  - Added RNDISEthernet demo application
1452   *
1453   *
1454   *  \section Sec_ChangeLog150 Version 1.5.0 (080610)
1455   *
1456   *  - Fixed MIDI demo, now correctly waits for the endpoint to be ready between multiple note messages
1457   *  - Added CDC Host demo application
1458   *  - Added KeyboardFullInt demo application
1459   *  - Endpoint and Pipe creation routines now mask endpoint/pipe size with the size mask, to remove transaction
1460   *    size bits not required for the routines (improves compatibility with devices)
1461   *  - Fixed AudioInput demo - now correctly sends sampled audio to the host PC
1462   *  - Fixed AudioOutput demo once more -- apparently Windows requires endpoint packets to be >=192 bytes
1463   *  - Shrunk round-robin scheduler code slightly via the use of struct pointers rather than array indexes
1464   *  - Fixed off-by-one error when determining if the Usage Stack is full inside the HID Report parser
1465   *  - Renamed Magstripe.h to MagstripeHW.h and moved driver out of the library and into the MagStripe demo folder
1466   *  - Added preprocessor checks to enable C linkage on the library components when used with a C++ compiler
1467   *  - Added Still Image Host demo application
1468   *  - The USB device task now restores the previously selected endpoint, allowing control requests to be transparently
1469   *    handled via interrupts while other endpoints are serviced through polling
1470   *  - Fixed device signature being sent in reverse order in the CDC bootloader
1471   *  - Host demos now have a separate ConfigDescriptor.c/.h file for configuration descriptor processing
1472   *  - HostWithParser demos now have a separate HIDReport.c/.h file for HID report processing and dumping
1473   *  - Removed non-mandatory commands from MassStorage demo to save space, fixed SENSE ResponseCode value
1474   *  - CDC demos now send empty packets after sending a full one to prevent buffering issues on the host
1475   *  - Updated demo descriptors to use VID/PID values donated by Atmel
1476   *  - Added DoxyGen documentation to the source files
1477   *  - Fixed Serial_IsCharReceived() definition, was previously reversed
1478   *  - Removed separate USB_Descriptor_Language_t descriptor, USB_Descriptor_String_t is used instead
1479   *  - Removed unused Device Qualifier descriptor structure
1480   *  - Renamed the USB_CreateEndpoints event to the more appropriate USB_ConfigurationChanged
1481   *  - Fixed MassStorageHost demo reading in the block data in reverse
1482   *  - Removed outdated typedefs in StdRequestType.h, superseded by the macro masks
1483   *  - Corrected OTG.h is now included when the AVR supports both Host and Device modes, for creating OTG products
1484   *  - USB_DeviceEnumerationComplete event is now also fired when in device mode and the host has finished its enumeration
1485   *  - Interrupt driven demos now properly restore previously selected endpoint when ISR is complete
1486   *  - The value of USB_HOST_TIMEOUT_MS can now be overridden in the user project makefile to a custom fixed timeout value
1487   *  - Renamed USB_Host_SOFGeneration_* macros to more friendly USB_Host_SuspendBus(), USB_Host_ResumeBus()
1488   *    and USB_Host_IsBusSuspended()
1489   *  - Renamed *_*_Is* macros to *_Is* to make all flag checking macros consistent, Pipe_SetInterruptFreq() is now
1490   *    Pipe_SetInterruptPeriod() to use the correct terminology
1491   *  - UnicodeString member of USB_Descriptor_String_t struct changed to an ordinary int array type, so that the GCC
1492   *    Unicode strings (prefixed with an L before the opening quotation mark) can be used instead of explicit arrays
1493   *    of ASCII characters
1494   *  - Fixed Endpoint/Pipes being configured incorrectly if the maximum endpoint/pipe size for the selected USB AVR
1495   *    model was given as the bank size
1496   *  - HID device demos now use a true raw array for the HID report descriptor rather than a struct wrapped array
1497   *  - Added VERSION_BCD() macro, fixed reported HID and USB version numbers in demo descriptors
1498   *  - Cleaned up GetDescriptor device chapter 9 handler function
1499   *  - Added GET_REPORT class specific request to HID demos to make them complaint to the HID class
1500   *  - Cleaned up setting of USB_IsInitialized and USB_IsConnected values to only when needed
1501   *  - Removed Atomic.c and ISRMacro.h; the library was already only compatible with recent avr-lib-c for other reasons
1502   *  - All demos and library functions now use USB standardized names for the USB data (bRequest, wLength, etc.)
1503   *  - Added USE_NONSTANDARD_DESCRIPTOR_NAMES token to switch back to the non-standard descriptor element names
1504   *
1505   *
1506   *  \section Sec_ChangeLog141 Version 1.4.1 (090519)
1507   *
1508   *  - Enhanced KeyboardWithParser demo, now prints out pressed alphanumeric characters like the standard demo
1509   *  - Fixed MassStorage demo, read/writes using non mode-10 commands now work correctly
1510   *  - Corrected version number in Version.h
1511   *
1512   *
1513   *  \section Sec_ChangeLog140 Version 1.4.0 (090505)
1514   *
1515   *  - Added HID Report Parser API to the library
1516   *  - Added Mouse and Keyboard host demo applications, using the new HID report parser engine
1517   *  - Added MouseFullInt demo, which demonstrates a fully interrupt (including control requests) mouse device
1518   *  - Fixed incorrect length value in the audio control descriptor of the AudioOutput and AudioInput demos
1519   *  - Added MIDI device demo application to the library
1520   *  - Fixed problem preventing USB devices from being resumed from a suspended state
1521   *  - Added new CDC class bootloader to the library, based on the AVR109 bootloader protocol
1522   *  - Added header to each demo application indicating the mode, class, subclass, standards used and supported speed
1523   *  - Functions expecting endpoint/pipe numbers are no longer automatically masked against ENDPOINT_EPNUM_MASK or
1524   *    PIPE_PIPENUM_MASK - this should be manually added to code which requires it
1525   *  - Fixed DFU class bootloader - corrected frequency of flash page writes, greatly reducing programming time
1526   *  - Renamed AVR_HOST_GetDeviceConfigDescriptor() to USB_Host_GetDeviceConfigDescriptor() and AVR_HOST_GetNextDescriptor()
1527   *    to USB_Host_GetNextDescriptor()
1528   *  - Added new USB_Host_GetNextDescriptorOfTypeBefore() and USB_Host_GetNextDescriptorOfTypeAfter() routines
1529   *  - Moved configuration descriptor routines to MyUSB/Drivers/USB/Class/, new accompanying ConfigDescriptors.c file
1530   *  - Added new configuration descriptor comparator API for more powerful descriptor parsing, updated host demos to use the
1531   *    new comparator API
1532   *  - Fixed MassStorageHost demo capacity printout, and changed data read/write mode from little-endian to the correct
1533   *    big-endian for SCSI devices
1534   *  - Fixed macro/function naming consistency; USB_HOST is now USB_Host, USB_DEV is now USB_Device
1535   *  - Added better error reporting to host demos
1536   *  - Added 10 microsecond delay after addressing devices in host mode, to prevent control stalls
1537   *
1538   *
1539   *  \section Sec_ChangeLog132 Version 1.3.2 (080401)
1540   *
1541   *  - Added call to ReconfigureUSART() in USBtoSerial SetLineCoding request, so that baud rate changes
1542   *    are reflected in the hardware
1543   *  - Fixed CDC and USBtoSerial demos - Stream commands do not work for control endpoints, and the
1544   *    GetLineCoding request had an incorrect RequestType mask preventing it from being processed
1545   *  - Improved reliability of the USBtoSerial demo, adding a busy wait while the buffer is full
1546   *  - Device control endpoint size is now determined from the device's descriptors rather than being fixed
1547   *  - Separated out SPI code into new SPI driver in AT90USBXXX driver directory
1548   *  - Bootloader now returns correct PID for the selected USB AVR model, not just the AT90USB128X PID
1549   *  - Added support for the RZUSBSTICK board
1550   *  - Bicolour driver removed in favor of generic LEDs driver
1551   *  - Added support for the ATMEGA32U4 AVR
1552   *  - Added MANUAL_PLL_CONTROL compile time option to prevent the USB library from manipulating the PLL
1553   *
1554   *
1555   *  \section Sec_ChangeLog131 Version 1.3.1 (080319)
1556   *
1557   *  - Fixed USB to Serial demo - class value in the descriptors was incorrect
1558   *  - Control endpoint size changed from 64 bytes to 8 bytes to save on USB FIFO RAM and to allow low
1559   *    speed mode devices to enumerate properly
1560   *  - USB to Serial demo data endpoints changed to dual-banked 16 byte to allow the demo to work
1561   *    on USB AVRs with limited USB FIFO RAM
1562   *  - Changed demo endpoint numbers to use endpoints 3 and 4 for double banking, to allow limited
1563   *    USB device controller AVRs (AT90USB162, AT90USB82) to function correctly
1564   *  - Updated Audio Out demo to use timer 1 for AVRs lacking a timer 3 for the PWM output
1565   *  - Fixed incorrect USB_DEV_OPT_HIGHSPEED entry in the Mass Storage device demo makefile
1566   *  - Optimized Mass Storage demo for a little extra transfer speed
1567   *  - Added LED indicators to the Keyboard demo for Caps Lock, Num Lock and Scroll Lock
1568   *  - Added Endpoint_Read_Stream, Endpoint_Write_Stream, Pipe_Read_Stream and Pipe_Write_Stream functions
1569   *    (including Big and Little Endian variants)
1570   *  - Made Dataflash functions inline for speed, removed now empty Dataflash.c driver file
1571   *  - Added new SetSystemClockPrescaler() macro (thanks to Joerg Wunsch)
1572   *  - Fixed Endpoint_ClearStall() to function correctly on full USB controller AVRs (AT90USBXXX6/7)
1573   *  - Endpoint_Setup_In_Clear() and Endpoint_Setup_Out_Clear() no longer set FIFOCON, in line with the
1574   *    directives in the datasheet
1575   *  - Fixed PLL prescaler defines for all AVR models and frequencies
1576   *  - Fixed ENDPOINT_INT_IN and ENDPOINT_INT_OUT definitions
1577   *  - Added interrupt driven keyboard and mouse device demos
1578   *  - Combined USB_Device_ClearFeature and USB_Device_SetFeature requests into a single routine for code
1579   *    size savings
1580   *  - Added missing Pipe_GetCurrentPipe() macro to Pipe.h
1581   *
1582   *
1583   *  \section Sec_ChangeLog130 Version 1.3.0 (080307)
1584   *
1585   *  - Unnecessary control endpoint config removed from device mode
1586   *  - Fixed device standard request interpreter accidentally processing some class-specific requests
1587   *  - Added USE_RAM_DESCRIPTORS and USE_EEPROM_DESCRIPTORS compile time options to instruct the library
1588   *    to use descriptors stored in RAM or EEPROM rather than flash memory
1589   *  - All demos now disable watchdog on startup, in case it has been enabled by fuses or the bootloader
1590   *  - USB_DEV_OPT_LOWSPEED option now works correctly
1591   *  - Added ability to set the USB options statically for a binary size reduction via the USE_STATIC_OPTIONS
1592   *    compile time define
1593   *  - USB_Init no longer takes a Mode parameter if compiled for a USB device with no host mode option, or
1594   *    if forced to a particular mode via the USB_HOST_ONLY or USB_DEVICE_ONLY compile time options
1595   *  - USB_Init no longer takes an Options parameter if options statically configured by USE_STATIC_OPTIONS
1596   *  - Endpoint_Ignore_* and Pipe_Ignore_* made smaller by making the dummy variable non-volatile so that the
1597   *    compiler can throw away the result more efficiently
1598   *  - Added in an optional GroupID value to each scheduler entry, so that groups of tasks can once again be
1599   *    controlled by the new Scheduler_SetGroupTaskMode() routine
1600   *  - Added support for AT90USB162 and AT90USB82 AVR models
1601   *  - Added support for the STK525 and STK526 boards
1602   *  - Added support for custom board drivers to be supplied by selecting the board type as BOARD_USER, and
1603   *    placing board drivers in {Application Directory}/Board/
1604   *  - PLL is now stopped and USB clock is frozen when detached from host in device mode, to save power
1605   *  - Joystick defines are now in sync with the schematics - orientation will be rotated for the USBKEY
1606   *  - Fixed USB_DEV_IsUSBSuspended() - now checks the correct register
1607   *  - Fixed data transfers to devices when in host mode
1608   *  - Renamed USB_DEV_OPT_HIGHSPEED to USB_DEV_OPT_FULLSPEED and USB_HOST_IsDeviceHighSpeed() to
1609   *    USB_HOST_IsDeviceFullSpeed() to be in line with the official USB speed names (to avoid confusion with
1610   *    the real high speed mode, which is unavailable on the USB AVRs)
1611   *
1612   *
1613   *  \section Sec_ChangeLog120 Version 1.2.0 (080204)
1614   *
1615   *  - Added USB_DeviceEnumerationComplete event for host mode
1616   *  - Added new Scheduler_Init routine to prepare the scheduler, so that tasks can be started and
1617   *    stopped before the scheduler has been started (via Scheduler_Start)
1618   *  - Connection events in both Device and Host mode are now interrupt-driven, allowing the USB management
1619   *    task to be stopped when the USB is not connected to a host or device
1620   *  - All demos updated to stop the USB task when not in use via the appropriate USB events
1621   *  - Mass Storage Host demo application updated to function correctly with all USB flash disks
1622   *  - Mass Storage Host demo application now prints out the capacity and number of LUNs in the attached
1623   *    device, and prints the first block as hexadecimal numbers rather than ASCII characters
1624   *  - Endpoint and Pipe clearing routines now clear the Endpoint/Pipe interrupt and status flags
1625   *  - Shifted error handling code in the host enum state machine to a single block, to reduce code complexity
1626   *  - Added in DESCRIPTOR_TYPE, DESCRIPTOR_SIZE and DESCRIPTOR_CAST macros to make config descriptor processing
1627   *    clearer in USB hosts and DESCRIPTOR_ADDRESS for convenience in USB devices
1628   *  - Added in alloca macro to common.h, in case the user is using an old version of avr-lib-c missing the macro
1629   *
1630   *
1631   *  \section Sec_ChangeLog110 Version 1.1.0 (080125)
1632   *
1633   *  - Fixed DCONNI interrupt being enabled accidentally after a USB reset
1634   *  - Fixed DDISCI interrupt not being disabled when a device is not connected
1635   *  - Added workaround for powerless pull-up devices causing false disconnect interrupts
1636   *  - Added USB_DeviceEnumerationFailed event for Host mode
1637   *  - AVR_HOST_GetDeviceConfigDescriptor routine no longer modifies ConfigSizePtr if a valid buffer
1638   *    pointer is passed
1639   *  - Added ALLOCABLE_BYTES to DynAlloc, and added code to make the size of key storage variables
1640   *    dependent on size of memory parameters passed in via the user project's makefile
1641   *  - Fixed incorrect device reset routine being called in USBTask
1642   *  - Devices which do not connect within the standard 300mS are now supported
1643   *  - Removed incorrect ATTR_PURE from Scheduler_SetTaskMode(), which was preventing tasks from being
1644   *    started/stopped, as well as USB_InitTaskPointer(), which was breaking dual device/host USB projects
1645   *  - Changed scheduler to use the task name rather than IDs for setting the task mode, eliminating the
1646   *    need to have a task ID list
1647   *  - ID transition interrupt now raises the appropriate device/host disconnect event if device attached
1648   *  - Fixed double VBUS change (and VBUS -) event when detaching in device mode
1649   *  - Added ability to disable ANSI terminal codes by the defining of DISABLE_TERMINAL_CODES in makefile
1650   *  - Removed return from ConfigurePipe and ConfigureEndpoint functions - use Pipe_IsConfigured() and
1651   *    Endpoint_IsConfigured() after calling the config functions to determine success
1652   */
1653