Documentation improvements - put driver example code into its own section, fix incorr...
[pub/USBasp.git] / LUFA / ManPages / 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_ChangeLogXXXXXX Version XXXXXX
10 * <b>New:</b>
11 * - Core:
12 * - Added new MIDIToneGenerator project
13 * - Added new ORDERED_EP_CONFIG compile time option to restrict endpoint/pipe configuration to ascending order
14 * in exchange for a smaller compiled program binary size
15 * - Added a new general RingBuff.h miscellaneous ring buffer library driver header
16 * - Added new GCC_FORCE_POINTER_ACCESS() macro to correct GCC's mishandling of struct pointer accesses
17 * - Added basic driver example use code to the library documentation
18 * - Library Applications:
19 * - Added ability to write protect Mass Storage disk write operations from the host OS
20 *
21 * <b>Changed:</b>
22 * - Core:
23 * - Unordered Endpoint/Pipe configuration is now allowed once again by default via the previous reconfig workaround
24 * - Refactored Host mode Class Driver *_Host_ConfigurePipes() routines to be more space efficient when compiled
25 * - Added new *_ENUMERROR_PipeConfigurationFailed error codes for the *_Host_ConfigurePipes() routines
26 * - The USARTStream global is now public and documented in the SerialStream module, allowing for the serial USART
27 * stream to be accessed via its handle rather than via the implicit stdout and stdin streams
28 * - Library Applications:
29 * - Changed the XPLAINBridge software UART to use the regular timer CTC mode instead of the alternative CTC mode
30 * via the Input Capture register, to reduce user confusion
31 * - Combined page and word ISP programming mode code in the AVRISP-MKII clone project to reduce compiled size and
32 * increase maintainability of the code
33 * - Changed over library projects to use the new general ring buffer library driver module
34 *
35 * <b>Fixed:</b>
36 * - Core:
37 * - Fixed broken USBFOO board drivers due to missing BOARD_USBFOO define
38 * - Fixed HID host class driver incorrectly binding to HID devices that do not have an OUT endpoint
39 * - Fixed incorrect definition of the HID_KEYBOARD_SC_D constant in the HID class driver (thanks to Opendous Inc.)
40 * - Fixed incorrect endpoint initialisation order in the several device demos (thanks to Rick Drolet)
41 * - Library Applications:
42 * - Fixed Benito project discarding incoming data from the USB virtual serial port when the USART is busy
43 * - Fixed broken DFU bootloader, added XPLAIN support for bootloader start when XCK jumpered to ground
44 * - Fixed broken HID_REQ_GetReport request handler in the Low Level GenericHID demo
45 * - Fixed possible lost data in the XPLAINBridge, USBtoSerial and Benito projects when the host exceeds the packet
46 * timeout period on received packets as set by USB_STREAM_TIMEOUT_MS (thanks to Justin Rajewski)
47 * - Fixed possible programming problem in the AVRISP-MKII clone project when programming specific patterns into a target
48 * memory space that is only byte (not page) addressable
49 *
50 * \section Sec_ChangeLog101122 Version 101122
51 * <b>New:</b>
52 * - Core:
53 * - Added new SCSI_ASENSE_NOT_READY_TO_READY_CHANGE constant to the Mass Storage class driver, to indicate when a previously
54 * not ready removable medium has now become ready for the host's use (thanks to Martin Degelsegger)
55 * - Moved the Pipe and Endpoint stream related code to two new USB library core source files EndpointStream.c and PipeStream.c
56 * - Added new USB_Device_GetFrameNumber() and USB_Host_GetFrameNumber() functions to retrieve the current USB frame number
57 * - Added new USB_Host_EnableSOFEvents(), USB_Host_DisableSOFEvents() and EVENT_USB_Host_StartOfFrame() for the user application
58 * handling of USB Start of Frame events while in USB Host mode
59 * - Added new PRNT_Host_BytesReceived(), PRNT_Host_ReceiveByte(), PRNT_Host_SendByte() and PRNT_Host_Flush() functions to the
60 * Print Host Class driver
61 * - Added class specific descriptor alternative struct type defines with standard USB-IF element naming
62 * - Added new project makefile template to the library and moved board driver stub files into in a new "CodeTemplates" directory
63 * - Added board hardware driver support for the Adafruit U4 breakout board
64 * - Added board hardware driver support for the Arduino Uno development board
65 * - Added board hardware driver support for the Blackcat USB JTAG board (thanks to the PSGroove team)
66 * - Added board hardware driver support for the Busware BUI development board
67 * - Added board hardware driver support for the Busware CUL V3 868MHZ radio board (thanks to Dirk Tostmann)
68 * - Added board hardware driver support for the Kernel Concepts USBFOO development board
69 * - Added board hardware driver support for the Linnix UDIP development board
70 * - Added board hardware driver support for the Olimex AVR-USB-162 development board (thanks to Steve Fawcett)
71 * - Added board hardware driver support for the Maximus board (thanks to the PSGroove team)
72 * - Added board hardware driver support for the Microsin AVR-USB162 breakout board
73 * - Added board hardware driver support for the Minimus board (thanks to the PSGroove team)
74 * - Added new NO_CLASS_DRIVER_AUTOFLUSH compile time option to disable automatic flushing of interfaces when the USB management
75 * tasks for each driver is called
76 * - Added standard keyboard HID report scancode defines (thanks to Laszlo Monda)
77 * - Added new Pipe_GetBusyBanks(), Endpoint_GetBusyBanks() and Endpoint_AbortPendingIN() functions
78 * - Library Applications:
79 * - Added default test tone generation mode to the Device mode AudioInput demos
80 * - Added new NO_BLOCK_SUPPORT, NO_EEPROM_BYTE_SUPPORT, NO_FLASH_BYTE_SUPPORT and NO_LOCK_BYTE_WRITE_SUPPORT compile time options to the
81 * CDC class bootloader
82 * - Added new XCK_RESCUE_CLOCK_ENABLE compile time option to the AVRISP-MKII clone programmer project (thanks to Tom Light)
83 *
84 * <b>Changed:</b>
85 * - Core:
86 * - Removed complicated logic for the Endpoint_ConfigureEndpoint() function to use inlined or function called versions
87 * depending of if the given bank size is a compile time constant, as the compiler does a better job of optimizing
88 * with basic code
89 * - Changed the signature of the CALLBACK_USB_GetDescriptor() callback function so that the descriptor pointer is const, to remove
90 * the need for extra casting inside the callback (thanks to Jonathan Kollasch)
91 * - Reduced HOST_DEVICE_SETTLE_DELAY_MS to 1000ms down from 1500ms to improve device compatibility while in USB Host mode
92 * - Removed the EVENT_USB_InitFailure() event, not specifying a USB mode correctly now defaults to UID selection mode
93 * - Renamed and moved class driver common constant definitions to make the naming scheme more uniform
94 * - Moved the USB mode specifier constants into a new enum, so that they are semantically related to one another
95 * - Renamed ENDPOINT_DOUBLEBANK_SUPPORTED() to ENDPOINT_BANKS_SUPPORTED() and changed it to return the maximum number of supported banks for
96 * the given endpoint
97 * - Better algorithm to extract and convert the internal device serial number into a string descriptor (if present)
98 * - All USB class drivers are now automatically included when LUFA/Drivers/USB.h is included, and no longer need to be seperately included
99 * - The MIDI class drivers now automatically flushes the MIDI interface when the MIDI class driver's USBTask() function is called
100 * - Renamed the EVENT_USB_Device_UnhandledControlRequest() event to EVENT_USB_Device_ControlRequest() as it is now fired before the library
101 * request handlers, not afterwards
102 * - Library Applications:
103 * - Changed over all device demos to use a clearer algorithm for the configuring of the application's endpoints
104 * - Added missing DataflashManager_CheckDataflashOperation() function to the MassStorageKeyboard demo, removed redundant
105 * SCSI_Codes.h file as these values are part of the MassStorage Class Driver
106 * - Added compile time error to the AVRISP-MKII project when built for the U4 chips, as the default VTARGET detection ADC channel
107 * does not exist on these chips (thanks to Marco)
108 * - Changed all Device mode LowLevel demos and Device Class drivers so that the control request is acknowledged and any data
109 * transferred as quickly as possible without any processing inbetween sections, so that long callbacks or event handlers will
110 * not break communications with the host by exceeding the maximum control request stage timeout period
111 * - Changed over all demos, drivers and internal functions to use the current frame number over the Start of Frame flag where possible
112 * to free up the Start of Frame flag for interrupt use in the user application
113 * - All project makefiles now correctly clean intermediate build files from assembly and C++ sources (thanks to Daniel Czigany)
114 * - Changed default value for the reset polarity parameter in the AVRISP-MKII project so that it defaults to active low drive
115 * - Changed configuration descriptor parser for all host mode projects and class drivers to ensure better compatibility with devices
116 * - All LowLevel demos changed to use the constants and types defined in the USB class drivers
117 * - Changed AudioInput and AudioOutput demos to reload the next sample via an interrupt rather than polling the sample timer
118 * - Rescue clock of the AVRISP-MKII moved to the AVR's OCR1A pin, so that the clock can be generated at all times
119 * - Changed ClassDriver MIDI demos to process all incomming events in a loop until the bank becomes empty rather than one at a time
120 * - Changed LowLevel MIDI demos to only clear the incomming event bank once it has become empty to support packed event packets
121 *
122 * <b>Fixed:</b>
123 * - Core:
124 * - Fixed USB_GetHIDReportItemInfo() function modifying the given report item's data when the report item does not exist
125 * within the supplied report of a multiple report HID device
126 * - Fixed critical pipe/endpoint memory allocation issue where the bank memory address space could be silently overlapped
127 * in the USB controller if the endpoints or pipes were allocated in anything other than ascending order (thanks to Martin Degelsegger)
128 * - Added LEDs_ToggleLEDs() function to several board LED drivers which were missing it (thanks to Andrei Krainev)
129 * - Fixed SET FEATURE and CLEAR FEATURE control requests directed at an unconfigured endpoint causing request timeouts
130 * - Fixed USB_Host_ClearPipeStall() incorrectly determining the endpoint direction from the currently selected pipe
131 * - Fixed JTAG_DEBUG_POINT() and JTAG_DEBUG_BREAK() macros not compiling under pure C99 standards mode
132 * - Fixed endpoint selection within the CALLBACK_HID_Device_CreateHIDReport() callback function causing broken GET REPORT requests
133 * - Fixed incorrect command name for EEPROM memory programming in the makefile dfu-ee target
134 * - Fixed incorrect LEDs_ChangeLEDs() function in the Benito board LED driver
135 * - Fixed incorrect USB_DeviceState value when unconfiguring the device without an address set
136 * - Fixed SPI driver not explicitly setting /SS and MISO pins as inputs when SPI_Init() is called
137 * - Fixed random enumeration failure while in device mode due to interrupts causing the Set Address request to exceed maximum timings
138 * - Fixed MIDI_Host_Flush() not aborting early when the specified MIDI host interface was not configured
139 * - Fixed MIDI class driver send routines silently discarding packets if the endpoint or pipe is busy (thanks to Robin Green)
140 * - Library Applications:
141 * - Fixed MassStorage based demos and projects resetting the SCSI sense values before the command is executed, leading to
142 * missed SCSI sense values when the host retrieves the sense key (thanks to Martin Degelsegger)
143 * - Fixed USBtoSerial and Benito project SetLineEncoding calls failing if the USART is busy, due to the RX ISR delaying the control
144 * request handler
145 * - Fixed LowLevel PrinterHost demo not sending control requests to the attached printer with the correct printer interface wIndex value
146 * - Fixed incorrect signature reported in the CDC class bootloader for the ATMEGA32U2
147 * - Fixed BootloaderCDC project failing on some operating systems due to removed Line Encoding options (thanks to Alexey Belyaev)
148 * - Fixed broken FLASH/EEPROM programming in the AVRISP-MKII clone project when writing in non-paged mode and the polling byte cannot be used
149 * - Fixed ISR definition conflict in the XPLAIN bridge between the software UART and the AVRISP-MKII ISP modules
150 * - Fixed USBtoSerial and XPLAINBridge demos discarding data from the PC if the send buffer becomes full
151 * - Fixed broken input in the MagStripe reader project due to an incorrect HID report descriptor
152 * - Fixed incorrect PollingIntervalMS values in the demo/project/bootloader endpoint descriptors (thanks to MCS Electronics)
153 * - Fixed AVRISP-MKII clone project not starting the target's program automatically after exiting TPI programming mode
154 *
155 * \section Sec_ChangeLog100807 Version 100807
156 * <b>New:</b>
157 * - Added new ADC_DisableChannel() function (thanks to Mich Davis)
158 * - Added new VTARGET_REF_VOLTS and VTARGET_SCALE_FACTOR compile time defines to the AVRISP-MKII programmer project to set
159 * the VTARGET reference voltage and scale factor
160 * - Added new pgm_read_ptr() macro to Common.h for reading of pointers out of flash memory space
161 * - Added new SWAPENDIAN_16() and SWAPENDIAN_32() macros to Common.h for statically initialized variables at compile time
162 * - Added new Drivers/USB/LowLevel/Device.c file to house Device mode specific functions that are more complicated than simple macros
163 * - Added new AVRStudio 4 project files for all library demos, projects and bootloaders
164 * - Added ability to set the serial baud rate via the user's terminal in the XPLAINBridge project
165 * - Added new LUFA module variables for the different source modules in the core library makefile to simplify project makefiles
166 * - Added start of a new Test and Measurement class demo (thanks to Peter Lawrence)
167 * - Added new SPI_ORDER_* data order masks to the SPI peripheral driver
168 * - Added support to the AVRISP-MKII project for ISP speeds slower than 125KHz via a new software SPI driver
169 * - Added support for the new button/LED on the latest model USBTINY-MKII
170 *
171 * <b>Changed:</b>
172 * - The RingBuff library code has been replaced in the XPLAINBridge, Benito and USBtoSerial projects with an ultra lightweight
173 * ring buffer to help improve the reliability of the projects
174 * - The EEPROM stream read/write functions now use eeprom_update_byte() instead of eeprom_write_byte(), so that only
175 * changed bytes are written to EEPROM to preserve its lifespan
176 * - Changed over the AVRISP-MKII and TemperatureDataLogger projects to use eeprom_update_byte() when writing non-volatile
177 * parameters to EEPROM to preserve its lifespan
178 * - Removed unused line encoding data and control requests from the CDC Bootloader code, to save space
179 * - Renamed SERIAL_STREAM_ASSERT() macro to STDOUT_ASSERT()
180 * - The USB_Device_IsRemoteWakeupSent() and USB_Device_IsUSBSuspended() macros have been deleted, as they are now obsolete
181 * - Rewrote the implementation of the SwapEndian_16() and SwapEndian_32() functions so that they compile down in most instances to
182 * minimal loads and stores rather than complicated shifts
183 * - The software UART in the XPLAINBridge has been largely altered to try to improve upon its performance and reliability
184 * - The USBtoSerial and Benito projects now flushes received data via a flush timer, so that several bytes can be transmitted at once
185 * - Removed the automated checking of event names in the demo, project and bootloader makefiles due to inconsistencies between the
186 * behaviour of the command line tools used to perform the check on each platform
187 * - Internal USB driver source files renamed and moved to ease future possible architecture ports
188 * - All internal pseudo-function macros have been converted to true inline functions for type-safety and readability
189 * - Changed LED indicator masks for the AVRISP-MKII project, so that there are defined roles for each LED
190 * - Altered the CDC Device and Host Class drivers' receive byte routines, so that no data is indicated by the function returning a
191 * negative value (thanks to Andreas Paulin)
192 * - Added auto flushing of OUT data to the CDC Host Class driver's USBTask function to automatically flush the send pipe buffer
193 *
194 * <b>Fixed:</b>
195 * - Fixed AVRISP project sending a LOAD EXTENDED ADDRESS command to 128KB AVRs after programming or reading from
196 * the last page of FLASH (thanks to Gerard Sexton)
197 * - Fixed AVRISP project not sending a full erase-and-write EEPROM command to XMEGA targets when writing to the EEPROM
198 * instead of the split write-only command (thanks to Tim Margush)
199 * - Fixed RNDISEthernet demos crashing when calculating checksums for Ethernet/TCP packets of more than ~500 bytes due to
200 * an overflow in the checksum calculation loop (thanks to Kevin Malec)
201 * - Fixed XPLAINBridge project not correctly reading the XMEGA's supply voltage when reporting back to the host
202 * - Fixed incorrect signature for the ATMEGA32U2 in the DFU bootloader (thanks to Axel Rohde)
203 * - Fixed internal device serial not being accessible on the ATMEGAXXU2 AVRs (thanks to Axel Rohde)
204 * - Fixed void pointer arithmetic in ConfigDescriptor.h breaking C++ compatibility (thanks to Michael Hennebry)
205 * - Fixed broken PDI EEPROM Section Erase functionality in the AVRISP-MKII project
206 * - Fixed USB_Device_SendRemoteWakeup() not working when the USB clock was frozen during USB bus suspend (thanks to Brian Dickman)
207 * - Fixed occasional lockup of the AVRISP project due to the timeout extension code incorrectly extending the timeout in
208 * PDI and TPI programming modes infinitely
209 * - Fixed HID device class driver still using PrevReportINBuffer for GetReport control requests even when it has been
210 * set to NULL by the user application (thanks to Axel Rohde)
211 * - Fixed MIDI_Device_SendEventPacket() not correctly waiting for the endpoint to become ready (thanks to Robin Green)
212 * - Fixed Benito and USBtoSerial projects not turning off the USART before reconfiguring it, which could cause incorrect
213 * operation to occur (thanks to Bob Paddock)
214 * - Fixed Serial peripheral driver not turning off the USART before reconfiguring it, which would cause incorrect operation
215 * to occur (thanks to Bob Paddock)
216 * - Fixed software application start command broken in the DFU class bootloader when dfu-programmer is used due to application
217 * start address corruption
218 *
219 * \section Sec_ChangeLog100513 Version 100513
220 * <b>New:</b>
221 * - Added incomplete MIDIToneGenerator project
222 * - Added new Relay Controller Board project (thanks to OBinou)
223 * - Added board hardware driver support for the Teensy, USBTINY MKII, Benito and JM-DB-U2 lines of third party USB AVR boards
224 * - Added new ATTR_NO_INIT variable attribute for global variables that should not be automatically cleared on startup
225 * - Added new ENDPOINT_*_BusSuspended error code to the Endpoint function, so that the stream functions early-abort if the bus
226 * is suspended before or during a transfer
227 * - Added new EVENT_CDC_Device_BreakSent() event and CDC_Host_SendBreak() function to the Device and Host CDC Class drivers
228 * - Added ReportType parameter to the HID device class driver CALLBACK_HID_Device_ProcessHIDReport() function so that FEATURE
229 * reports from the host to the device can be correctly processed
230 * - Added ReportType parameter to the HID host class driver HID_Host_SendReportByID() function so that FEATURE reports can be
231 * issued to the attached device
232 *
233 * <b>Changed:</b>
234 * - AVRISP programmer project now has a more robust timeout system
235 * - Added a timeout value to the TWI_StartTransmission() function, within which the addressed device must respond
236 * - Webserver project now uses the board LEDs to indicate the current IP configuration state
237 * - Added ENABLE_TELNET_SERVER compile time option to the Webserver project to disable the TELNET server if desired
238 * - Increased throughput of the USBtoSerial demo on systems that send multiple bytes per packet (thanks to Opendous Inc.)
239 * - Double bank CDC endpoints in the XPLAIN Bridge project, re-enable JTAG once the mode selection pin has been sampled.
240 * - Standardized the naming scheme given to configuration descriptor sub-elements in the Device mode demos, bootloaders
241 * and projects
242 * - All Class Driver Host mode demos now correctly set the board LEDs to READY once the enumeration process has completed
243 * - Added LIBUSB_FILTERDRV_COMPAT compile time option to the AVRISP programmer project to make the code compatible with Windows
244 * builds of avrdude at the expense of AVRStudio compatibility
245 * - Removed two-step endpoint/pipe bank clear and switch sequence for smaller, faster endpoint/pipe code
246 * - The USB_Init() function no longer calls sei() - the user is now responsible for enabling interrupts when they are ready
247 * for them to be enabled (thanks to Andrei Krainev)
248 * - The Audio_Device_IsSampleReceived() and Audio_Device_IsReadyForNextSample() functions are now inline, to reduce overhead
249 * - Removed the cast to uint16_t on the set baud rate in the USBtoSerial project, so that the higher >1M baud rates can be
250 * selected (thanks to Steffan Woltjer)
251 * - Removed software PDI and TPI emulation from the AVRISP-MKII clone project as it was very buggy and slow - PDI and TPI must
252 * now be implemented via separate programming headers
253 * - The CDC class bootloader now uses a watchdog reset rather than a soft-reset when exited to ensure that all hardware is
254 * properly reset to their defaults
255 * - Device mode class driver callbacks are now fired before the control request status stage is sent to prevent the host from
256 * timing out if another request is immediately fired and the device has a lengthy callback routine
257 * - The TeensyHID bootloader has been removed, per request from Paul at PJRC
258 * - The LIBUSB_FILTERDRV_COMPAT compile time option in the XPLAINBridge and AVRISP-MKII projects has been renamed
259 * LIBUSB_DRIVER_COMPAT, as it applies to all software on all platforms using the libUSB driver
260 *
261 * <b>Fixed:</b>
262 * - Fixed possible device lockup when INTERRUPT_CONTROL_ENDPOINT is enabled and the control endpoint is not properly
263 * selected when the ISR completes
264 * - Fixed AVRISP-MKII clone project not correctly issuing LOAD EXTENDED ADDRESS commands when the extended address
265 * boundary is crossed during programming or read back (thanks to Gerard Sexton)
266 * - Fixed warnings when building the AVRISP-MKII clone project with the ENABLE_XPROG_PROTOCOL compile time option disabled
267 * - Fixed software PDI/TPI programming mode in the AVRISP project not correctly toggling just the clock pin
268 * - Fixed TWI_StartTransmission() corrupting the contents of the GPIOR0 register
269 * - Fixed TWI driver not aborting when faced with no response after attempting to address a device on the bus
270 * - Fixed ADC routines not correctly returning the last result when multiple channels were read
271 * - Fixed ADC routines failing to read the extended channels (Channels 8 to 13, Internal Temperature Sensor) on the
272 * U4 series USB AVR parts
273 * - Fixed LowLevel MassStorage demo broken on the U2 series USB AVRs due to unsupported double-banked endpoint modes used
274 * - Fixed compilation error in the AudioInput demos when MICROPHONE_BIASED_TO_HALF_RAIL is defined (thanks to C. Scott Ananian)
275 * - Fixed incorrect definition of HID_ALIGN_DATA() causing incorrect HID report item data alignment
276 * - Fixed Still Image Host class driver not resetting the transaction ID when a new session is opened, fixed driver not sending
277 * a valid session ID to the device
278 * - Removed invalid dfu and flip related targets from the bootloaders - bootloaders can only be replaced with an external programmer
279 * - Fixed Set/Clear Feature requests directed to a non-configured endpoint not returning a stall to the host
280 * - Fixed HID Device Class Driver not allocating a temporary buffer when the host requests a report via the control endpoint and the
281 * user has set the PrevReportINBuffer driver configuration element to NULL (thanks to Lars Noschinski)
282 * - Fixed device state not being reset to DEVICE_STATE_Default if the host sets a 0x00 device address
283 * - Fixed device not stalling configuration requests before the device's address has been set
284 * - Fixed possibility of internal signature retrieval being corrupted if an interrupt occurs during a signature byte
285 * read (thanks to Andrei Krainev)
286 * - Fixed device state not being reset back to the default state if the host sets the address to 0
287 * - Fixed Set Configuration requests not being stalled until the host has set the device's address
288 * - Fixed Host mode HID class driver not sending the correct report type when HID_Host_SendReportByID() was called and the
289 * HID_HOST_BOOT_PROTOCOL_ONLY compile time option is set
290 * - Fixed INTERRUPT_CONTROL_ENDPOINT compile time option preventing other interrupts from occurring while the control endpoint
291 * request is being processed, causing possible lockups if a USB interrupt occurs during a transfer
292 * - Remove incorrect Abstract Call Management class specific descriptor from the CDC demos, bootloaders and projects
293 *
294 * \section Sec_ChangeLog100219 Version 100219
295 *
296 * <b>New:</b>
297 * - Added TPI programming support for 6-pin ATTINY devices to the AVRISP programmer project (thanks to Tom Light)
298 * - Added command timeout counter to the AVRISP project so that the device no longer freezes when incorrectly connected
299 * to a target
300 * - Added new TemperatureDataLogger application, a USB data logger which writes to the device's dataflash and appears to
301 * the host as a standard Mass Storage device when inserted
302 * - Added MIDI event packing support to the MIDI Device and Host mode Class drivers, allowing for multiple MIDI events to
303 * sent or received in packed form in a single USB packet
304 * - Added new MIDI send buffer flush routines to the MIDI Device and Host mode Class drivers, to flush packed events
305 * - Added master mode hardware TWI driver for easy TWI peripheral control
306 * - Added ADC MUX masks for the standard ADC input channels on all AVR models with an ADC, altered demos to use these masks
307 * as on some models, the channel number is not identical to its single-ended ADC MUX mask
308 * - New Webserver project, a RNDIS host USB webserver using the open source uIP TCP/IP network stack and FatFS library
309 * - New BOARD value option BOARD_NONE (equivalent to not specifying BOARD) which will remove all board hardware drivers which
310 * do not adversely affect the code operation (currently only the LEDs driver)
311 * - Added keyboard modifier masks (HID_KEYBOARD_MODIFER_*) and LED report masks (KEYBOARD_LED_*) to the HID class driver and
312 * Keyboard demos
313 * - Added .5MHz recovery clock to the AVRISP programmer project when in ISP programming mode to correct mis-set fuses
314 *
315 * <b>Changed:</b>
316 * - Slowed down software USART carried PDI programming in the AVRISP project to prevent transmission errors
317 * - Renamed the AVRISP project folder to AVRISP-MKII to reduce confusion
318 * - Renamed the RESET_LINE_* makefile tokens in the AVRISP MKII Project to AUX_LINE_*, as they are not always used for target
319 * reset
320 * - Changed over the MassStorageKeyboard Class driver device demo to use Start of Frame events rather than a timer to keep track
321 * of elapsed milliseconds
322 * - Inlined currently unused (but standardized) maintenance functions in the Device and Host Class drivers to save space
323 * - The XPLAINBridge project now selects between a USB to Serial bridge and a PDI programmer on startup, reading the JTAG port's
324 * TDI pin to determine which mode to use
325 * - Removed the stream example code from the Low Level VirtualSerial demos, as they were buggy and only served to add clutter
326 *
327 * <b>Fixed:</b>
328 * - Fixed AVRISP project not able to enter programming mode when ISP protocol is used
329 * - Fixed AVRISP PDI race condition where the guard time between direction changes could be interpreted as a start bit
330 * - Fixed ADC_IsReadingComplete() returning an inverted result
331 * - Fixed blocking CDC streams not aborting when the host is disconnected
332 * - Fixed XPLAIN board Dataflash driver broken due to incorrect preprocessor commands
333 * - Fixed inverted XPLAIN LED driver output (LED turned on when it was supposed to be turned off, and vice-versa)
334 * - Fixed Class Driver struct interface numbers in the KeyboardMouse and VirtualSerialMouse demos (thanks to Renaud Cerrato)
335 * - Fixed invalid USB controller PLL prescaler values for the ATMEGAxxU2 controllers
336 * - Fixed lack of support for the ATMEGA32U2 in the DFU and CDC class bootloaders
337 * - Fixed Benito project not resetting the target AVR automatically when programming has completed
338 * - Fixed DFU bootloader programming not discarding the correct number of filler bytes from the host when non-aligned programming
339 * ranges are specified (thanks to Thomas Bleeker)
340 * - Fixed CDC and RNDIS host demos and class drivers - bidirectional endpoints should use two separate pipes, not one half-duplex pipe
341 * - Fixed Pipe_IsEndpointBound() not taking the endpoint's direction into account
342 * - Fixed EEPROM and FLASH ISP programming in the AVRISP project
343 * - Fixed incorrect values of USB_CONFIG_ATTR_SELFPOWERED and USB_CONFIG_ATTR_REMOTEWAKEUP tokens (thanks to Claus Christensen)
344 * - Fixed SerialStream driver blocking while waiting for characters to be received instead of returning EOF
345 * - Fixed SerialStream driver not setting stdin to the created serial stream (thanks to Mike Alexander)
346 * - Fixed USB_GetHIDReportSize() returning the number of bits in the specified report instead of bytes
347 * - Fixed AVRISP project not extending the command delay after each successful page/word/byte program
348 * - Fixed accuracy of the SERIAL_UBBRVAL() and SERIAL_2X_UBBRVAL() macros for higher baud rates (thanks to Renaud Cerrato)
349 *
350 * \section Sec_ChangeLog091223 Version 091223
351 *
352 * <b>New:</b>
353 * - Added activity LED indicators to the AVRISP project to indicate when the device is busy processing a command
354 * - The USB target family and allowable USB mode tokens are now public and documented (USB_CAN_BE_*, USB_SERIES_*_AVR)
355 * - Added new XPLAIN USB to Serial Bridge project (thanks to John Steggall for initial proof-of-concept, David Prentice
356 * and Peter Danneger for revised software USART code)
357 * - Added new RNDIS Ethernet Host LowLevel demo
358 * - Added new RNDIS Ethernet Host Class Driver
359 * - Added new RNDIS Ethernet Host ClassDriver demo
360 * - Added CDC_Host_Flush() function to the CDC Host Class driver to flush sent data to the attached device
361 * - Added PDI programming support for XMEGA devices to the AVRISP programmer project (thanks to Justin Mattair)
362 * - Added support for the XPLAIN board Dataflash, with new XPLAIN_REV1 board target for the different dataflash used
363 * on the first revision boards compared to the one mounted on later revisions
364 * - Added new HID_ALIGN_DATA() macro to return the pre-retrieved value of a HID report item, left-aligned to a given datatype
365 * - Added new PreviousValue to the HID Report Parser report item structure, for easy monitoring of previous report item values
366 * - Added new EVK527 board target
367 * - Added new USB_Host_GetDeviceStringDescriptor() convenience function
368 * - Added new LEDNotification project to the library, to give a visual LED notification on new events from the host
369 * - Added new NO_DEVICE_REMOTE_WAKEUP and NO_DEVICE_SELF_POWER compile time options
370 *
371 * <b>Changed:</b>
372 * - Removed code in the Keyboard demos to send zeroed reports between two reports with differing numbers of key codes
373 * as this relied on non-standard OS driver behaviour to repeat key groups
374 * - The SCSI_Request_Sense_Response_t and SCSI_Inquiry_Response_t type defines are now part of the Mass Storage Class
375 * driver common defines, rather than being defined in the Host mode Class driver section only
376 * - The USB_MODE_HOST token is now defined even when host mode is not available
377 * - The CALLBACK_HID_Device_CreateHIDReport() HID Device Class driver callback now has a new ReportType parameter to
378 * indicate the report type to generate
379 * - All Class Drivers now return false or the "DeviceDisconnected" error code of their respective error enums when a function
380 * is called when no host/device is connected where possible
381 * - The HOST_SENDCONTROL_DeviceDisconnect enum value has been renamed to HOST_SENDCONTROL_DeviceDisconnected to be in line
382 * with the rest of the library error codes
383 * - Make MIDI device demos also turn off the on board LEDs if MIDI Note On messages are sent with a velocity of zero,
384 * which some devices use instead of Note Off messages (thanks to Robin Green)
385 * - The CDC demos are now named "VirtualSerial" instead to indicate the demos' function rather than its implemented USB class,
386 * to reduce confusion and to be in line with the rest of the LUFA demos
387 * - The SImage_Host_SendBlockHeader() and SImage_Host_ReceiveBlockHeader() Still Image Host Class driver functions are now public
388 *
389 * <b>Fixed:</b>
390 * - Added missing CDC_Host_CreateBlockingStream() function code to the CDC Host Class driver
391 * - Fixed incorrect values for REPORT_ITEM_TYPE_* enum values causing corrupt data in the HID Host Parser
392 * - Fixed misnamed SI_Host_USBTask() and SI_Host_ConfigurePipes() functions
393 * - Fixed broken USB_GetNextDescriptor() function causing the descriptor to jump ahead double the expected amount
394 * - Fixed Pipe_IsEndpointBound() not masking the given Endpoint Address against PIPE_EPNUM_MASK
395 * - Fixed host state machine not enabling Auto VBUS mode when HOST_DEVICE_SETTLE_DELAY_MS is set to zero
396 * - Fixed misnamed Pipe_SetPipeToken() macro for setting a pipe's direction
397 * - Fixed CDCHost failing on devices with bidirectional endpoints
398 * - Fixed USB driver failing to define the PLL prescaler mask for the ATMEGA8U2 and ATMEGA16U2
399 * - Fixed HID Parser not distributing the Usage Min and Usage Max values across an array of report items
400 * - Fixed Mass Storage Host Class driver and Low Level demo not clearing the error condition if an attached device returns a
401 * STALL to a GET MAX LUN request (thanks to Martin Luxen)
402 * - Fixed TeensyHID bootloader not properly shutting down the USB interface to trigger a disconnection on the host before resetting
403 * - Fixed MassStorageHost Class driver demo not having USB_STREAM_TIMEOUT_MS compile time option set properly to prevent slow
404 * devices from timing out the data pipes
405 * - Fixed the definition of the Endpoint_BytesInEndpoint() macro for the U4 series AVR parts
406 * - Fixed MIDI host Class driver MIDI_Host_SendEventPacket() routine not properly checking for Pipe ready before writing
407 * - Fixed use of deprecated struct initializers, removed library unused parameter warnings when compiled with -Wextra enabled
408 * - Fixed Still Image Host Class driver truncating the PIMA response code (thanks to Daniel Seibert)
409 * - 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
410 * used (thanks to Daniel Levy)
411 * - Fixed TeensyHID bootloader not enumerating to the host correctly (thanks to Clint Fisher)
412 * - Fixed AVRISP project timeouts not checking for the correct timeout period (thanks to Carl Ott)
413 * - Fixed STK525 Dataflash driver using incorrect bit-shifting for Dataflash addresses (thanks to Tim Mitchell)
414 *
415 * \section Sec_ChangeLog091122 Version 091122
416 *
417 * <b>New:</b>
418 * - Added new Dual Role Keyboard/Mouse demo
419 * - Added new HID_HOST_BOOT_PROTOCOL_ONLY compile time token to reduce the size of the HID Host Class driver when
420 * Report protocol is not needed
421 * - Added new MIDI LowLevel and ClassDriver Host demo, add new MIDI Host Class driver
422 * - Added new CDC/Mouse ClassDriver device demo
423 * - Added new Joystick Host ClassDriver and LowLevel demos
424 * - Added new Printer Host mode Class driver
425 * - Added new Printer Host mode ClassDriver demo
426 * - Added optional support for double banked endpoints and pipes in the Device and Host mode Class drivers
427 * - Added new stream creation function to the CDC Class drivers, to easily make standard I/O streams from CDC Class driver instances
428 *
429 * <b>Changed:</b>
430 * - Removed mostly useless "TestApp" demo, as it was mainly useful only for checking for syntax errors in the library
431 * - MIDI device demos now receive MIDI events from the host and display note ON messages via the board LEDs
432 * - Cleanups to the Device mode Mass Storage demo application SCSI routines
433 * - Changed Audio Class driver sample read/write functions to be inline, to reduce the number of cycles needed to transfer
434 * samples to and from the device (allowing more time for sample processing and output)
435 * - Audio class Device mode demos now work at both 16MHz and 8MHz, rather than just at 8MHz
436 * - The previous USBtoSerial demo has been moved into the projects directory, as it was just a modified CDC demo
437 * - The Endpoint/Pipe functions now use the const qualifier on the input buffer
438 * - Changed the CALLBACK_HIDParser_FilterHIDReportItem() callback to pass a HID_ReportItem_t rather than just the current
439 * item's attributes, to expose more information on the item (including it's type, collection path, etc.)
440 * - Changed MouseHostWithParser demos to check that the report items have a Mouse usage collection as a parent at some point,
441 * to prevent Joysticks from enumerating with the demo
442 * - Corrected the name of the misnamed USB_GetDeviceConfigDescriptor() function to USB_Host_GetDeviceConfigDescriptor().
443 * - Keyboard LowLevel/ClassDriver demos now support multiple simultaneous key presses (up to 6) per report
444 *
445 * <b>Fixed:</b>
446 * - Fixed PrinterHost demo returning invalid Device ID data when the attached device does not have a
447 * device ID (thanks to Andrei Krainev)
448 * - Changed LUFA_VERSION_INTEGER define to use BCD values, to make comparisons easier
449 * - Fixed issue in the HID Host class driver's HID_Host_SendReportByID() routine using the incorrect mode (control/pipe)
450 * to send report to the attached device
451 * - Fixed ClassDriver AudioOutput device demo not selecting an audio output mode
452 * - Fixed incorrect SampleFrequencyType value in the AudioInput and AudioOutput ClassDriver demos' descriptors
453 * - Fixed incorrect event name rule in demo/project/bootloader makefiles
454 * - Fixed HID device class driver not reselecting the correct endpoint once the user callback routines have been called
455 * - Corrected HID descriptor in the Joystick Device demos - buttons should be placed outside the pointer collection
456 * - Fixed HID report parser collection paths invalid due to misplaced semicolon in the free path item search loop
457 * - Fixed HID host Class driver report send/receive report broken when issued through the control pipe
458 * - Fixed HOST_STATE_AS_GPIOR compile time option being ignored when in host mode (thanks to David Lyons)
459 * - Fixed LowLevel Keyboard demo not saving the issues report only after it has been sent to the host
460 * - Fixed Endpoint_Write_Control_Stream_* functions not sending a terminating IN when given data Length is zero
461 *
462 * \section Sec_ChangeLog090924 Version 090924
463 *
464 * <b>New:</b>
465 * - Added new host mode class drivers and matching demos to the library for rapid application development
466 * - Added flag to the HID report parser to indicate if a device has multiple reports
467 * - Added new EVENT_USB_Device_StartOfFrame() event, controlled by the new USB_Device_EnableSOFEvents() and
468 * USB_Device_DisableSOFEvents() macros to give bus-synchronized millisecond interrupts when in USB device mode
469 * - Added new Endpoint_SetEndpointDirection() macro for bidirectional endpoints
470 * - Added new AVRISP project, a LUFA powered clone of the Atmel AVRISP-MKII programmer
471 * - Added ShutDown() functions for all hardware peripheral drivers, so that peripherals can be turned off after use
472 * - Added new CDC_Device_Flush() command to the device mode CDC Class driver to flush Device->Host data
473 * - Added extra masks to the SPI driver, changed SPI_Init() so that the clock polarity and sample modes can be set
474 * - Added new callback to the HID report parser, so that the user application can filter only the items it is interested
475 * in to be stored into the HIDReportInfo structure to save RAM
476 * - Added support for the officially recommended external peripheral layout for the BUMBLEB board (thanks to Dave Fletcher)
477 * - Added new Pipe_IsFrozen() macro to determine if the currently selected pipe is frozen
478 * - Added new USB_GetHIDReportSize() function to the HID report parser to retrieve the size of a given report by its ID
479 * - Added new combined Mass Storage and Keyboard demo (thanks to Matthias Hullin)
480 *
481 * <b>Changed:</b>
482 * - SetIdle requests to the HID device driver with a 0 idle period (send changes only) now only affect the requested
483 * HID interface within the device, not all HID interfaces
484 * - Added explicit attribute masks to the device mode demos' descriptors
485 * - Added return values to the CDC and MIDI class driver transmit functions
486 * - Optimized Endpoint_Read_Word_* and Pipe_Read_Word_* macros to reduce compiled size
487 * - Added non-null function parameter pointer restrictions to USB Class drivers to improve user code reliability
488 * - Added new "Common" section to the class drivers, to hold all mode-independent definitions for clarity
489 * - Moved SCSI command/sense constants into the Mass Storage Class driver, instead of the user-code
490 * - Altered the SCSI commands in the LowLevel Mass Storage Host to save on FLASH space by reducing function calls
491 * - Changed the parameters and behaviour of the USB_GetDeviceConfigDescriptor() function so that it now performs size checks
492 * and data validations internally, to simplify user code
493 * - Changed HIDParser to only zero out important values in the Parsed HID Report Item Information structure to save cycles
494 * - The HID report parser now always processed FEATURE items - HID_ENABLE_FEATURE_PROCESSING token now has no effect
495 * - The HID report parser now always ignores constant-data items, HID_INCLUDE_CONSTANT_DATA_ITEMS token now has no effect
496 * - The Benito Programmer project now has its own unique VID/PID pair allocated from the Atmel donated LUFA VID/PID pool
497 * - Add in new invalid event hook check targets to project makefiles to produce compilation errors when invalid event names
498 * are used in a project
499 * - The HID Report Parser now gives information on the total length of each report within a HID interface
500 * - The USE_NONSTANDARD_DESCRIPTOR_NAMES compile time token has been removed - there are now separate USB_Descriptor_* and
501 * USB_StdDescriptor_* structures for both the LUFA and standardized element naming conventions so both may be used
502 *
503 * <b>Fixed:</b>
504 * - Fixed possible lockup in the CDC device class driver, when the host sends data that is a multiple of the
505 * endpoint's bank
506 * - Fixed swapped parameters in the HID state memory copy call while processing a HID PUSH item in the HID report parser
507 * - Fixed memory corruption HID report parser when too many COLLECTION or PUSH items were processed
508 * - Fixed HID report parser not resetting the FEATURE item count when a REPORT ID item is encountered
509 * - Fixed USBtoSerial demos not reading in UDR1 when the USART receives data but the USB interface is not enumerated,
510 * causing continuous USART receive interrupts
511 * - Fixed misspelled event name in the Class driver USBtoSerial demo, preventing correct operation
512 * - Fixed invalid data being returned when a GetStatus request is issued in Device mode with an unhandled data recipient
513 * - Added hardware USART receive interrupt and software buffering to the Benito project to ensure received data is not
514 * missed or corrupted
515 * - Fixed Device mode HID Class driver always sending IN packets, even when nothing to report
516 * - Fixed Device mode HID Class driver not explicitly initializing the ReportSize parameter to zero before calling callback
517 * routine, so that ignored callbacks don't cause incorrect data to be sent
518 * - Fixed StillImageHost not correctly freezing and unfreezing data pipes while waiting for a response block header
519 * - Fixed error in the PrinterHost demo preventing the full page data from being sent to the attached device (thanks to John Andrews)
520 * - Fixed CDC based demos and projects' INF driver files under 64 bit versions of Windows (thanks to Ronny Hanson, Thomas Bleeker)
521 * - Re-add in missing flip, flip-ee, dfu and dfu-ee targets to project makefiles (thanks to Opendous Inc.)
522 * - Fix allowable F_CPU values comment in project makefiles to more accurately reflect the allowable values on the USB AVRs
523 * - Fixed DFU and CDC class bootloaders on the series 2 USB AVRs, corrected invalid signatures, added support for the new
524 * ATMEGAxx2 series 2 variant AVRs to the DFU bootloader
525 * - Fixed Low Level USBtoSerial demo not storing received characters (thanks to Michael Cooper)
526 * - Fixed MIDI Device Class driver not sending/receiving MIDI packets of the correct size (thanks to Thomas Bleeker)
527 *
528 *
529 * \section Sec_ChangeLog090810 Version 090810
530 *
531 * <b>New:</b>
532 * - Added new device class drivers and matching demos to the library for rapid application development
533 * - Added new PrinterHost demo (thanks to John Andrews)
534 * - Added USB Missile Launcher project, submitted by Dave Fletcher
535 * - Added new Benito Arduino Programmer project
536 * - Added incomplete device and host mode demos for later enhancement
537 * - Updated MassStorage device block write routines to use ping-pong Dataflash buffering to increase throughput by around 30%
538 * - Error status LEDs shown when device endpoint configuration fails to complete in all demos and projects
539 * - Added new USB_Host_SetDeviceConfiguration() convenience function for easy configuration selection of devices while in USB
540 * host mode
541 * - Added new USB_Host_ClearPipeStall() convenience function to clear a stall condition on an attached device's endpoint
542 * - Added new USB_Host_GetDeviceDescriptor() convenience function to retrieve the attached device's Device descriptor
543 * - Added new Endpoint_ClearStatusStage() convenience function to assist with the status stages of control transfers
544 * - Added new USE_INTERNAL_SERIAL define for using the unique serial numbers in some AVR models as the USB device's serial number,
545 * added NO_INTERNAL_SERIAL compile time option to turn off new serial number reading code
546 * - Added new DATAFLASH_CHIP_MASK() macro to the Dataflash driver, which returns the Dataflash select mask for the given chip index
547 * - Added new HOST_STATE_WaitForDeviceRemoval host state machine state for non-blocking disabling of device communications until the
548 * device has been removed (for use when an error occurs or communications with the device have completed)
549 * - Added new FAST_STREAM_TRANSFERS compile time option for faster stream transfers via multiple bytes copied per stream loop
550 * - Added stdio stream demo code to the CDC device demos, to show how to create standard streams out of the virtual serial ports
551 * - Added new EEPROM and FLASH buffer versions of the Endpoint and Pipe stream functions
552 * - Added new USE_FLASH_DESCRIPTORS and FIXED_NUM_CONFIGURATIONS compile time options
553 * - Added support for the new ATMEGA32U2, ATMEGA16U2 and ATMEGA8U2 AVR models
554 * - Added new USB_DeviceState variable to keep track of the current Device mode USB state
555 * - Added new LEDs_ToggleLEDs() function to the LEDs driver
556 * - Added new Pipe_BoundEndpointNumber() and Pipe_IsEndpointBound() functions
557 * - Added new DEVICE_STATE_AS_GPIOR and HOST_STATE_AS_GPIOR compile time options
558 * - Added 404 Not Found errors to the webserver in the RNDIS demos to indicate invalid URLs
559 *
560 * <b>Changed:</b>
561 * - Deprecated pseudo-scheduler and removed dynamic memory allocator from the library (first no longer needed and second unused)
562 * - The device-mode CALLBACK_USB_GetDescriptor() function now has an extra parameter so that the memory space in which the requested
563 * descriptor is located can be specified. This means that descriptors can now be located in multiple memory spaces within a device.
564 * - Removed vague USB_IsConnected global - test USB_DeviceState or USB_HostState explicitly to gain previous functionality
565 * - Removed USB_IsSuspended global - test USB_DeviceState against DEVICE_STATE_Suspended instead
566 * - Extended USB_GetDeviceConfigDescriptor() routine to require the configuration number within the device to fetch
567 * - Dataflash_WaitWhileBusy() now always ensures that the dataflash is ready for the next command immediately after returning,
568 * no need to call Dataflash_ToggleSelectedChipCS() afterwards
569 * - Low level API MIDI device demo no longer blocks if a note change event is sent while the endpoint is not ready
570 * - Pipe_GetErrorFlags() now returns additional error flags for overflow and underflow errors
571 * - Pipe stream functions now automatically set the correct pipe token, so that bidirectional pipes can be used
572 * - Pipe_ConfigurePipe() now automatically defaults IN pipes to accepting infinite IN requests, this can still be changed by calling
573 * the existing Pipe_SetFiniteINRequests() function
574 * - Changed F_CLOCK entries in project makefiles to alias to F_CPU by default, as this is the most common case
575 * - Host mode demos now use sane terminal escape codes, so that text is always readable and events/program output is visually distinguished
576 * from one another using foreground colours
577 * - Internal per-device preprocessing conditions changed to per-device series rather than per-controller group for finer-grain
578 * internal control
579 * - Interrupts are no longer disabled during the processing of Control Requests on the default endpoint while in device mode
580 * - AudioOutput demos now always output to board LEDs, regardless of output mode (removed AUDIO_OUT_LEDS project option)
581 * - Removed SINGLE_DEVICE_CONFIGURATION compile time option in favor of the new FIXED_NUM_CONFIGURATIONS option so that the exact number
582 * of device configurations can be defined statically
583 * - Removed VBUS events, as they are already exposed to the user application via the regular device connection and disconnection events
584 * - Renamed and altered existing events to properly separate out Host and Device mode events
585 * - All demos switched over from GNU99 standards mode to C99 standards mode, to reduce the dependancies on GCC-only language extensions
586 *
587 * <b>Fixed:</b>
588 * - Changed bootloaders to use FLASHEND rather than the existence of RAMPZ to determine if far FLASH pointers are needed to fix
589 * bootloaders on some of the USB AVR devices where avr-libc erroneously defines RAMPZ
590 * - Fixes to MassStorageHost for better device compatibility (increase command timeout, change MassStore_WaitForDataReceived()
591 * to only unfreeze and check one data pipe at a time) to prevent incorrect device enumerations and freezes while transferring data
592 * - Make Pipe_ConfigurePipe() mask the given endpoint number against PIPE_EPNUM_MASK to ensure the endpoint IN direction bit is
593 * cleared to prevent endpoint type corruption
594 * - Fixed issue opening CDC-ACM ports on hosts when the CDC device tries to send data before the host has set the line encoding
595 * - Fixed USB_OPT_MANUAL_PLL option being ignored during device disconnects on some models (thanks to Brian Dickman)
596 * - Fixed documentation mentioning Pipe_GetCurrentToken() function when correct function name is Pipe_GetPipeToken()
597 * - Fixed ADC driver for the ATMEGA32U4 and ATMEGA16U4 (thanks to Opendous Inc.)
598 * - Fixed CDCHost demo unfreezing the pipes at the point of configuration, rather than use
599 * - Fixed MassStorage demo not clearing the reset flag when a Mass Storage Reset is issued while not processing a command
600 * - Fixed USB_Host_SendControlRequest() not re-suspending the USB bus when initial device ready-wait fails
601 * - Fixed USB Pad regulator not being disabled on some AVR models when the USB_OPT_REG_DISABLED option is used
602 * - Fixed Host mode to Device mode UID change not causing a USB Disconnect event when a device was connected
603 * - Fixed Mouse/Keyboard demos not performing the correct arithmetic on the Idle period at the right times (thanks to Brian Dickman)
604 * - Fixed GenericHID failing HID class tests due to incorrect Logical Minimum and Logical Maximum values (thanks to Søren Greiner)
605 * - Fixed incorrect PIPE_EPNUM_MASK mask causing pipe failures on devices with endpoint addresses of 8 and above (thanks to John Andrews)
606 * - Fixed report data alignment issues in the MouseHostWithParser demo when X and Y movement data size is not a multiple of 8 bits
607 * - Fixed HID Report Descriptor Parser not correctly resetting internal states when a REPORT ID element is encountered
608 * - Fixed incorrect BUTTONS_BUTTON1 for the STK526 target
609 * - Fixed RNDIS demos freezing when more than one connection was attempted simultaneously, causing memory corruption
610 * - Fixed USBtoSerial demo receiving noise from the USART due to pull-up not being enabled
611 *
612 *
613 * \section Sec_ChangeLog090605 Version 090605
614 *
615 * - Fixed bug in RNDISEthernet and DualCDC demos not using the correct USB_ControlRequest structure for control request data
616 * - Fixed documentation showing incorrect USB mode support on the supported AVRs list
617 * - Fixed RNDISEthernet not working under Linux due to Linux requiring an "optional" RNDIS request which was unhandled
618 * - Fixed Mouse and Keyboard device demos not acting in accordance with the HID specification for idle periods (thanks to Brian Dickman)
619 * - Removed support for endpoint/pipe non-control interrupts; these did not act in the way users expected, and had many subtle issues
620 * - Fixed Device Mode not handling Set Feature and Clear Feature Chapter 9 requests that are addressed to the device (thanks to Brian Dickman)
621 * - Moved control endpoint interrupt handling into the library itself, enable via the new INTERRUPT_CONTROL_ENDPOINT token
622 * - Fixed CDCHost not clearing configured pipes and resetting configured pipes mask when a partially enumerated invalid CDC
623 * interface is skipped
624 * - Clarified the size of library tokens which accept integer values in the Compile Time Tokens page, values now use the smallest datatype
625 * inside the library that is able to hold their defined value to save space
626 * - Removed DESCRIPTOR_ADDRESS() macro as it was largely superfluous and only served to obfuscate code
627 * - Rewritten event system to remove all macros, to make user code clearer
628 * - Fixed incorrect ENDPOINT_EPNUM_MASK mask preventing endpoints above EP3 from being selected (thanks to Jonathan Oakley)
629 * - Removed STREAM_CALLBACK() macro - callbacks now use regular function definitions to clarify user code
630 * - Removed DESCRIPTOR_COMPARATOR() macro - comparators should now use regular function definitions to clarify user code
631 * - USB_IsConnected is now cleared before the USB_Disconnect() event is fired in response to VBUS being removed
632 * - Fixed incorrect PID value being used in the USBtoSerial project (thanks to Phill)
633 * - Deleted StdDescriptors.c, renamed USB_GetDescriptor() to CALLBACK_USB_GetDescriptor, moved ConfigDescriptor.c/.h from the
634 * LUFA/Drivers/USB/Class/ directory to LUFA/Drivers/USB/HighLevel/ in preparation for the new USB class APIs
635 * - Moved out each demos' functionality library files (e.g. Ring Buffer library) to /Lib directories for a better directory structure
636 * - Removed Tx interrupt from the USBtoSerial demo; now sends characters via polling to ensure more time for the Rx interrupt
637 * - Fixed possible enumeration errors from spin-loops which may fail to exit if the USB connection is severed before the exit condition
638 * becomes true
639 *
640 *
641 * \section Sec_ChangeLog090510 Version 090510
642 *
643 * - Added new GenericHIDHost demo
644 * - Corrections to the KeyboardHost and MouseHost demos' pipe handling to freeze and unfreeze the data pipes at the point of use
645 * - KeyboardHost, MouseHost and GenericHIDHost demos now save and restore the currently selected pipe inside the pipe ISR
646 * - Changed GenericHID device demo to use the LUFA scheduler, added INTERRUPT_DATA_ENDPOINT and INTERRUPT_CONTROL_ENDPOINT compile
647 * time options
648 * - All comments in the library, bootloaders, demos and projects have now been spell-checked and spelling mistakes/typos corrected
649 * - Added new PIMA_DATA_SIZE() define to the Still Image Host demo
650 * - Add call to MassStore_WaitForDataReceived() in MassStore_GetReturnedStatus() to ensure that the CSW has been received in the
651 * extended MSC timeout period before continuing, to prevent long processing delays from causing the MassStore_GetReturnedStatus()
652 * to early-abort (thanks to Dmitry Maksimov)
653 * - Move StdRequestType.h, StreamCallbacks.h, USBMode.h from the LowLevel USB driver directory to the HighLevel USB driver directory,
654 * where they are more suited
655 * - Removed all binary constants and replaced with decimal or hexadecimal constants so that unpatched GCC compilers can still build the
656 * code without having to be itself patched and recompiled first
657 * - Added preprocessor checks and documentation to the bootloaders giving information about missing SIGNATURE_x defines due to
658 * outdated avr-libc versions.
659 * - Added support to the CDCHost demo for devices with multiple CDC interfaces which are not the correct ACM type preceding the desired
660 * ACM CDC interface
661 * - Fixed GenericHID demo not starting USB and HID management tasks when not using interrupt driven modes (thanks to Carl Kjeldsen)
662 * - Fixed RNDISEthenet demo checking the incorrect message field for packet size constraints (thanks to Jonathan Oakley)
663 * - Fixed WriteNextReport code in the GenericHIDHost demo using incorrect parameter types and not selecting the correct endpoint
664 * - Adjusted sample CTC timer calculations in the AudioOutput and AudioInput demos to match the CTC calculations in the AVR datasheet,
665 * and to fix instances where rounding caused the endpoint to underflow (thanks to Robin Theunis)
666 * - The USB_Host_SendControlRequest() function no longer automatically selects the Control pipe (pipe 0), so that other control type
667 * pipes can be used with the function
668 * - The USB Host management task now saves and restores the currently selected pipe before and after the task completes
669 * - Fixed GenericHIDHost demo report write routine incorrect for control type requests (thanks to Andrei Krainev)
670 * - Removed Endpoint_ClearCurrentBank() and Pipe_ClearCurrentBank() in favor of new Endpoint_ClearIN(), Endpoint_ClearOUT(),
671 * Pipe_ClearIN() and Pipe_ClearOUT() macros (done to allow for the detection of packets of zero length)
672 * - Renamed *_ReadWriteAllowed() macros to *_IsReadWriteAllowed() to remain consistent with the rest of the LUFA API
673 * - Endpoint_IsSetupReceived() macro has been renamed to Endpoint_IsSETUPReceived(), Endpoint_ClearSetupReceived() macro has been
674 * renamed to Endpoint_ClearSETUP(), the Pipe_IsSetupSent() macro has been renamed to Pipe_IsSETUPSent() and the
675 * Pipe_ClearSetupSent() macro is no longer applicable and should be removed - changes made to compliment the new endpoint and pipe
676 * bank management API
677 * - Updated all demos, bootloaders and projects to use the new endpoint and pipe management APIs (thanks to Roman Thiel from Curetis AG)
678 * - Updated library doxygen documentation, added groups, changed documentation macro functions to real functions for clarity
679 * - Removed old endpoint and pipe aliased read/write/discard routines which did not have an explicit endian specifier for clarity
680 * - Removed the ButtLoadTag.h header file, as no one used for its intended purpose anyway
681 * - Renamed the main Drivers/AT90USBXXX directory to Drivers/Peripheral, renamed the Serial_Stream driver to SerialStream
682 * - Fixed CDC and USBtoSerial demos freezing where buffers were full while still transmitting or receiving (thanks to Peter Hand)
683 * - Removed "Host_" section of the function names in ConfigDescriptor.h, as most of the routines can now be used in device mode on the
684 * device descriptor
685 * - Renamed functions in the HID parser to have a "USB_" prefix and the acronym "HID" in the name
686 * - Fixed incorrect HID interface class and subclass values in the Mouse and KeyboardMouse demos (thanks to Brian Dickman)
687 * - Capitalized the "Descriptor_Search" and "Descriptor_Search_Comp" prefixes of the values in the DSearch_Return_ErrorCodes_t and
688 * DSearch_Comp_Return_ErrorCodes_t enums
689 * - Removed "ERROR" from the enum names in the endpoint and pipe stream error code enums
690 * - Renamed the USB_PowerOnErrorCodes_t enum to USB_InitErrorCodes_t, renamed the POWERON_ERROR_NoUSBModeSpecified enum value to
691 * USB_INITERROR_NoUSBModeSpecified
692 * - Renamed USB_PowerOnFail event to USB_InitFailure
693 * - Renamed OTG.h header functions to be more consistent with the rest of the library API
694 * - Changed over all deprecated GCC structure tag initializers to the standardized C99 format (thanks to Mike Alexander)
695 * - USB_HostRequest renamed to USB_ControlRequest, entire control request header is now read into USB_ControlRequest in Device mode
696 * rather than having the library pass only partially read header data to the application
697 * - The USB_UnhandledControlPacket event has had its parameters removed, in favor of accessing the new USB_ControlRequest structure
698 * - The Endpoint control stream functions now correctly send a ZLP to the host when less data than requested is sent
699 * - Fixed USB_RemoteWakeupEnabled flag never being set (the REMOTE WAKEUP Set Feature request was not being handled)
700 * - Renamed the FEATURELESS_CONTROL_ONLY_DEVICE compile-time token to CONTROL_ONLY_DEVICE
701 * - Endpoint configuration is now refined to give better output when all configurations have static inputs - removed the now useless
702 * STATIC_ENDPOINT_CONFIGURATION compile time token
703 * - Fixed SPI driver init function not clearing SPI2X bit when not needed
704 * - Fixed PREVENT ALLOW MEDIUM REMOVAL command issuing in the MassStorageHost demo using incorrect parameters (thanks to Mike Alex)
705 * - Fixed MassStorageHost demo broken due to an incorrect if statement test in MassStore_GetReturnedStatus()
706 * - Fixed reversed signature byte ordering in the CDC bootloader (thanks to Johannes Raschke)
707 * - Changed PIPE_CONTROLPIPE_DEFAULT_SIZE from 8 to 64 to try to prevent problems with faulty devices which do not respect the given
708 * wLength value when reading in the device descriptor
709 * - Fixed missing semicolon in the ATAVRUSBRF01 LED board driver code (thanks to Morten Lund)
710 * - 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
711 * with less than four LEDs without code modifications (thanks to Morten Lund)
712 * - Changed HWB board driver to Buttons driver, to allow for the support of future boards with more than one mounted GPIO button
713 * - Serial driver now correctly calculates the baud register value when in double speed mode
714 * - Init function of the Serial driver is now static inline to product smaller code for the common-case of static init values
715 *
716 *
717 * \section Sec_ChangeLog090401 Version 090401
718 *
719 * - Fixed MagStripe project configuration descriptor containing an unused (blank) endpoint descriptor
720 * - Incorporated makefile changes by Denver Gingerich to retain compatibility with stock (non-WinAVR) AVR-GCC installations
721 * - Fixed makefile EEPROM programming targets programming FLASH data in addition to EEPROM data
722 * - LUFA devices now enumerate correctly with LUFA hosts
723 * - Fixed Configuration Descriptor search routine freezing when a comparator returned a failure
724 * - Removed HID report item serial dump in the MouseHostWithParser and KeyboardHostWithParser - useful only for debugging, and
725 * slowed down the enumeration of HID devices too much
726 * - Increased the number of bits per track which can be read in the MagStripe project to 8192 when compiled for the AT90USBXXX6/7
727 * - Fixed KeyboardMouse demo discarding the wIndex value in the REQ_GetReport request
728 * - USBtoSerial demo now discards all Rx data when not connected to a USB host, rather than buffering characters for transmission
729 * next time the device is attached to a host.
730 * - Added new F_CLOCK compile time constant to the library and makefiles, to give the raw input clock (used to feed the PLL before any
731 * clock prescaling is performed) frequency, so that the PLL prescale mask can be determined
732 * - Changed stream wait timeout counter to be 16-bit, so that very long timeout periods can be set for correct communications with
733 * badly designed hosts or devices which greatly exceed the USB specification limits
734 * - Mass Storage Host demo now uses a USB_STREAM_TIMEOUT_MS of two seconds to maintain compatibility with poorly designed devices
735 * - Function attribute ATTR_ALWAYSINLINE renamed to ATTR_ALWAYS_INLINE to match other function attribute macro naming conventions
736 * - Added ATTR_ALWAYS_INLINE attribute to several key inlined library components, to ensure they are inlined in all circumstances
737 * - Removed SetSystemClockPrescaler() macro, the clock_prescale_set() avr-libc macro has been corrected in recent avr-libc versions
738 * - Fixed incorrect/missing control status stage transfers on demos, bootloaders and applications (thanks to Nate Lawson)
739 * - The NO_CLEARSET_FEATURE_REQUEST compile time token has been renamed to FEATURELESS_CONTROL_ONLY_DEVICE, and its function expanded
740 * to also remove parts of the Get Status chapter 9 request to further reduce code usage
741 * - Makefile updated to include output giving the currently selected BOARD parameter value
742 * - Board Dataflash driver now allows for dataflash ICs which use different shifts for setting the current page/byte address (thanks
743 * to Kenneth Clubb)
744 * - Added DataflashManager_WriteBlocks_RAM() and DataflashManager_ReadBlocks_RAM() functions to the MassStorage demo, to allow for easy
745 * interfacing with a FAT library for dataflash file level access
746 * - Corrected CDC class bootloader to fix a few bugs, changed address counter to store x2 addresses for convenience
747 * - Fixed typos in the SPI driver SPI_SPEED_FCPU_DIV_64 and SPI_SPEED_FCPU_DIV_128 masks (thanks to Markus Zocholl)
748 * - Keyboard and Mouse device demos (normal, data interrupt and fully interrupt driven) combined into unified keyboard and mouse demos
749 * - Keyboard and Mouse host demos (normal and data interrupt driven) combined into unified keyboard and mouse demos
750 * - Removed AVRISP_Programmer project due to code quality concerns
751 * - Fixed CDC demo not sending an empty packet after each transfer to prevent the host from buffering incoming data
752 * - Fixed documentation typos and preprocessor checks relating to misspellings of the USE_RAM_DESCRIPTORS token (thanks to Ian Gregg)
753 * - Fixed USBTask.h not conditionally including HostChapter9.h only when USB_CAN_BE_HOST is defined (thanks to Ian Gregg)
754 * - Fixed incorrect ADC driver init register manipulation (thanks to Tobias)
755 * - Added new GenericHID device demo application
756 * - Fixed Still Image Host SImage_SendData() function not clearing the pipe bank after sending data
757 *
758 *
759 * \section Sec_ChangeLog090209 Version 090209
760 *
761 * - PWM timer mode in AudioOut demo changed to Fast PWM for speed
762 * - Updated Magstripe project to work with the latest hardware revision
763 * - Fixed library not responding to the BCERRI flag correctly in host mode, leading to device lockups
764 * - Fixed library handling Get Descriptor requests when not addressed as standard requests to the device or interface (thanks to
765 * Nate Lawson)
766 * - Fixed serious data corruption issue in MassStorage demo dataflash write routine
767 * - Added new NO_CLEARSET_FEATURE_REQUEST compile time token
768 * - USB task now restores previous global interrupt state after execution, rather than forcing global interrupts to be enabled
769 * - Fixed USB_DeviceEnumerationComplete event firing after each configuration change, rather than once after the initial configuration
770 * - Added ENDPOINT_DOUBLEBANK_SUPPORTED() macros to Endpoint.h, altered ENDPOINT_MAX_SIZE() to allow user to specify endpoint
771 * - ENDPOINT_MAX_ENDPOINTS changed to ENDPOINT_TOTAL_ENDPOINTS, PIPE_MAX_PIPES changed to PIPE_TOTAL_PIPES
772 * - Endpoint and Pipe non-control stream functions now ensure endpoint or pipe is ready before reading or writing
773 * - Changed Teensy bootloader to use a watchdog reset when exiting rather than a software jump
774 * - Fixed integer promotion error in MassStorage and MassStorageHost demos, corrupting read/write transfers
775 * - SPI_SendByte is now SPI_TransferByte, added new SPI_SendByte and SPI_ReceiveByte functions for fast one-way transfer
776 * - MassStorage demo changed to use new fast one-way SPI transfers to increase throughput
777 * - MassStorage handling of Mass Storage Reset class request improved
778 * - Altered MassStorage demo dataflash block read code for speed
779 * - Added USB_IsSuspended global flag
780 * - Simplified internal Dual Mode (OTG) USB library code to reduce code size
781 * - Extended stream timeout period to 100ms from 50ms
782 * - Mass Storage Host demo commands now all return an error code from the Pipe_Stream_RW_ErrorCodes_t enum
783 * - Added SubErrorCode parameter to the USB_DeviceEnumerationFailed event
784 * - VBUS drop interrupt now disabled during the manual-to-auto VBUS delivery handoff
785 * - Simplified low level backend so that device/host mode initialization uses the same code paths
786 * - Added workaround for faulty Mass Storage devices which do not implement the required GET_MAX_LUN request
787 * - Removed buggy Telnet application from the RNDIS demo
788 * - Moved Mass Storage class requests in the Mass Storage Host demo to wrapper functions in MassStoreCommands.c
789 * - Fixed incorrect SCSI command size value in the Request Sense command in MassStoreCommands.c
790 * - Added SetProtocol request to HID class non-parser Mouse and Keyboard demos to force devices to use the correct Boot Protocol
791 * - Added new "dfu" and "flip" programming targets to project makefiles
792 * - HID_PARSE_Sucessful enum member typo corrected to HID_PARSE_Successful
793 * - Changed COLLECTION item structures in the HID descriptor parser to include the collection's Usage Page value
794 * - Serial driver now sets Tx line as output, enables pull-up on Rx line
795 * - Fixed smaller USB AVRs raising multiple connection and disconnection events when NO_LIMITED_CONTROLLER_CONNECT is disabled
796 * - Added HOST_DEVICE_SETTLE_DELAY_MS to give the host delay after a device is connected before it is enumerated
797 * - Fixed KeyboardHostWithParser demo linking against the wrong global variables
798 * - Completed doxygen documentation of remaining library bootloaders, demos and projects
799 * - Fixed incorrect bootloader start address in the TeensyHID bootloader
800 * - Added HWB button whole-disk ASCII dump functionality to MassStoreHost demo
801 * - Replaced printf_P(PSTR("%c"), {Variable}) calls with putchar(<Variable>) for speed and size savings
802 * - Serial driver now accepts baud rates over 16-bits in size, added double speed flag option
803 * - Fixed incorrect callback abort return value in Pipe.c
804 * - Added new flip-ee and dfu-ee makefile targets (courtesy of Opendous Inc.)
805 * - Removed reboot-on-disconnect code from the TeensyHID bootloader, caused problems on some systems
806 * - Fixed AudioOutput and AudioInput demos looping on the endpoint data, rather than processing a sample at a time and returning
807 * each time the task runs to allow for other tasks to execute
808 * - Added support for the Atmel ATAVRUSBRF01 board
809 * - Added AVRISP Programmer Project, courtesy of Opendous Inc.
810 * - Fixed CDC Host demo not searching through both CDC interfaces for endpoints
811 * - Fixed incorrect Product String descriptor length in the DFU class bootloader
812 *
813 *
814 * \section Sec_ChangeLog081224 Version 081224
815 *
816 * - MyUSB name changed to LUFA, the Lightweight USB Framework for AVRs
817 * - Fixed Mass Storage Host demo's MassStore_SendCommand() delay in the incorrect place
818 * - Fixed USBtoSerial demo not calling ReconfigureUSART() after a change in the line encoding
819 * - Fixed infinite loop in host mode Host-to-Device control transfers with data stages
820 * - HID report parser now supports devices with multiple reports in one interface via Report IDs
821 * - Fixed RZUSBSTICK board LED driver header incorrect macro definition order causing compile errors
822 * - Calling USB_Init() when the USB interface is already configured now forces a complete interface reset
823 * and re-enumeration - fixes MyUSB DFU bootloader not switching to app code correctly when soft reset used
824 * - Fixed "No newline at end of file" warning when stream callbacks are enabled
825 * - DFU bootloader now uses fixed signature bytes per device, rather than reading them out dynamically for size
826 * - Added new FIXED_CONTROL_ENDPOINT_SIZE and USE_SINGLE_DEVICE_CONFIGURATION switches to statically define certain values to
827 * reduce compiled binary size
828 * - Added new NO_LIMITED_CONTROLLER_CONNECT switch to prevent the library from trying to determine bus connection
829 * state from the suspension and wake up events on the smaller USB AVRs
830 * - Added summary of all library compile time tokens to the documentation
831 * - Added overview of the LUFA scheduler to the documentation
832 * - Removed MANUAL_PLL_CONTROL compile time token, replaced with a mask for the USB_Init() Options parameter
833 * - CDC bootloader now uses the correct non-far or far versions of the pgm_* functions depending on if RAMPZ is defined
834 * - Doxygen documentation now contains documentation on all the projects, bootloaders and most demos included with the library
835 * - CDC bootloader now runs user application when USB disconnected rather than waiting for a hard reset
836 * - MouseHostWithParser and KeyboardHostWithParser now support multiple-report devices
837 * - RNDIS demo can now close connections correctly using the new TCP_APP_CLOSECONNECTION() macro - used in Webserver
838 * - Fixed the DFU bootloader, no longer freezes up when certain files are programmed into an AVR, made reading/writing faster
839 * - Fixed mouse/joystick up/down movements reversed - HID mouse X/Y coordinates use a left-handed coordinate system, not a normal
840 * right-handed system
841 * - Added stub code to the CDC and USBtoSerial demos showing how to read and set the RS-232 handshake lines - not currently used in
842 * the demos, but the example code and supporting defines are now in place
843 * - Interrupts are now disabled when processing a control request in device mode, to avoid exceeding the strict control request
844 * timing requirements.
845 * - All demos now use a central StatusUpdate() function rather than direct calls to the board LED functions, so that the demos can
846 * easily be altered to show different LED combinations (or do something else entirely) as the demo's status changes
847 * - Removed LED commands from the CDC bootloader, unused by most AVR910 programming software
848 * - Fixed RNDIS demo ICMP ping requests echoing back incorrect data
849 * - Added DHCP server code to RNDIS demo, allowing for hands-free auto configuration on any PC
850 * - Fixed DFU bootloader PID value for the ATMEGA16U4 AVR
851 * - Endpoint and Pipe configuration functions now return an error code indicating success or failure
852 * - USB Reset in device mode now resets and disables all device endpoints
853 * - Added intermediate states to the host mode state machine, reducing the USB task blocking time to no more than 1ms explicitly per
854 * invocation when in host mode
855 * - Added support for the ATMEGA32U6 microcontroller
856 * - Added STATIC_ENDPOINT_CONFIGURATION compile time option, enabled in the bootloaders to minimize space usage
857 * - Removed redundant code from the USB device GetStatus() chapter 9 processing routine
858 * - Added new TeensyHID bootloader, compatible with the Teensy HID protocol (http://www.pjrc.com/teensy/)
859 * - Versions are now numbered by release dates, rather than arbitrary major/minor revision numbers
860 * - USB_RemoteWakeupEnabled is now correctly set and cleared by SetFeature and ClearFeature requests from the host
861 * - Changed prototype of GetDescriptor, so that it now returns the descriptor size (or zero if the descriptor doesn't exist)
862 * rather than passing the size back to the caller through a parameter and returning a boolean
863 *
864 *
865 * \section Sec_ChangeLog153 Version 1.5.3 - Released 2nd October, 2008
866 *
867 * - Fixed CDC bootloader using pgmspace macros for some descriptors inappropriately
868 * - Updated all Mouse and Keyboard device demos to include boot protocol support (now works in BIOS)
869 * - Renamed bootloader directories to remove spaces, which were causing build problems on several OSes
870 * - Removed serial number strings from all but the MassStore demo where it is required - users were not
871 * modifying the code to either omit the descriptor or use a unique serial per device causing problems
872 * when multiple units of the same device were plugged in at the same time
873 * - AudioOutput and AudioInput demos now correctly silence endpoints when not enabled by the host
874 * - Added KeyboardMouse demo (Keyboard and Mouse functionality combined into a single demo)
875 * - Added DriverStubs directory to house board level driver templates, to make MyUSB compatible custom board
876 * driver creation easier
877 * - Extended MassStorage demo to support multiple LUNs, 2 by default
878 * - Fixed incorrect device address mask, preventing the device from enumerating with addresses larger than 63
879 * - Fixed incorrect data direction mask in the GetStatus standard request, preventing it from being handled
880 * - Fixed incorrect GetStatus standard request for endpoints, now returns the endpoint STALL status correctly
881 * - Added in new USB_RemoteWakeupEnabled and USB_CurrentlySelfPowered flags rather than using fixed values
882 * - Added DualCDC demo to demonstrate the use of Interface Association Descriptors
883 * - Added pipe NAK detection and clearing API
884 * - Added pipe status change (NAK, STALL, etc.) interrupt API
885 * - Fixed MassStorageHost demo so that it no longer freezes randomly when issuing several commands in a row
886 * - Host demos configuration descriptor routines now return a unique error code when the returned data does
887 * not have a valid configuration descriptor header
888 * - Added Endpoint_WaitUntilReady() and Pipe_WaitUntilReady() functions
889 * - Stream functions now have software timeouts, timeout period can be set by the USB_STREAM_TIMEOUT_MS token
890 * - All demos now pass the USB.org automated Chapter 9 device compliance tests
891 * - All HID demos now pass the USB.org automated HID compliance tests
892 * - Polling interval of the interrupt endpoint in the CDC based demos changed to 0xFF to fix problems on Linux systems
893 * - Changed stream functions to accept a new callback function, with NO_STREAM_CALLBACKS used to disable all callbacks
894 * - Mass Storage demo dataflash management routines changed to use the endpoint stream functions
895 * - Added AVRStudio project files for each demo in addition to the existing Programmer's Notepad master project file
896 * - Re-added call to ReconfigureUSART() in USBtoSerial SetLineCoding request, so that baud rate changes
897 * are reflected in the hardware (change was previously lost)
898 *
899 *
900 * \section Sec_ChangeLog152 Version 1.5.2 - Released 31st July, 2008
901 *
902 * - Fixed SwapEndian_32() function in Common.h so that it now works correctly (wrong parameter types)
903 * - Updated RNDIS demo - notification endpoint is no longer blocking so that it works with faulty Linux RNDIS
904 * implementations (where the notification endpoint is ignored in favor of polling the control endpoint)
905 * - Fixed incorrect Vendor Description string return size in RNDIS demo for the OID_GEN_VENDOR_DESCRIPTION OID token
906 * - Added very basic TCP/IP stack and HTTP/TELNET servers to RNDIS demo
907 * - Fixed DFU bootloader exit causing programming software to complain about failed writes
908 * - Fixed DFU bootloader EEPROM programming mode wiping first flash page
909 * - Fixed Clear/Set Feature device standard request processing code (fixing MassStorage demo in the process)
910 * - Added support for the ATMEGA16U4 AVR microcontroller
911 * - Library license changed from LGPLv3 to MIT license
912 *
913 *
914 * \section Sec_ChangeLog151 Version 1.5.1 - Released 31st July, 2008
915 *
916 * - Changed host demos to enable the host function task on the firing of the USB_DeviceEnumerationComplete event
917 * rather than the USB_DeviceAttached event
918 * - HID Usage Stack now forcefully cleared after an IN/OUT/FEATURE item has been completely processed to remove
919 * any referenced but not created usages
920 * - Changed USB_INT_DisableAllInterrupts() and USB_INT_ClearAllInterrupts(), USB_Host_GetNextDescriptorOfType(),
921 * USB_Host_GetNextDescriptorOfTypeBefore(), USB_Host_GetNextDescriptorOfTypeAfter() to normal functions (from inline)
922 * - Fixed USBtoSerial demo not sending data, only receiving
923 * - Fixed main makefile to make all by default, fixed MagStripe directory case to prevent case-sensitive path problems
924 * - ConfigDescriptor functions made normal, instead of static inline
925 * - Pipe/Endpoint *_Ignore_* functions changed to *_Discard_*, old names still present as aliases
926 * - Fixed ENDPOINT_MAX_SIZE define to be correct on limited USB controller AVRs
927 * - Changed endpoint and pipe size translation routines to use previous IF/ELSE IF cascade code, new algorithmic
928 * approach was buggy and caused problems
929 * - Bootloaders now compile with -fno-inline-small-functions option to reduce code size
930 * - Audio demos now use correct endpoint sizes for full and limited controller USB AVRs, double banking in all cases
931 * to be in line with the specification (isochronous endpoints MUST be double banked)
932 * - Added Interface Association descriptor to StdDescriptors.h, based on the relevant USB2.0 ECN
933 * - Fixed MIDI demo, corrected Audio Streaming descriptor to follow the MIDI-specific AS structure
934 * - Fixed HID class demo descriptors so that the HID interface's protocol is 0x00 (required for non-boot protocol HID
935 * devices) to prevent problems on hosts expecting the boot protocol functions to be supported
936 * - Added read/write control stream functions to Endpoint.h
937 * - Fixed AudioOut demo not setting port pins to inputs on USB disconnect properly
938 * - Added RNDISEthernet demo application
939 *
940 *
941 * \section Sec_ChangeLog150 Version 1.5.0 - Released 10 June, 2008
942 *
943 * - Fixed MIDI demo, now correctly waits for the endpoint to be ready between multiple note messages
944 * - Added CDC Host demo application
945 * - Added KeyboardFullInt demo application
946 * - Endpoint and Pipe creation routines now mask endpoint/pipe size with the size mask, to remove transaction
947 * size bits not required for the routines (improves compatibility with devices)
948 * - Fixed AudioInput demo - now correctly sends sampled audio to the host PC
949 * - Fixed AudioOutput demo once more -- apparently Windows requires endpoint packets to be >=192 bytes
950 * - Shrunk round-robbin scheduler code slightly via the use of struct pointers rather than array indexes
951 * - Fixed off-by-one error when determining if the Usage Stack is full inside the HID Report parser
952 * - Renamed Magstripe.h to MagstripeHW.h and moved driver out of the library and into the MagStripe demo folder
953 * - Added preprocessor checks to enable C linkage on the library components when used with a C++ compiler
954 * - Added Still Image Host demo application
955 * - The USB device task now restores the previously selected endpoint, allowing control requests to be transparently
956 * handled via interrupts while other endpoints are serviced through polling
957 * - Fixed device signature being sent in reverse order in the CDC bootloader
958 * - Host demos now have a separate ConfigDescriptor.c/.h file for configuration descriptor processing
959 * - HostWithParser demos now have a separate HIDReport.c/.h file for HID report processing and dumping
960 * - Removed non-mandatory commands from MassStorage demo to save space, fixed SENSE ResponseCode value
961 * - CDC demos now send empty packets after sending a full one to prevent buffering issues on the host
962 * - Updated demo descriptors to use VID/PID values donated by Atmel
963 * - Added DoxyGen documentation to the source files
964 * - Fixed Serial_IsCharReceived() definition, was previously reversed
965 * - Removed separate USB_Descriptor_Language_t descriptor, USB_Descriptor_String_t is used instead
966 * - Removed unused Device Qualifier descriptor structure
967 * - Renamed the USB_CreateEndpoints event to the more appropriate USB_ConfigurationChanged
968 * - Fixed MassStorageHost demo reading in the block data in reverse
969 * - Removed outdated typedefs in StdRequestType.h, superseded by the macro masks
970 * - Corrected OTG.h is now included when the AVR supports both Host and Device modes, for creating OTG products
971 * - USB_DeviceEnumerationComplete event is now also fired when in device mode and the host has finished its enumeration
972 * - Interrupt driven demos now properly restore previously selected endpoint when ISR is complete
973 * - The value of USB_HOST_TIMEOUT_MS can now be overridden in the user project makefile to a custom fixed timeout value
974 * - Renamed USB_Host_SOFGeneration_* macros to more friendly USB_Host_SuspendBus(), USB_Host_ResumeBus()
975 * and USB_Host_IsBusSuspended()
976 * - Renamed *_*_Is* macros to *_Is* to make all flag checking macros consistent, Pipe_SetInterruptFreq() is now
977 * Pipe_SetInterruptPeriod() to use the correct terminology
978 * - UnicodeString member of USB_Descriptor_String_t struct changed to an ordinary int array type, so that the GCC
979 * Unicode strings (prefixed with an L before the opening quotation mark) can be used instead of explicit arrays
980 * of ASCII characters
981 * - Fixed Endpoint/Pipes being configured incorrectly if the maximum endpoint/pipe size for the selected USB AVR
982 * model was given as the bank size
983 * - HID device demos now use a true raw array for the HID report descriptor rather than a struct wrapped array
984 * - Added VERSION_BCD() macro, fixed reported HID and USB version numbers in demo descriptors
985 * - Cleaned up GetDescriptor device chapter 9 handler function
986 * - Added GET_REPORT class specific request to HID demos to make them complaint to the HID class
987 * - Cleaned up setting of USB_IsInitialized and USB_IsConnected values to only when needed
988 * - Removed Atomic.c and ISRMacro.h; the library was already only compatible with recent avr-lib-c for other reasons
989 * - All demos and library functions now use USB standardized names for the USB data (bRequest, wLength, etc.)
990 * - Added USE_NONSTANDARD_DESCRIPTOR_NAMES token to switch back to the non-standard descriptor element names
991 *
992 *
993 * \section Sec_ChangeLog141 Version 1.4.1 - Released 5 May, 2008
994 *
995 * - Enhanced KeyboardWithParser demo, now prints out pressed alphanumeric characters like the standard demo
996 * - Fixed MassStorage demo, read/writes using non mode-10 commands now work correctly
997 * - Corrected version number in Version.h
998 *
999 *
1000 * \section Sec_ChangeLog140 Version 1.4.0 - Released 5 May, 2008
1001 *
1002 * - Added HID Report Parser API to the library
1003 * - Added Mouse and Keyboard host demo applications, using the new HID report parser engine
1004 * - Added MouseFullInt demo, which demonstrates a fully interrupt (including control requests) mouse device
1005 * - Fixed incorrect length value in the audio control descriptor of the AudioOutput and AudioInput demos
1006 * - Added MIDI device demo application to the library
1007 * - Fixed problem preventing USB devices from being resumed from a suspended state
1008 * - Added new CDC class bootloader to the library, based on the AVR109 bootloader protocol
1009 * - Added header to each demo application indicating the mode, class, subclass, standards used and supported speed
1010 * - Functions expecting endpoint/pipe numbers are no longer automatically masked against ENDPOINT_EPNUM_MASK or
1011 * PIPE_PIPENUM_MASK - this should be manually added to code which requires it
1012 * - Fixed DFU class bootloader - corrected frequency of flash page writes, greatly reducing programming time
1013 * - Renamed AVR_HOST_GetDeviceConfigDescriptor() to USB_Host_GetDeviceConfigDescriptor() and AVR_HOST_GetNextDescriptor()
1014 * to USB_Host_GetNextDescriptor()
1015 * - Added new USB_Host_GetNextDescriptorOfTypeBefore() and USB_Host_GetNextDescriptorOfTypeAfter() routines
1016 * - Moved configuration descriptor routines to MyUSB/Drivers/USB/Class/, new accompanying ConfigDescriptors.c file
1017 * - Added new configuration descriptor comparator API for more powerful descriptor parsing, updated host demos to use the
1018 * new comparator API
1019 * - Fixed MassStorageHost demo capacity printout, and changed data read/write mode from little-endian to the correct
1020 * big-endian for SCSI devices
1021 * - Fixed macro/function naming consistency; USB_HOST is now USB_Host, USB_DEV is now USB_Device
1022 * - Added better error reporting to host demos
1023 * - Added 10 microsecond delay after addressing devices in host mode, to prevent control stalls
1024 *
1025 *
1026 * \section Sec_ChangeLog132 Version 1.3.2 - Released April 1st, 2008
1027 *
1028 * - Added call to ReconfigureUSART() in USBtoSerial SetLineCoding request, so that baud rate changes
1029 * are reflected in the hardware
1030 * - Fixed CDC and USBtoSerial demos - Stream commands do not work for control endpoints, and the
1031 * GetLineCoding request had an incorrect RequestType mask preventing it from being processed
1032 * - Improved reliability of the USBtoSerial demo, adding a busy wait while the buffer is full
1033 * - Device control endpoint size is now determined from the device's descriptors rather than being fixed
1034 * - Separated out SPI code into new SPI driver in AT90USBXXX driver directory
1035 * - Bootloader now returns correct PID for the selected USB AVR model, not just the AT90USB128X PID
1036 * - Added support for the RZUSBSTICK board
1037 * - Bicolour driver removed in favor of generic LEDs driver
1038 * - Added support for the ATMEGA32U4 AVR
1039 * - Added MANUAL_PLL_CONTROL compile time option to prevent the USB library from manipulating the PLL
1040 *
1041 *
1042 * \section Sec_ChangeLog131 Version 1.3.1 - Released March 19th 2008
1043 *
1044 * - Fixed USB to Serial demo - class value in the descriptors was incorrect
1045 * - Control endpoint size changed from 64 bytes to 8 bytes to save on USB FIFO RAM and to allow low
1046 * speed mode devices to enumerate properly
1047 * - USB to Serial demo data endpoints changed to dual-banked 16 byte to allow the demo to work
1048 * on USB AVRs with limited USB FIFO RAM
1049 * - Changed demo endpoint numbers to use endpoints 3 and 4 for double banking, to allow limited
1050 * USB device controller AVRs (AT90USB162, AT90USB82) to function correctly
1051 * - Updated Audio Out demo to use timer 1 for AVRs lacking a timer 3 for the PWM output
1052 * - Fixed incorrect USB_DEV_OPT_HIGHSPEED entry in the Mass Storage device demo makefile
1053 * - Optimized Mass Storage demo for a little extra transfer speed
1054 * - Added LED indicators to the Keyboard demo for Caps Lock, Num Lock and Scroll Lock
1055 * - Added Endpoint_Read_Stream, Endpoint_Write_Stream, Pipe_Read_Stream and Pipe_Write_Stream functions
1056 * (including Big and Little Endian variants)
1057 * - Made Dataflash functions inline for speed, removed now empty Dataflash.c driver file
1058 * - Added new SetSystemClockPrescaler() macro (thanks to Joerg Wunsch)
1059 * - Fixed Endpoint_ClearStall() to function correctly on full USB controller AVRs (AT90USBXXX6/7)
1060 * - Endpoint_Setup_In_Clear() and Endpoint_Setup_Out_Clear() no longer set FIFOCON, in line with the
1061 * directives in the datasheet
1062 * - Fixed PLL prescaler defines for all AVR models and frequencies
1063 * - Fixed ENDPOINT_INT_IN and ENDPOINT_INT_OUT definitions
1064 * - Added interrupt driven keyboard and mouse device demos
1065 * - Combined USB_Device_ClearFeature and USB_Device_SetFeature requests into a single routine for code
1066 * size savings
1067 * - Added missing Pipe_GetCurrentPipe() macro to Pipe.h
1068 *
1069 *
1070 * \section Sec_ChangeLog130 Version 1.3.0 - Released March 7th 2008
1071 *
1072 * - Unnecessary control endpoint config removed from device mode
1073 * - Fixed device standard request interpreter accidentally processing some class-specific requests
1074 * - Added USE_RAM_DESCRIPTORS and USE_EEPROM_DESCRIPTORS compile time options to instruct the library
1075 * to use descriptors stored in RAM or EEPROM rather than flash memory
1076 * - All demos now disable watchdog on startup, in case it has been enabled by fuses or the bootloader
1077 * - USB_DEV_OPT_LOWSPEED option now works correctly
1078 * - Added ability to set the USB options statically for a binary size reduction via the USE_STATIC_OPTIONS
1079 * compile time define
1080 * - USB_Init no longer takes a Mode parameter if compiled for a USB device with no host mode option, or
1081 * if forced to a particular mode via the USB_HOST_ONLY or USB_DEVICE_ONLY compile time options
1082 * - USB_Init no longer takes an Options parameter if options statically configured by USE_STATIC_OPTIONS
1083 * - Endpoint_Ignore_* and Pipe_Ignore_* made smaller by making the dummy variable non-volatile so that the
1084 * compiler can throw away the result more efficiently
1085 * - Added in an optional GroupID value to each scheduler entry, so that groups of tasks can once again be
1086 * controlled by the new Scheduler_SetGroupTaskMode() routine
1087 * - Added support for AT90USB162 and AT90USB82 AVR models
1088 * - Added support for the STK525 and STK526 boards
1089 * - Added support for custom board drivers to be supplied by selecting the board type as BOARD_USER, and
1090 * placing board drivers in {Application Directory}/Board/
1091 * - PLL is now stopped and USB clock is frozen when detached from host in device mode, to save power
1092 * - Joystick defines are now in synch with the schematics - orientation will be rotated for the USBKEY
1093 * - Fixed USB_DEV_IsUSBSuspended() - now checks the correct register
1094 * - Fixed data transfers to devices when in host mode
1095 * - Renamed USB_DEV_OPT_HIGHSPEED to USB_DEV_OPT_FULLSPEED and USB_HOST_IsDeviceHighSpeed() to
1096 * USB_HOST_IsDeviceFullSpeed() to be in line with the official USB speed names (to avoid confusion with
1097 * the real high speed mode, which is unavailable on the USB AVRs)
1098 *
1099 *
1100 * \section Sec_ChangeLog120 Version 1.2.0 - Released February 4th, 2008
1101 *
1102 * - Added USB_DeviceEnumerationComplete event for host mode
1103 * - Added new Scheduler_Init routine to prepare the scheduler, so that tasks can be started and
1104 * stopped before the scheduler has been started (via Scheduler_Start)
1105 * - Connection events in both Device and Host mode are now interrupt-driven, allowing the USB management
1106 * task to be stopped when the USB is not connected to a host or device
1107 * - All demos updated to stop the USB task when not in use via the appropriate USB events
1108 * - Mass Storage Host demo application updated to function correctly with all USB flash disks
1109 * - Mass Storage Host demo application now prints out the capacity and number of LUNs in the attached
1110 * device, and prints the first block as hexadecimal numbers rather than ASCII characters
1111 * - Endpoint and Pipe clearing routines now clear the Endpoint/Pipe interrupt and status flags
1112 * - Shifted error handling code in the host enum state machine to a single block, to reduce code complexity
1113 * - Added in DESCRIPTOR_TYPE, DESCRIPTOR_SIZE and DESCRIPTOR_CAST macros to make config descriptor processing
1114 * clearer in USB hosts and DESCRIPTOR_ADDRESS for convenience in USB devices
1115 * - Added in alloca macro to common.h, in case the user is using an old version of avr-lib-c missing the macro
1116 *
1117 *
1118 * \section Sec_ChangeLog130 Version 1.1.0 - Released January 25th 2008
1119 *
1120 * - Fixed DCONNI interrupt being enabled accidentally after a USB reset
1121 * - Fixed DDISCI interrupt not being disabled when a device is not connected
1122 * - Added workaround for powerless pull-up devices causing false disconnect interrupts
1123 * - Added USB_DeviceEnumerationFailed event for Host mode
1124 * - AVR_HOST_GetDeviceConfigDescriptor routine no longer modifies ConfigSizePtr if a valid buffer
1125 * pointer is passed
1126 * - Added ALLOCABLE_BYTES to DynAlloc, and added code to make the size of key storage variables
1127 * dependant on size of memory parameters passed in via the user project's makefile
1128 * - Fixed incorrect device reset routine being called in USBTask
1129 * - Devices which do not connect within the standard 300mS are now supported
1130 * - Removed incorrect ATTR_PURE from Scheduler_SetTaskMode(), which was preventing tasks from being
1131 * started/stopped, as well as USB_InitTaskPointer(), which was breaking dual device/host USB projects
1132 * - Changed scheduler to use the task name rather than IDs for setting the task mode, eliminating the
1133 * need to have a task ID list
1134 * - ID transition interrupt now raises the appropriate device/host disconnect event if device attached
1135 * - Fixed double VBUS change (and VBUS -) event when detaching in device mode
1136 * - Added ability to disable ANSI terminal codes by the defining of DISABLE_TERMINAL_CODES in makefile
1137 * - Removed return from ConfigurePipe and ConfigureEndpoint functions - use Pipe_IsConfigured() and
1138 * Endpoint_IsConfigured() after calling the config functions to determine success
1139 */
1140