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