Squashed 'lib/lufa/' content from commit 385d40300
git-subtree-dir: lib/lufa git-subtree-split: 385d4030035dbaf41591309dbde47653bd03841b
This commit is contained in:
		
						commit
						60b30c0363
					
				
					 1455 changed files with 394541 additions and 0 deletions
				
			
		
							
								
								
									
										281
									
								
								LUFA/DoxygenPages/BuildSystem.txt
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										281
									
								
								LUFA/DoxygenPages/BuildSystem.txt
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,281 @@ | |||
| /** \file | ||||
|  * | ||||
|  *  This file contains special DoxyGen information for the generation of the main page and other special | ||||
|  *  documentation pages. It is not a project source file. | ||||
|  */ | ||||
| 
 | ||||
| /** \page Page_BuildSystem The LUFA Build System | ||||
|  * | ||||
|  *  \section Sec_BuildSystem_Overview Overview of the LUFA Build System | ||||
|  *  The LUFA build system was originally an attempt at making a set of | ||||
|  *  re-usable, modular build make files which could be referenced in a LUFA | ||||
|  *  powered project, to minimize the amount of code required in an | ||||
|  *  application makefile. | ||||
|  * | ||||
|  *  As it turned out to be fairly generic in nature, it was split out into its | ||||
|  *  own separate project, called DMBS (<i>Dean's Makefile Build System</i>) | ||||
|  *  which is released into the public domain. LUFA-specific portions of the | ||||
|  *  LUFA build system extend DMBS, and provide a universal build system for all | ||||
|  *  LUFA projects. | ||||
|  * | ||||
|  *  The latest DMBS project information and documentation can be found at: | ||||
|  *  https://github.com/abcminiuser/dmbs | ||||
|  * | ||||
|  *  DMBS is written in GNU Make, and each module is independent of one-another. | ||||
|  * | ||||
|  *  LUFA now uses DMBS for its build system, with some LUFA specific extension | ||||
|  *  modules. | ||||
|  * | ||||
|  *  If you have problems building using LUFA, see \subpage Page_BuildTroubleshooting for resolution steps. | ||||
|  * | ||||
|  *  \li \subpage Page_BuildModule_LUFA_SOURCES - The LUFA SOURCES extension module for DMBS | ||||
|  *  \li \subpage Page_BuildModule_LUFA_GCC - The LUFA GCC extension module for DMBS | ||||
|  */ | ||||
| 
 | ||||
| /** \page Page_BuildModule_LUFA_SOURCES LUFA SOURCES extension module for DMBS | ||||
|  * | ||||
|  *  The LUFA SOURCES extension more for DMBS provides LUFA specific variables | ||||
|  *  listing the various LUFA source files required to be build by a project for | ||||
|  *  a given LUFA module. This module gives a way to reference LUFA source files | ||||
|  *  symbolically, so that changes to the library structure do not break the | ||||
|  *  library makefile. | ||||
|  * | ||||
|  *  To use this module in your application makefile, add the following code: | ||||
|  *  \code | ||||
|  *  include $(LUFA_PATH)/Build/LUFA/lufa-sources.mk | ||||
|  *  \endcode | ||||
|  * | ||||
|  *  \section SSec_BuildModule_LUFA_SOURCES_Requirements Requirements | ||||
|  *  None. | ||||
|  * | ||||
|  *  \section SSec_BuildModule_LUFA_SOURCES_Targets Targets | ||||
|  * | ||||
|  *  <table> | ||||
|  *   <tr> | ||||
|  *    <td><i>None</i></td> | ||||
|  *   </tr> | ||||
|  *  </table> | ||||
|  * | ||||
|  *  \section SSec_BuildModule_LUFA_SOURCES_MandatoryParams Mandatory Parameters | ||||
|  * | ||||
|  *  <table> | ||||
|  *   <tr> | ||||
|  *    <td><tt>LUFA_PATH</tt></td> | ||||
|  *    <td>Path to the LUFA library core, either relative or absolute (e.g. <tt>../LUFA-000000/LUFA/</tt>).</td> | ||||
|  *   </tr> | ||||
|  *   <tr> | ||||
|  *    <td><tt>ARCH</tt></td> | ||||
|  *    <td>Architecture of the target processor (see \ref Page_DeviceSupport).</td> | ||||
|  *   </tr> | ||||
|  *  </table> | ||||
|  * | ||||
|  *  \section SSec_BuildModule_LUFA_SOURCES_OptionalParams Optional Parameters | ||||
|  * | ||||
|  *  <table> | ||||
|  *   <tr> | ||||
|  *    <td><i>None</i></td> | ||||
|  *   </tr> | ||||
|  *  </table> | ||||
|  * | ||||
|  *  \section SSec_BuildModule_LUFA_SOURCES_ProvidedVariables Module Provided Variables | ||||
|  * | ||||
|  *  <table> | ||||
|  *   <tr> | ||||
|  *    <td><tt>LUFA_SRC_USB</tt></td> | ||||
|  *    <td>List of LUFA USB driver source files.</td> | ||||
|  *   </tr> | ||||
|  *   <tr> | ||||
|  *    <td><tt>LUFA_SRC_USBCLASS</tt></td> | ||||
|  *    <td>List of LUFA USB Class driver source files.</td> | ||||
|  *   </tr> | ||||
|  *   <tr> | ||||
|  *    <td><tt>LUFA_SRC_TEMPERATURE</tt></td> | ||||
|  *    <td>List of LUFA temperature sensor driver source files.</td> | ||||
|  *   </tr> | ||||
|  *   <tr> | ||||
|  *    <td><tt>LUFA_SRC_SERIAL</tt></td> | ||||
|  *    <td>List of LUFA Serial U(S)ART driver source files.</td> | ||||
|  *   </tr> | ||||
|  *   <tr> | ||||
|  *    <td><tt>LUFA_SRC_TWI</tt></td> | ||||
|  *    <td>List of LUFA TWI driver source files.</td> | ||||
|  *   </tr> | ||||
|  *   <tr> | ||||
|  *    <td><tt>LUFA_SRC_PLATFORM</tt></td> | ||||
|  *    <td>List of LUFA architecture specific platform management source files.</td> | ||||
|  *   </tr> | ||||
|  *  </table> | ||||
|  * | ||||
|  *  \section SSec_BuildModule_LUFA_SOURCES_ProvidedMacros Module Provided Macros | ||||
|  * | ||||
|  *  <table> | ||||
|  *   <tr> | ||||
|  *    <td><i>None</i></td> | ||||
|  *   </tr> | ||||
|  *  </table> | ||||
|  */ | ||||
| 
 | ||||
| /** \page Page_BuildModule_LUFA_GCC LUFA GCC extension module for DMBS | ||||
|  * | ||||
|  *  The LUFA GCC extension module for the standard DMBS GCC module extends the | ||||
|  *  latter to support the compilation of LUFA powered projects. It should be | ||||
|  *  imported into your LUFA powered project makefiles to ensure that the correct | ||||
|  *  build settings are used for the project's configuration. | ||||
|  * | ||||
|  *  To use this module in your application makefile, add the following code: | ||||
|  *  \code | ||||
|  *  include $(LUFA_PATH)/Build/LUFA/lufa-gcc.mk | ||||
|  *  \endcode | ||||
|  * | ||||
|  *  \section SSec_BuildModule_LUFA_GCC_Requirements Requirements | ||||
|  *  This module should be included in your makefile *after* the DMBS GCC module. | ||||
|  * | ||||
|  *  \section SSec_BuildModule_LUFA_GCC_Targets Targets | ||||
|  * | ||||
|  *  <table> | ||||
|  *   <tr> | ||||
|  *    <td><i>None</i></td> | ||||
|  *   </tr> | ||||
|  *  </table> | ||||
|  * | ||||
|  *  \section SSec_BuildModule_LUFA_GCC_MandatoryParams Mandatory Parameters | ||||
|  * | ||||
|  *  <table> | ||||
|  *   <tr> | ||||
|  *    <td><tt>LUFA_PATH</tt></td> | ||||
|  *    <td>Path to the LUFA library core, either relative or absolute (e.g. <tt>../LUFA-000000/LUFA/</tt>).</td> | ||||
|  *   </tr> | ||||
|  *  </table> | ||||
|  * | ||||
|  *  \section SSec_BuildModule_LUFA_GCC_OptionalParams Optional Parameters | ||||
|  * | ||||
|  *  <table> | ||||
|  *   <tr> | ||||
|  *    <td><tt>BOARD</tt></td> | ||||
|  *    <td>LUFA board hardware drivers to use (see \ref Page_DeviceSupport).</td> | ||||
|  *   </tr> | ||||
|  *  </table> | ||||
|  * | ||||
|  *  \section SSec_BuildModule_LUFA_GCC_ProvidedVariables Module Provided Variables | ||||
|  * | ||||
|  *  <table> | ||||
|  *   <tr> | ||||
|  *    <td><i>None</i></td> | ||||
|  *   </tr> | ||||
|  *  </table> | ||||
|  * | ||||
|  *  \section SSec_BuildModule_LUFA_GCC_ProvidedMacros Module Provided Macros | ||||
|  * | ||||
|  *  <table> | ||||
|  *   <tr> | ||||
|  *    <td><i>None</i></td> | ||||
|  *   </tr> | ||||
|  *  </table> | ||||
|  */ | ||||
| 
 | ||||
| /** \page Page_BuildTroubleshooting Troubleshooting Information | ||||
|  * | ||||
|  *  LUFA uses a lot of advanced features of the AVR-GCC compiler, linker, and | ||||
|  *  surrounding binaries. This can sometimes lead to problems compiling | ||||
|  *  applications if one of these features is buggy in the version of the tools | ||||
|  *  used in a build environment. Missing utilities and incorrectly set makefile | ||||
|  *  configuration options can also result in different errors being produced | ||||
|  *  when compilation or other operations are attempted. The table below lists a | ||||
|  *  set of commonly encountered errors and their resolutions. | ||||
|  * | ||||
|  *  <table> | ||||
|  *    <tr> | ||||
|  *    <th>Problem</th> | ||||
|  *    <th>Resolution</th> | ||||
|  *   </tr> | ||||
|  *   <tr> | ||||
|  *    <td>Error "<b><tt>relocation truncated to fit: R_AVR_13_PCREL against symbol <i>{X}</i></tt></b>" shown when compiling.</td> | ||||
|  *    <td>Try compiling with the setting <tt>LINKER_RELAXATIONS=N</tt> in your LUFA Build System 2.0 makefile, or remove the line <tt>-Wl,--relax</tt> | ||||
|  *        from other makefiles. Alternatively, make sure you have the latest version of the Atmel Toolchain installed for your system.</td> | ||||
|  *   </tr> | ||||
|  *   <tr> | ||||
|  *    <td>Error "<b><tt>error: ld terminated with signal 11 [Segmentation fault]</tt></b>" shown when compiling.</td> | ||||
|  *    <td>Try compiling with the setting <tt>DEBUG_LEVEL=2</tt> in your LUFA Build System 2.0 makefile, or make sure you are using <tt>binutils</tt> version 2.22 or later.</td> | ||||
|  *   </tr> | ||||
|  *   <tr> | ||||
|  *    <td>Error "<b><tt>EMERGENCY ABORT: INFINITE RECURSION DETECTED</tt></b>" shown when compiling.</td> | ||||
|  *    <td>Make sure you are using an up to date version of GNU Make when compiling. This error is a safety system added to the mid-level makefiles, to prevent an issue with | ||||
|  *        GNU make or other variants of Make causing an infinitely recursive build.</td> | ||||
|  *   </tr> | ||||
|  *   <tr> | ||||
|  *    <td>Error "<b><tt>Unsupported architecture "<i>{X}</i>"</tt></b>" shown when compiling.</td> | ||||
|  *    <td>Ensure your makefile's <tt>ARCH</tt> setting is set to one of the architecture names (case-sensitive) supported by the version of LUFA you are compiling against.</td> | ||||
|  *   </tr> | ||||
|  *   <tr> | ||||
|  *    <td>Error "<b><tt>Makefile <i>{X}</i> value not set</tt></b>" shown when compiling.</td> | ||||
|  *    <td>The specified Makefile value was not configured in your project's makefile or on the command line, and the nominated setting is required by one or more LUFA | ||||
|  *        build system modules. Define the value in your project makefile and try again.</td> | ||||
|  *   </tr> | ||||
|  *   <tr> | ||||
|  *    <td>Error "<b><tt>Makefile <i>{X}</i> option cannot be blank</tt></b>" shown when compiling.</td> | ||||
|  *    <td>The specified Makefile value was configured in your project's makefile or on the command line, but was set to an empty value. For the nominated configuration | ||||
|  *        option, an empty value is not allowed. Define the nominated setting to a correct non-blank value and try again.</td> | ||||
|  *   </tr> | ||||
|  *   <tr> | ||||
|  *    <td>Error "<b><tt>Makefile <i>{X}</i> option must be Y or N</tt></b>" shown when compiling.</td> | ||||
|  *    <td>The specified Makefile value was configured in your project's makefile or on the command line, but was set to a value other than a Y (for "Yes") or "N" (for "No"). | ||||
|  *        This configuration option is required to be one of the aforementioned boolean values, and other values are invalid. Set this option to either Y or N and try again.</td> | ||||
|  *   </tr> | ||||
|  *   <tr> | ||||
|  *    <td>Error "<b><tt>Unknown input source file formats: <i>{X}</i></tt></b>" shown when compiling.</td> | ||||
|  *    <td>The nominated source files, specified in your project's makefile in the <tt>SRC</tt> configuration option, has an extension that the LUFA build system does not | ||||
|  *        recognise. The file extensions are case sensitive, and must be one of the supported formats (<tt>*.c</tt>, <tt>*.cpp</tt> or <tt>*.S</tt>).</td> | ||||
|  *   </tr> | ||||
|  *   <tr> | ||||
|  *    <td>Error "<b><tt>Cannot build with OBJDIR parameter set - one or more object file name is not unique</tt></b>" shown when compiling.</td> | ||||
|  *    <td>When a project is built with a non-empty <tt>OBJDIR</tt> object directory name set, all input source files must have unique names, excluding extension and path. | ||||
|  *        This means that input files that are named identically and differ only by their path or extension are invalid when this mode is used.</td> | ||||
|  *   </tr> | ||||
|  *   <tr> | ||||
|  *    <td>Error "<b><tt>Source file does not exist: <i>{X}</i></tt></b>" shown when compiling.</td> | ||||
|  *    <td>The nominated input source file, specified in the user project's <tt>SRC</tt> parameter, could not be found. Ensure the source file exists and the absolute or | ||||
|  *        relative path given in the user project makefile is correct and try again.</td> | ||||
|  *   </tr> | ||||
|  *   <tr> | ||||
|  *    <td>Error "<b><tt>Doxygen configuration file <i>{X}</i> does not exist</tt></b>" shown when upgrading a Doxygen configuration file.</td> | ||||
|  *    <td>The nominated Doxygen configuration file, specified in the user project's <tt>DOXYGEN_CONF</tt> parameter, could not be found. Ensure the configuration file exists | ||||
|  *        and the absolute or relative path given in the user project makefile is correct and try again, or run the appropriate makefile target to generate a new configuration | ||||
|  *        file.</td> | ||||
|  *   </tr> | ||||
|  *   <tr> | ||||
|  *    <td>Error "<b><tt>avr-gcc: error: unrecognized option '<i>{X}</i>'</tt></b>" shown when compiling.</td> | ||||
|  *    <td>An unrecognised option was supplied to the compiler, usually in the <tt>C_FLAGS</tt>, <tt>CPP_FLAGS</tt>, <tt>ASM_FLAGS</tt> or <tt>CC_FLAGS</tt> configuration | ||||
|  *        options. The nominated compiler switch may be invalid, or unsupported by the version of AVR-GCC on the host system. Remove the unrecognised flag if invalid, or | ||||
|  *        upgrade to the latest AVR-GCC. If the option is a valid linker option, use the prefix "-Wl," to ensure it is passed to the linker correctly.</td> | ||||
|  *   </tr> | ||||
|  *   <tr> | ||||
|  *    <td>Error "<b><tt>makefile:{X}: {Y}.mk: No such file or directory</tt></b>" shown when make is invoked.</td> | ||||
|  *    <td>The path to the nominated makefile module was incorrect. This usually indicates that the makefile <tt>LUFA_PATH</tt> option is not set to a valid relative or | ||||
|  *        absolute path to the LUFA library core.</td> | ||||
|  *   </tr> | ||||
|  *   <tr> | ||||
|  *    <td>Error "<b><tt>fatal error: LUFAConfig.h: No such file or directory</tt></b>" shown when compiling.</td> | ||||
|  *    <td>The <tt>USE_LUFA_CONFIG_HEADER</tt> compile time option was set in the user project makefile, but the user supplied <tt>LUFAConfig.h</tt> header could not be | ||||
|  *        found. Ensure that the directory that contains this configuration file is correctly passed to the compiler via the -I switch in the makefile <tt>CC_FLAGS</tt> | ||||
|  *        parameter.</td> | ||||
|  *   </tr> | ||||
|  *   <tr> | ||||
|  *    <td>Error "<b><tt>ld.exe: section .apitable_trampolines loaded at <i>{X}</i> overlaps section .text</tt></b>" shown when compiling a bootloader.</td> | ||||
|  *    <td>The bootloader is compiling too large for the given <tt>FLASH_SIZE_KB</tt> and <tt>BOOT_SECTION_SIZE_KB</tt> parameters set in the bootloader makefile. This | ||||
|  *        usually indicates that these values are incorrect for the specified device the bootloader is targeting. If these values are correct, a newer version of the | ||||
|  *        compiler may need to be used to ensure that the bootloader is built within the section size constraints of the target device.</td> | ||||
|  *   </tr> | ||||
|  *   <tr> | ||||
|  *    <td>Error "<b><tt>unknown MCU '<i>{X}</i>' specified</tt></b>" shown when compiling.</td> | ||||
|  *    <td>The specified microcontroller device model name set in the user application's makefile as the <tt>MCU</tt> parameter is incorrect, or unsupported by the | ||||
|  *        version of the compiler being used. Make sure the model name is correct, or upgrade to the latest Atmel Toolchain to obtain newer device support.</td> | ||||
|  *   </tr> | ||||
|  *   <tr> | ||||
|  *    <td>Error "<b><tt>undefined reference to `<i>{X}</i>'</tt></b>" shown when compiling.</td> | ||||
|  *    <td>This is usually caused by a missing source file in the user application's <tt>SRC</tt> configuration parameter. If the indicated symbol is one from the LUFA | ||||
|  *        library, you may be missing a LUFA source makefile module (see \ref Page_BuildModule_LUFA_SOURCES).</td> | ||||
|  *   </tr> | ||||
|  *  </table> | ||||
|  * | ||||
|  *  For troubleshooting other errors you encounter, please see \ref Sec_ProjectHelp. | ||||
|  */ | ||||
							
								
								
									
										23
									
								
								LUFA/DoxygenPages/BuildingLinkableLibraries.txt
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										23
									
								
								LUFA/DoxygenPages/BuildingLinkableLibraries.txt
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,23 @@ | |||
| /** \file | ||||
|  * | ||||
|  *  This file contains special DoxyGen information for the generation of the main page and other special | ||||
|  *  documentation pages. It is not a project source file. | ||||
|  */ | ||||
| 
 | ||||
| /** \page Page_BuildLibrary Building as a Linkable Library | ||||
|  * | ||||
|  *  The LUFA library can be built as a proper linkable library (with the extension .a) under AVR-GCC, so that | ||||
|  *  the library does not need to be recompiled with each revision of a user project. Instructions for creating | ||||
|  *  a library from a given source tree can be found in the AVR-GCC user manual included in the WinAVR install | ||||
|  *  /Docs/ directory. | ||||
|  * | ||||
|  *  However, building the library is <b>not recommended</b>, as the static (compile-time) options will be | ||||
|  *  unable to be changed without a recompilation of the LUFA code. Therefore, if the library is to be built | ||||
|  *  from the LUFA source, it should be made to be application-specific and compiled with the static options | ||||
|  *  that are required for each project (which should be recorded along with the library). | ||||
|  * | ||||
|  *  Normal library use has the library components compiled in at the same point as the application code, as | ||||
|  *  demonstrated in the library demos and applications. This is the preferred method, as the library is recompiled | ||||
|  *  each time to ensure that all static options for a particular application are applied. | ||||
|  */ | ||||
| 
 | ||||
							
								
								
									
										1653
									
								
								LUFA/DoxygenPages/ChangeLog.txt
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										1653
									
								
								LUFA/DoxygenPages/ChangeLog.txt
									
										
									
									
									
										Normal file
									
								
							
										
											
												File diff suppressed because it is too large
												Load diff
											
										
									
								
							
							
								
								
									
										223
									
								
								LUFA/DoxygenPages/CompileTimeTokens.txt
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										223
									
								
								LUFA/DoxygenPages/CompileTimeTokens.txt
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,223 @@ | |||
| /** \file | ||||
|  * | ||||
|  *  This file contains special DoxyGen information for the generation of the main page and other special | ||||
|  *  documentation pages. It is not a project source file. | ||||
|  */ | ||||
| 
 | ||||
| /** \page Page_TokenSummary Summary of Compile Tokens | ||||
|  * | ||||
|  *  The following lists all the possible tokens which can be defined in a project makefile, and passed to the | ||||
|  *  compiler via the -D switch, to alter the LUFA library code. These tokens may alter the library behaviour, | ||||
|  *  or remove features unused by a given application in order to save flash space. | ||||
|  * | ||||
|  *  \note If the \c USE_LUFA_CONFIG_HEADER token is defined, the library will include a header file named \c LUFAConfig.h located | ||||
|  *        in the user directory where the below compile time tokens may be defined. This allows for an alternative to makefile | ||||
|  *        defined tokens for configuring the library. | ||||
|  * | ||||
|  *  \section Sec_TokenSummary_NonUSBTokens Non USB Related Tokens | ||||
|  *  This section describes compile tokens which affect non-USB sections of the LUFA library. | ||||
|  * | ||||
|  *  \li <b>DISABLE_TERMINAL_CODES</b> - (\ref Group_Terminal) - <i>All Architectures</i> \n | ||||
|  *      If an application contains ANSI terminal control codes listed in TerminalCodes.h, it might be desired to remove them | ||||
|  *      at compile time for use with a terminal which is non-ANSI control code aware, without modifying the source code. If | ||||
|  *      this token is defined, all ANSI control codes in the application code from the TerminalCodes.h header are removed from | ||||
|  *      the source code at compile time. | ||||
|  * | ||||
|  * | ||||
|  *  \section Sec_TokenSummary_USBClassTokens USB Class Driver Related Tokens | ||||
|  *  This section describes compile tokens which affect USB class-specific drivers in the LUFA library. | ||||
|  * | ||||
|  *  \li <b>HID_HOST_BOOT_PROTOCOL_ONLY</b> - (\ref Group_USBClassHIDHost) - <i>All Architectures</i> \n | ||||
|  *      By default, the USB HID Host class driver is designed to work with HID devices using either the Boot or Report HID | ||||
|  *      communication protocols. On devices where the Report protocol is not used (i.e. in applications where only basic | ||||
|  *      Mouse or Keyboard operation is desired, using boot compatible devices), the code responsible for the Report protocol | ||||
|  *      mode can be removed to save space in the compiled application by defining this token. When defined, it is still necessary | ||||
|  *      to explicitly put the attached device into Boot protocol mode via a call to \ref HID_Host_SetBootProtocol(). | ||||
|  * | ||||
|  *  \li <b>HID_STATETABLE_STACK_DEPTH</b>=<i>x</i> - (\ref Group_HIDParser) - <i>All Architectures</i> \n | ||||
|  *      HID reports may contain PUSH and POP elements, to store and retrieve the current HID state table onto a stack. This | ||||
|  *      allows for reports to save the state table before modifying it slightly for a data item, and then restore the previous | ||||
|  *      state table in a compact manner. This token may be defined to a non-zero 8-bit value to give the maximum depth of the state | ||||
|  *      table stack. If not defined, this defaults to the value indicated in the HID.h file documentation. | ||||
|  * | ||||
|  *  \li <b>HID_USAGE_STACK_DEPTH</b>=<i>x</i> - (\ref Group_HIDParser) - <i>All Architectures</i> \n | ||||
|  *      HID reports generally contain many USAGE elements, which are assigned to INPUT, OUTPUT and FEATURE items in succession | ||||
|  *      when multiple items are defined at once (via REPORT COUNT elements). This allows for several items to be defined with | ||||
|  *      different usages in a compact manner. This token may be defined to a non-zero 8-bit value to set the maximum depth of the | ||||
|  *      usage stack, indicating the maximum number of USAGE items which can be stored temporarily until the next INPUT, OUTPUT | ||||
|  *      and FEATURE item. If not defined, this defaults to the value indicated in the HID.h file documentation. | ||||
|  * | ||||
|  *  \li <b>HID_MAX_COLLECTIONS</b>=<i>x</i> - (\ref Group_HIDParser) - <i>All Architectures</i> \n | ||||
|  *      HID reports generally contain several COLLECTION elements, used to group related data items together. Collection information | ||||
|  *      is stored separately in the processed usage structure (and referred to by the data elements in the structure) to save space. | ||||
|  *      This token may be defined to a non-zero 8-bit value to set the maximum number of COLLECTION items which can be processed by the | ||||
|  *      parser into the resultant processed report structure. If not defined, this defaults to the value indicated in the HID.h file | ||||
|  *      documentation. | ||||
|  * | ||||
|  *  \li <b>HID_MAX_REPORTITEMS</b>=<i>x</i> - (\ref Group_HIDParser) - <i>All Architectures</i> \n | ||||
|  *      All HID reports contain one or more INPUT, OUTPUT and/or FEATURE items describing the data which can be sent to and from the HID | ||||
|  *      device. Each item has associated usages, bit offsets in the item reports and other associated data indicating the manner in which | ||||
|  *      the report data should be interpreted by the host. This token may be defined to a non-zero 8-bit value to set the maximum number of | ||||
|  *      data elements which can be stored in the processed HID report structure, including INPUT, OUTPUT and (if enabled) FEATURE items. | ||||
|  *      If a item has a multiple count (i.e. a REPORT COUNT of more than 1), each item in the report count is placed separately in the | ||||
|  *      processed HID report table. If not defined, this defaults to the value indicated in the HID.h file documentation. | ||||
|  * | ||||
|  *  \li <b>HID_MAX_REPORT_IDS</b>=<i>x</i> - (\ref Group_HIDParser) - <i>All Architectures</i> \n | ||||
|  *      HID reports may contain several report IDs, to logically distinguish grouped device data from one another - for example, a combination | ||||
|  *      keyboard and mouse might use report IDs to separate the keyboard reports from the mouse reports. In order to determine the size of each | ||||
|  *      report, and thus know how many bytes must be read or written, the size of each report (IN, OUT and FEATURE) must be calculated and | ||||
|  *      stored. This token may be defined to a non-zero 8-bit value to set the maximum number of report IDs in a device which can be processed | ||||
|  *      and their sizes calculated/stored into the resultant processed report structure. If not defined, this defaults to the value indicated in | ||||
|  *      the HID.h file documentation. | ||||
|  * | ||||
|  *  \li <b>NO_CLASS_DRIVER_AUTOFLUSH</b> - (\ref Group_USBClassDrivers) - <i>All Architectures</i> \n | ||||
|  *      Many of the device and host mode class drivers automatically flush any data waiting to be written to an interface, when the corresponding | ||||
|  *      USB management task is executed. This is usually desirable to ensure that any queued data is sent as soon as possible once and new data is | ||||
|  *      constructed in the main program loop. However, if flushing is to be controlled manually by the user application via the *_Flush() commands, | ||||
|  *      the compile time token may be defined in the application's makefile to disable automatic flushing during calls to the class driver USB | ||||
|  *      management tasks. | ||||
|  * | ||||
|  * | ||||
|  *  \section Sec_TokenSummary_USBTokens General USB Driver Related Tokens | ||||
|  *  This section describes compile tokens which affect USB driver stack as a whole in the LUFA library. | ||||
|  * | ||||
|  *  \li <b>ORDERED_EP_CONFIG</b> - (\ref Group_EndpointManagement , \ref Group_PipeManagement) - <i>AVR8, UC3</i> \n | ||||
|  *      The USB AVRs do not allow for Endpoints and Pipes to be configured out of order; they <i>must</i> be configured in an ascending order to | ||||
|  *      prevent data corruption issues. However, by default LUFA employs a workaround to allow for unordered Endpoint/Pipe initialization. This compile | ||||
|  *      time token may be used to restrict the initialization order to ascending indexes only in exchange for a smaller compiled binary size. Use | ||||
|  *      caution when applied to applications using the library USB Class drivers; the user application must ensure that all endpoints and pipes are | ||||
|  *      allocated sequentially. | ||||
|  * | ||||
|  *  \li <b>USE_STATIC_OPTIONS</b>=<i>x</i> - (\ref Group_USBManagement) - <i>All Architectures</i> \n | ||||
|  *      By default, the USB_Init() function accepts dynamic options at runtime to alter the library behaviour, including whether the USB pad | ||||
|  *      voltage regulator is enabled, and the device speed when in device mode. By defining this token to a mask comprised of the USB options | ||||
|  *      mask defines usually passed as the Options parameter to USB_Init(), the resulting compiled binary can be decreased in size by removing | ||||
|  *      the dynamic options code, and replacing it with the statically set options. When defined, the USB_Init() function no longer accepts an | ||||
|  *      Options parameter. | ||||
|  * | ||||
|  *  \li <b>USB_DEVICE_ONLY</b> - (\ref Group_USBManagement) - <i>All Architectures</i> \n | ||||
|  *      For the USB AVR models supporting both device and host USB modes, the USB_Init() function contains a Mode parameter which specifies the | ||||
|  *      mode the library should be initialized to. If only device mode is required, the code for USB host mode can be removed from the binary to | ||||
|  *      save space. When defined, the USB_Init() function no longer accepts a Mode parameter. This define is irrelevant on smaller USB AVRs which | ||||
|  *      do not support host mode. | ||||
|  * | ||||
|  *  \li <b>USB_HOST_ONLY</b> - (\ref Group_USBManagement) - <i>All Architectures</i> \n | ||||
|  *      Same as USB_DEVICE_ONLY, except the library is fixed to USB host mode rather than USB device mode. Not available on some USB AVR models. | ||||
|  * | ||||
|  *  \li <b>USB_STREAM_TIMEOUT_MS</b>=<i>x</i> - (\ref Group_USBManagement) - <i>All Architectures</i> \n | ||||
|  *      When endpoint and/or pipe stream functions are used, by default there is a timeout between each transfer which the connected device or host | ||||
|  *      must satisfy, or the stream function aborts the remaining data transfer. This token may be defined to a non-zero 16-bit value to set the timeout | ||||
|  *      period for stream transfers, specified in milliseconds. If not defined, the default value specified in LowLevel.h is used instead. | ||||
|  * | ||||
|  *  \li <b>NO_LIMITED_CONTROLLER_CONNECT</b> - (\ref Group_Events) - <i>AVR8 Only</i> \n | ||||
|  *      On the smaller USB AVRs, the USB controller lacks VBUS events to determine the physical connection state of the USB bus to a host. In lieu of | ||||
|  *      VBUS events, the library attempts to determine the connection state via the bus suspension and wake up events instead. This however may be | ||||
|  *      slightly inaccurate due to the possibility of the host suspending the bus while the device is still connected. If accurate connection status is | ||||
|  *      required, the VBUS line of the USB connector should be routed to an AVR pin to detect its level, so that the \ref USB_DeviceState global | ||||
|  *      can be accurately set and the \ref EVENT_USB_Device_Connect() and \ref EVENT_USB_Device_Disconnect() events manually raised by the user application. | ||||
|  *      When defined, this token disables the library's auto-detection of the connection state by the aforementioned suspension and wake up events. | ||||
|  * | ||||
|  *  \li <b>NO_SOF_EVENTS</b> - (\ref Group_Events) - <i>All Architectures</i> \n | ||||
|  *      By default, there exists a LUFA application event for the start of each USB frame while the USB bus is not suspended in either host or device mode. | ||||
|  *      This event can be selectively enabled or disabled by calling the appropriate device or host mode function. When this compile time token is defined, | ||||
|  *      the ability to receive USB Start of Frame events via the \ref EVENT_USB_Device_StartOfFrame() or \ref EVENT_USB_Host_StartOfFrame() events is removed, | ||||
|  *      reducing the compiled program's binary size. | ||||
|  * | ||||
|  * | ||||
|  *  \section Sec_TokenSummary_USBDeviceTokens USB Device Mode Driver Related Tokens | ||||
|  *  This section describes compile tokens which affect USB driver stack of the LUFA library when used in Device mode. | ||||
|  * | ||||
|  *  \li <b>USE_RAM_DESCRIPTORS</b> - (\ref Group_StdDescriptors) - <i>AVR8 Only</i> \n | ||||
|  *      Define this token to indicate to the USB driver that all device descriptors are stored in RAM, rather than being located in any one | ||||
|  *      of the AVR's memory spaces. RAM descriptors may be desirable in applications where the descriptors need to be modified at runtime. | ||||
|  * | ||||
|  *  \li <b>USE_FLASH_DESCRIPTORS</b> - (\ref Group_StdDescriptors) - <i>AVR8 Only</i> \n | ||||
|  *      Similar to USE_RAM_DESCRIPTORS, but all descriptors are stored in the AVR's FLASH memory rather than RAM. | ||||
|  * | ||||
|  *  \li <b>USE_EEPROM_DESCRIPTORS</b> - (\ref Group_StdDescriptors) - <i>AVR8 Only</i> \n | ||||
|  *      Similar to USE_RAM_DESCRIPTORS, but all descriptors are stored in the AVR's EEPROM memory rather than RAM. | ||||
|  * | ||||
|  *  \li <b>NO_INTERNAL_SERIAL</b> - (\ref Group_StdDescriptors) - <i>All Architectures</i> \n | ||||
|  *      Some AVR models contain a unique serial number which can be used as the device serial number, while in device mode. This allows | ||||
|  *      the host to uniquely identify the device regardless of if it is moved between USB ports on the same computer, allowing allocated | ||||
|  *      resources (such as drivers, COM Port number allocations) to be preserved. This is not needed in many apps, and so the code that | ||||
|  *      performs this task can be disabled by defining this option and passing it to the compiler via the -D switch. | ||||
|  * | ||||
|  *  \li <b>FIXED_CONTROL_ENDPOINT_SIZE</b>=<i>x</i> - (\ref Group_EndpointManagement) - <i>All Architectures</i> \n | ||||
|  *      By default, the library determines the size of the control endpoint (when in device mode) by reading the device descriptor. | ||||
|  *      Normally this reduces the amount of configuration required for the library, allows the value to change dynamically (if | ||||
|  *      descriptors are stored in EEPROM or RAM rather than flash memory) and reduces code maintenance. However, this token can be | ||||
|  *      defined to a non-zero value instead to give the size in bytes of the control endpoint, to reduce the size of the compiled | ||||
|  *      binary. | ||||
|  * | ||||
|  *  \li <b>DEVICE_STATE_AS_GPIOR</b> - (\ref Group_Device) - <i>AVR8 Only</i> \n | ||||
|  *      One of the most frequently used global variables in the stack is the USB_DeviceState global, which indicates the current state of | ||||
|  *      the Device State Machine. To reduce the amount of code and time required to access and modify this global in an application, this token | ||||
|  *      may be defined to a value between 0 and 2 to fix the state variable into one of the three general purpose IO registers inside the AVR | ||||
|  *      reserved for application use. When defined, the corresponding GPIOR register should not be used within the user application except | ||||
|  *      implicitly via the library APIs. | ||||
|  * | ||||
|  *  \li <b>FIXED_NUM_CONFIGURATIONS</b>=<i>x</i> - (\ref Group_Device) - <i>All Architectures</i> \n | ||||
|  *      By default, the library determines the number of configurations a USB device supports by reading the device descriptor. This reduces | ||||
|  *      the amount of configuration required to set up the library, and allows the value to change dynamically (if descriptors are stored in | ||||
|  *      EEPROM or RAM rather than flash memory) and reduces code maintenance. However, this value may be fixed via this token in the project | ||||
|  *      makefile to reduce the compiled size of the binary at the expense of flexibility. | ||||
|  * | ||||
|  *  \li <b>CONTROL_ONLY_DEVICE</b> - (\ref Group_Device) - <i>All Architectures</i> \n | ||||
|  *      In some limited USB device applications, there are no device endpoints other than the control endpoint; i.e. all device communication | ||||
|  *      is through control endpoint requests. Defining this token will remove several features related to the selection and control of device | ||||
|  *      endpoints internally, saving space. Generally, this is usually only useful in (some) bootloaders and is best avoided. | ||||
|  * | ||||
|  *  \li <b>MAX_ENDPOINT_INDEX</b> - (\ref Group_Device) - <i>XMEGA Only</i> \n | ||||
|  *      Defining this value to the highest index (not address - this excludes the direction flag) endpoint within the device will restrict the | ||||
|  *      number of FIFOs created internally for the endpoint buffers, reducing the total RAM usage. | ||||
|  * | ||||
|  *  \li <b>INTERRUPT_CONTROL_ENDPOINT</b> - (\ref Group_USBManagement) - <i>All Architectures</i> \n | ||||
|  *      Some applications prefer to not call the USB_USBTask() management task regularly while in device mode, as it can complicate code significantly. | ||||
|  *      Instead, when device mode is used this token can be passed to the library via the -D switch to allow the library to manage the USB control | ||||
|  *      endpoint entirely via USB controller interrupts asynchronously to the user application. When defined, USB_USBTask() does not need to be called | ||||
|  *      when in USB device mode. | ||||
|  * | ||||
|  *  \li <b>NO_DEVICE_REMOTE_WAKEUP</b> - (\ref Group_Device) - <i>All Architectures</i> \n | ||||
|  *      Many devices do not require the use of the Remote Wakeup features of USB, used to wake up the USB host when suspended. On these devices, | ||||
|  *      the code required to manage device Remote Wakeup can be disabled by defining this token and passing it to the library via the -D switch. | ||||
|  * | ||||
|  *  \li <b>NO_DEVICE_SELF_POWER</b> - (\ref Group_Device) - <i>All Architectures</i> \n | ||||
|  *      USB devices may be bus powered, self powered, or a combination of both. When a device can be both bus powered and self powered, the host may | ||||
|  *      query the device to determine the current power source, via \ref USB_Device_CurrentlySelfPowered. For solely bus powered devices, this global | ||||
|  *      and the code required to manage it may be disabled by passing this token to the library via the -D switch. | ||||
|  * | ||||
|  * | ||||
|  *  \section Sec_TokenSummary_USBHostTokens USB Host Mode Driver Related Tokens | ||||
|  * | ||||
|  *  This section describes compile tokens which affect USB driver stack of the LUFA library when used in Host mode. | ||||
|  * | ||||
|  *  \li <b>HOST_STATE_AS_GPIOR</b> - (\ref Group_Host) - <i>AVR8 Only</i> \n | ||||
|  *      One of the most frequently used global variables in the stack is the USB_HostState global, which indicates the current state of | ||||
|  *      the Host State Machine. To reduce the amount of code and time required to access and modify this global in an application, this token | ||||
|  *      may be defined to a value between 0 and 2 to fix the state variable into one of the three general purpose IO registers inside the AVR | ||||
|  *      reserved for application use. When defined, the corresponding GPIOR register should not be used within the user application except | ||||
|  *      implicitly via the library APIs. | ||||
|  * | ||||
|  *  \li <b>USB_HOST_TIMEOUT_MS</b>=<i>x</i> - (\ref Group_Host) - <i>All Architectures</i> \n | ||||
|  *      When a control transfer is initiated in host mode to an attached device, a timeout is used to abort the transfer if the attached | ||||
|  *      device fails to respond within the timeout period. This token may be defined to a non-zero 16-bit value to set the timeout period for | ||||
|  *      control transfers, specified in milliseconds. If not defined, the default value specified in Host.h is used instead. | ||||
|  * | ||||
|  *  \li <b>HOST_DEVICE_SETTLE_DELAY_MS</b>=<i>x</i> - (\ref Group_Host) - <i>All Architectures</i> \n | ||||
|  *      Some devices require a delay of up to 5 seconds after they are connected to VBUS before the enumeration process can be started, or | ||||
|  *      they will fail to enumerate correctly. By placing a delay before the enumeration process, it can be ensured that the bus has settled | ||||
|  *      back to a known idle state before communications occur with the device. This token may be defined to a 16-bit value to set the device | ||||
|  *      settle period, specified in milliseconds. If not defined, the default value specified in Host.h is used instead. | ||||
|  * | ||||
|  *  \li <b>INVERTED_VBUS_ENABLE_LINE</b> - (\ref Group_Host) - <i>All Architectures</i> \n | ||||
|  *      If enabled, this will indicate that the USB target VBUS line polarity is inverted; i.e. it should be pulled low to enable VBUS to the | ||||
|  *      target, and pulled high to stop the target VBUS generation. | ||||
|  *      \n | ||||
|  *      \attention On AVR8 architecture devices, this compile time option requires \c NO_AUTO_VBUS_MANAGEMENT to be set. | ||||
|  * | ||||
|  *  \li <b>NO_AUTO_VBUS_MANAGEMENT</b> - (\ref Group_Host) - <i>All Architectures</i> \n | ||||
|  *      Disables the automatic management of VBUS to the target, i.e. automatic shut down in the even of an overcurrent situation. When enabled, VBUS | ||||
|  *      is enabled while the USB controller is initialized in USB Host mode. | ||||
|  */ | ||||
| 
 | ||||
							
								
								
									
										46
									
								
								LUFA/DoxygenPages/CompilingApps.txt
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										46
									
								
								LUFA/DoxygenPages/CompilingApps.txt
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,46 @@ | |||
| /** \file | ||||
|  * | ||||
|  *  This file contains special DoxyGen information for the generation of the main page and other special | ||||
|  *  documentation pages. It is not a project source file. | ||||
|  */ | ||||
| 
 | ||||
| /** \page Page_CompilingApps Compiling the Demos, Bootloaders and Projects | ||||
|  * | ||||
|  *  The following details how to compile the included LUFA demos, applications and bootloaders using AVR-GCC. | ||||
|  * | ||||
|  *  \section Sec_CompilingApps_Prerequisites Prerequisites | ||||
|  *  Before you can compile any of the LUFA library code or demos, you will need a recent distribution of avr-libc (1.6.2+) | ||||
|  *  and the AVR-GCC (4.2+) compiler. A standard "coreutils" package for your system is also required for command line | ||||
|  *  compilation of LUFA based applications. | ||||
|  * | ||||
|  *  \subsection SSec_CompilingApps_PreqWindows Windows Prerequisites | ||||
|  *  On Windows, you will need a copy of the latest Atmel Toolchain (<a>http://www.atmel.com/tools/ATMELAVRTOOLCHAINFORWINDOWS.aspx</a>), | ||||
|  *  either downloaded and installed as a standalone package, or installed as part of Atmel Studio. You will need to ensure | ||||
|  *  that the "bin" directory of the toolchain is available in your system's <b>PATH</b> environment variable. | ||||
|  * | ||||
|  *  In addition, you will need to install a ported version of the ZSH or BASH *nix shells, and a standard set of *nix | ||||
|  *  utilities such as <i>cut</i>, <i>find</i> and <i>sed</i>. These can be found in the "basic" system package of the | ||||
|  *  of the MinGW installer (<a>http://www.mingw.org</a>). Once installed, add the "msys\1.0\bin" of the MinGW installation | ||||
|  *  folder is added to your system's <b>PATH</b> environment variable. | ||||
|  * | ||||
|  *  \subsection SSec_CompilingApps_PreqLinux Linux Prerequisites | ||||
|  *  On Linux systems you will need to install the latest Linux distribution of the standalone Atmel Toolchain from the | ||||
|  *  Atmel website (<a>http://www.atmel.com/tools/ATMELAVRTOOLCHAINFORLINUX.aspx</a>), or use the latest avr-libc and avr-gcc packages | ||||
|  *  for your chosen distribution's package manager. For full device support, the Atmel standalone Toolchain package is recommended. | ||||
|  * | ||||
|  *  \section Sec_CompilingApps_Compiling Compiling a LUFA Application | ||||
|  *  Compiling the LUFA demos, applications and/or bootloaders is very simple. LUFA comes with makefile scripts for | ||||
|  *  each individual demo, bootloader and project folder, as well as scripts in the Demos/, Bootloaders/, Projects/ | ||||
|  *  and the LUFA root directory. Compilation of projects can be started from any of the above directories, with a build | ||||
|  *  started from an upper directory in the directory structure executing build of all child directories under it. This | ||||
|  *  means that while a build inside a particular demo directory will build only that particular demo, a build started from | ||||
|  *  the /Demos/ directory will build all LUFA demo projects sequentially. | ||||
|  * | ||||
|  *  To build a project from the source via the command line, the command <b>"make all"</b> should be executed from the command | ||||
|  *  line in the directory of interest. To remove compiled files (including the binary output, all intermediately files and all | ||||
|  *  diagnostic output files), execute <b>"make clean"</b>. Once a "make all" has been run and no errors were encountered, the | ||||
|  *  resulting binary will be located in the generated ".HEX" file. If your project makes use of pre-initialized EEPROM | ||||
|  *  variables, the generated ".EEP" file will contain the project's EEPROM data. | ||||
|  * | ||||
|  *  \see \ref Page_BuildSystem for information on the LUFA build system. | ||||
|  */ | ||||
							
								
								
									
										157
									
								
								LUFA/DoxygenPages/ConfiguringApps.txt
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										157
									
								
								LUFA/DoxygenPages/ConfiguringApps.txt
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,157 @@ | |||
| /** \file | ||||
|  * | ||||
|  *  This file contains special DoxyGen information for the generation of the main page and other special | ||||
|  *  documentation pages. It is not a project source file. | ||||
|  */ | ||||
| 
 | ||||
| /** \page Page_ConfiguringApps Configuring the Demos, Bootloaders and Projects | ||||
|  * | ||||
|  *  If the target microcontroller model, architecture, clock speed, board or other settings are different from the current | ||||
|  *  settings, they must be changed and the project recompiled from the source code before being programmed into the microcontroller. | ||||
|  *  Most project configuration options are located in the <tt>makefile</tt> build script inside each LUFA application's folder, | ||||
|  *  however some demo or application-specific configuration settings are located in one or more of the source files of the project. | ||||
|  *  See each project's individual documentation for application-specific configuration values. | ||||
|  * | ||||
|  *  Each project "makefile" contains all the script and configuration data required to compile each project. When opened with | ||||
|  *  any regular basic text editor such as Notepad or WordPad (ensure that the save format is a pure ASCII text format) the | ||||
|  *  build configuration settings may be altered. | ||||
|  * | ||||
|  *  \see \ref Page_BuildSystem for information on the LUFA build system. | ||||
|  * | ||||
|  *  \section Sec_ConfiguringApps_AppMakefileParams The Default Application Makefile Template | ||||
|  * | ||||
|  *  Below is a copy of the default LUFA application makefile, which can be used as a template for each application. | ||||
|  * | ||||
|  *  \verbinclude makefile_template | ||||
|  * | ||||
|  *  Inside each makefile, a number of configuration variables are listed with the syntax "<VARIABLE NAME> = <VALUE>". For | ||||
|  *  each application, the important standard variables which should be altered are: | ||||
|  * | ||||
|  *    - <b>MCU</b>, the target processor model | ||||
|  *    - <b>ARCH</b>, the target microcontroller architecture | ||||
|  *    - <b>BOARD</b>, the target board hardware | ||||
|  *    - <b>F_CPU</b>, the target CPU master clock frequency, after any prescaling | ||||
|  *    - <b>F_USB</b>, the target raw input clock to the USB module of the processor | ||||
|  *    - <b>OPTIMIZATION</b>, the level of optimization to compile with | ||||
|  *    - <b>TARGET</b>, the name of the target output binary and other files | ||||
|  *    - <b>SRC</b>, the list of source files to compile/assemble/link | ||||
|  *    - <b>LUFA_PATH</b>, the path to the LUFA library core source code | ||||
|  *    - <b>CC_FLAGS</b>, the common command line flags to pass to the C/C++ compiler, assembler and linker | ||||
|  *    - <b>LD_FLAGS</b>, the command line flags to pass to the linker | ||||
|  * | ||||
|  *  These values should be changed to reflect the build hardware. | ||||
|  * | ||||
|  *  \subsection SSec_ConfiguringApps_MCU The MCU Parameter | ||||
|  *  This parameter indicates the target microcontroller model for the compiled application. This should be set to the model of the target | ||||
|  *  microcontroller (such as the AT90USB1287, or the ATMEGA32U4), in all lower-case (e.g. "at90usb1287"). Note that not all demos support all the | ||||
|  *  microcontroller models and architectures, as they may make use of peripherals or modes only present in some devices. | ||||
|  * | ||||
|  *  For supported processor models, see \ref Page_DeviceSupport. | ||||
|  * | ||||
|  *  \subsection SSec_ConfiguringApps_ARCH The ARCH Parameter | ||||
|  *  This parameter indicates the target microcontroller architecture the library is to be compiled for. Different microcontroller | ||||
|  *  architectures require different source files to be compiled into the final binary, and so this option must be set to the correct | ||||
|  *  architecture for the selected platform. | ||||
|  * | ||||
|  *  For supported processor architectures, see \ref Page_DeviceSupport. | ||||
|  * | ||||
|  *  \subsection SSec_ConfiguringApps_BOARD The BOARD Parameter | ||||
|  *  This parameter indicates the target board hardware for the compiled application. Some LUFA library drivers are board-specific, | ||||
|  *  such as the LED driver, and the library needs to know the layout of the target board. If you are using one of the board models listed | ||||
|  *  on the main library page, change this parameter to the board name in all UPPER-case. | ||||
|  * | ||||
|  *  If you are not using any board-specific drivers in the LUFA library, or you are using a custom board layout, change this to read | ||||
|  *  "USER" (no quotes) instead of a standard board name. If the USER board type is selected and the application makes use of one or more | ||||
|  *  board-specific hardware drivers inside the LUFA library, then the appropriate stub drives files should be copied from the \c /CodeTemplates/DriverStubs/ | ||||
|  *  directory into a /Board/ folder inside the application directory, and the stub driver completed with the appropriate code to drive the | ||||
|  *  custom board's hardware. | ||||
|  * | ||||
|  *  For boards with built in hardware driver support within the LUFA library, see \ref Page_DeviceSupport. | ||||
|  * | ||||
|  *  \subsection SSec_ConfiguringApps_F_CPU The F_CPU Parameter | ||||
|  *  This parameter indicates the target microcontroller's main CPU clock frequency, in Hz. This is used by many libraries (and applications) for | ||||
|  *  timing related purposes, and should reflect the actual CPU speed after any prescaling or adjustments are performed. | ||||
|  * | ||||
|  *  \subsection SSec_ConfiguringApps_F_USB The F_USB Parameter | ||||
|  *  This parameter indicates the raw input clock frequency to the USB module within the microcontroller in Hz. This may be very different on some platforms | ||||
|  *  to the main CPU clock or other peripheral/bus clocks. | ||||
|  * | ||||
|  *    \note On AVR8 platforms, this must be equal to \c 8000000 or \c 16000000. | ||||
|  * | ||||
|  *    \note On XMEGA platforms, this must be equal to a multiple of 6000000 from \c 6000000 to \c 48000000. | ||||
|  * | ||||
|  *    \note On UC3 platforms, this must be equal to a multiple of 12000000 from \c 12000000 to \c 48000000. | ||||
|  * | ||||
|  *  \subsection SSec_ConfiguringApps_OPTIMIZATION The OPTIMIZATION Parameter | ||||
|  *  This parameter indicates the level of optimization to use when compiling the application. This will allow you to compile with an optimization level | ||||
|  *  supported by GCC, from <tt>0</tt> (no optimization) to <tt>3</tt> (fastest runtime optimization) or <tt>s</tt> (smallest size). | ||||
|  * | ||||
|  *  \subsection SSec_ConfiguringApps_TARGET The TARGET Parameter | ||||
|  *  This parameter indicates the application target name, which is used as the base filename for the build binary and debugging files. This will be the | ||||
|  *  name of the output files once linked together into the final application, ready to load into the target. | ||||
|  * | ||||
|  *  \subsection SSec_ConfiguringApps_SRC The SRC Parameter | ||||
|  *  This parameter indicates the source files used to compile the application, as a list of C (<tt>*.c</tt>), C++ (<tt>*.cpp</tt>) and Assembly (<tt>*.S</tt>) files. Note that | ||||
|  *  all assembly files must end in a <b>capital</b> .S extension, as lowercase .s files are reserved for GCC intermediate files. | ||||
|  * | ||||
|  *  \subsection SSec_ConfiguringApps_LUFA_PATH The LUFA_PATH Parameter | ||||
|  *  As each LUFA program requires the LUFA library source code to compile correctly, the application must know where the LUFA library is located. This | ||||
|  *  value specifies the path to the LUFA library core. This path may be relative or absolute, however note than even under Windows based systems the | ||||
|  *  forward-slash (/) path separator must be used. | ||||
|  * | ||||
|  *  \subsection SSec_ConfiguringApps_CC_FLAGS The CC_FLAGS Parameter | ||||
|  *  This parameter lists the compiler flags passed to the C/C++ compiler, the assembler and the linker. These are used as-is directly to GCC and thus | ||||
|  *  must match GCC's command line options as given in the GCC manual. This variable may be used to define tokens directly on the command line, enable or | ||||
|  *  disable warnings, adjust the target-specific tuning parameters or other options. | ||||
|  * | ||||
|  *  \subsection SSec_ConfiguringApps_LD_FLAGS The LD_FLAGS Parameter | ||||
|  *  This parameter lists the linker flags passed exclusively to the linker. These are used as-is directly to GCC and thus must match GCC's command line | ||||
|  *  linker options as given in the GCC manual. This variable may be used to create or relocate custom data sections, or enable linker specific behaviors. | ||||
|  * | ||||
|  * | ||||
|  *  \section Sec_ExampleAppConfig Example Application Makefile Configurations | ||||
|  *  Below is an example makefile for an AVR8 based AT90USB1287 running at 8MHz, to compile a program called "MyApplication": | ||||
|  *  \verbatim | ||||
|     MCU          = at90usb1287 | ||||
|     ARCH         = AVR8 | ||||
|     BOARD        = NONE | ||||
|     F_CPU        = 8000000 | ||||
|     F_USB        = $(F_CPU) | ||||
|     OPTIMIZATION = s | ||||
|     TARGET       = MyApplication | ||||
|     SRC          = MyApplication.c Descriptors.c $(LUFA_SRC_USB) $(LUFA_SRC_USBCLASS) | ||||
|     LUFA_PATH    = ../../../../LUFA | ||||
|     CC_FLAGS     = -DUSE_LUFA_CONFIG_HEADER -IConfig/ | ||||
|     LD_FLAGS     = | ||||
|     \endverbatim | ||||
|  * | ||||
|  *  Below is an example makefile for an XMEGA based ATXMEGA128A1U running at 32MHz, to compile a program called "MyApplication": | ||||
|  *  \verbatim | ||||
|     MCU          = atxmega128a1u | ||||
|     ARCH         = XMEGA | ||||
|     BOARD        = NONE | ||||
|     F_CPU        = 32000000 | ||||
|     F_USB        = 48000000 | ||||
|     OPTIMIZATION = s | ||||
|     TARGET       = MyApplication | ||||
|     SRC          = MyApplication.c Descriptors.c $(LUFA_SRC_USB) $(LUFA_SRC_USBCLASS) | ||||
|     LUFA_PATH    = ../../../../LUFA | ||||
|     CC_FLAGS     = -DUSE_LUFA_CONFIG_HEADER -IConfig/ | ||||
|     LD_FLAGS     = | ||||
|     \endverbatim | ||||
|  * | ||||
|  *  Below is an example makefile for a UC3 based AT32UC3A0512 running at 50MHz, to compile a program called "MyApplication": | ||||
|  *  \verbatim | ||||
|     MCU          = uc3a0512 | ||||
|     ARCH         = UC3 | ||||
|     BOARD        = NONE | ||||
|     F_CPU        = 50000000 | ||||
|     F_USB        = 48000000 | ||||
|     OPTIMIZATION = s | ||||
|     TARGET       = MyApplication | ||||
|     SRC          = MyApplication.c Descriptors.c $(LUFA_SRC_USB) $(LUFA_SRC_USBCLASS) | ||||
|     LUFA_PATH    = ../../../../LUFA | ||||
|     CC_FLAGS     = -DUSE_LUFA_CONFIG_HEADER -IConfig/ | ||||
|     LD_FLAGS     = | ||||
|     \endverbatim | ||||
|  */ | ||||
							
								
								
									
										23
									
								
								LUFA/DoxygenPages/DevelopingWithLUFA.txt
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										23
									
								
								LUFA/DoxygenPages/DevelopingWithLUFA.txt
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,23 @@ | |||
| /** \file | ||||
|  * | ||||
|  *  This file contains special DoxyGen information for the generation of the main page and other special | ||||
|  *  documentation pages. It is not a project source file. | ||||
|  */ | ||||
| 
 | ||||
| /** | ||||
|  *  \page Page_DevelopingWithLUFA Developing With LUFA | ||||
|  * | ||||
|  *  This section of the manual contains information on LUFA development, such as Getting Started information, | ||||
|  *  information on compile-time tuning of the library and other developer-related sections. | ||||
|  * | ||||
|  *  <b>Subsections:</b> | ||||
|  *  \li \subpage Page_BuildSystem - The LUFA Buildsystem | ||||
|  *  \li \subpage Page_TokenSummary - Summary of Compile Time Tokens | ||||
|  *  \li \subpage Page_Migration - Migrating from an Older LUFA Version | ||||
|  *  \li \subpage Page_VIDPID - Allocated USB VID and PID Values | ||||
|  *  \li \subpage Page_OSDrivers - Operating System Driver Information | ||||
|  *  \li \subpage Page_BuildLibrary - Building as a Linkable Library | ||||
|  *  \li \subpage Page_WritingBoardDrivers - How to Write Custom Board Drivers | ||||
|  *  \li \subpage Page_SoftwareBootloaderStart - How to jump to the bootloader in software | ||||
|  */ | ||||
| 
 | ||||
							
								
								
									
										424
									
								
								LUFA/DoxygenPages/DeviceSupport.txt
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										424
									
								
								LUFA/DoxygenPages/DeviceSupport.txt
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,424 @@ | |||
| /** \file | ||||
|  * | ||||
|  *  This file contains special DoxyGen information for the generation of the main page and other special | ||||
|  *  documentation pages. It is not a project source file. | ||||
|  */ | ||||
| 
 | ||||
| /** | ||||
|  *  \page Page_DeviceSupport Device and Hardware Support | ||||
|  * | ||||
|  *  <b>Atmel Microcontrollers:</b> | ||||
|  *  \li \subpage Page_AVR8Support - Atmel AVR8 Support | ||||
|  *  \li \subpage Page_UC3Support - Atmel AVR32 UC3 Support | ||||
|  *  \li \subpage Page_XMEGASupport - Atmel XMEGA Support | ||||
|  */ | ||||
| 
 | ||||
| /** | ||||
|  *  \page Page_AVR8Support Atmel 8-Bit AVR (AVR8) Support | ||||
|  * | ||||
|  *  \section Sec_AVR8Support_Devices Supported Microcontroller Models | ||||
|  * | ||||
|  *  Currently supported AVR8 models: | ||||
|  * | ||||
|  *  <table> | ||||
|  *  <tr> | ||||
|  *   <th width="150px">Part</th> | ||||
|  *   <th width="150px">USB Device Mode</th> | ||||
|  *   <th width="150px">USB Host Mode</th> | ||||
|  *  </tr> | ||||
|  *  <tr> | ||||
|  *   <td>AT90USB82</td> | ||||
|  *   <td bgcolor="#00EE00">Yes</td> | ||||
|  *   <td bgcolor="#EE0000">No</td> | ||||
|  *  </tr> | ||||
|  *  <tr> | ||||
|  *   <td>ATMEGA8U2</td> | ||||
|  *   <td bgcolor="#00EE00">Yes</td> | ||||
|  *   <td bgcolor="#EE0000">No</td> | ||||
|  *  </tr> | ||||
|  *  <tr> | ||||
|  *   <td>AT90USB162</td> | ||||
|  *   <td bgcolor="#00EE00">Yes</td> | ||||
|  *   <td bgcolor="#EE0000">No</td> | ||||
|  *  </tr> | ||||
|  *  <tr> | ||||
|  *   <td>ATMEGA16U2</td> | ||||
|  *   <td bgcolor="#00EE00">Yes</td> | ||||
|  *   <td bgcolor="#EE0000">No</td> | ||||
|  *  </tr> | ||||
|  *  <tr> | ||||
|  *   <td>ATMEGA16U4</td> | ||||
|  *   <td bgcolor="#00EE00">Yes</td> | ||||
|  *   <td bgcolor="#EE0000">No</td> | ||||
|  *  </tr> | ||||
|  *  <tr> | ||||
|  *   <td>ATMEGA32U2</td> | ||||
|  *   <td bgcolor="#00EE00">Yes</td> | ||||
|  *   <td bgcolor="#EE0000">No</td> | ||||
|  *  </tr> | ||||
|  *  <tr> | ||||
|  *   <td>ATMEGA32U4</td> | ||||
|  *   <td bgcolor="#00EE00">Yes</td> | ||||
|  *   <td bgcolor="#EE0000">No</td> | ||||
|  *  </tr> | ||||
|  *  <tr> | ||||
|  *   <td>AT90USB646</td> | ||||
|  *   <td bgcolor="#00EE00">Yes</td> | ||||
|  *   <td bgcolor="#EE0000">No</td> | ||||
|  *  </tr> | ||||
|  *  <tr> | ||||
|  *   <td>AT90USB647</td> | ||||
|  *   <td bgcolor="#00EE00">Yes</td> | ||||
|  *   <td bgcolor="#00EE00">Yes</td> | ||||
|  *  </tr> | ||||
|  *  <tr> | ||||
|  *   <td>AT90USB1286</td> | ||||
|  *   <td bgcolor="#00EE00">Yes</td> | ||||
|  *   <td bgcolor="#EE0000">No</td> | ||||
|  *  </tr> | ||||
|  *  <tr> | ||||
|  *   <td>AT90USB1287</td> | ||||
|  *   <td bgcolor="#00EE00">Yes</td> | ||||
|  *   <td bgcolor="#00EE00">Yes</td> | ||||
|  *  </tr> | ||||
|  *  </table> | ||||
|  * | ||||
|  *  \section Sec_AVR8Support_Boards Supported Atmel Boards | ||||
|  *  Currently supported Atmel AVR8 boards (see \ref Group_BoardTypes): | ||||
|  *   - AT90USBKEY | ||||
|  *   - ATAVRUSBRF01 | ||||
|  *   - EVK527 | ||||
|  *   - RZUSBSTICK | ||||
|  *   - STK525 | ||||
|  *   - STK526 | ||||
|  *   - XPLAIN (Original green board, <i>not</i> the newer blue XPLAINED family boards) | ||||
|  *   - Xplained-MINI | ||||
|  * | ||||
|  *  \section Sec_AVR8Support_ThirdParty Supported Third Party Boards | ||||
|  *  Currently supported third-party boards (see \ref Group_BoardTypes for makefile \c BOARD constant names): | ||||
|  *   - Adafruit U4 Breakout Board | ||||
|  *   - Arduino Leonardo | ||||
|  *   - Arduino Micro | ||||
|  *   - Arduino Uno | ||||
|  *   - Arduino Yun | ||||
|  *   - Bitwizard Multio and Big-Multio | ||||
|  *   - Busware BUI | ||||
|  *   - Busware CUL V3 | ||||
|  *   - Busware TUL | ||||
|  *   - DorkbotPDX Duce | ||||
|  *   - Fletchtronics Bumble-B (using manufacturer recommended peripheral layout) | ||||
|  *   - Kernel Concepts USBFOO | ||||
|  *   - Linnix UDIP | ||||
|  *   - MattairTech JM-DB-U2 | ||||
|  *   - Maximus USB | ||||
|  *   - Micropendous Boards (Micropendous-32U2, Micropendous-1, Micropendous-2) | ||||
|  *   - Microsin AVR-USB162 | ||||
|  *   - Minimus USB | ||||
|  *   - Olimex AVR-USB-162, AVR-USB-32U4 and AVR-USB-T32U4 Boards | ||||
|  *   - Olimex AVR-ISP-MK2 | ||||
|  *   - Paranoid Studio's US2AX (V1, V2 and V3 hardware revisions) | ||||
|  *   - PJRC Teensy (1.x and 2.x versions) | ||||
|  *   - Pololu A-Star Micro | ||||
|  *   - Rikus' U2S | ||||
|  *   - Sparkfun U2 Breakout Board | ||||
|  *   - Stange ISP Programmer Board | ||||
|  *   - TCNISO Blackcat USB JTAG | ||||
|  *   - Tempusdictum Benito | ||||
|  *   - Tom's USBTINY-MKII (all revisions and versions) | ||||
|  *   - Custom User Boards (with Board Drivers if desired, see \ref Page_WritingBoardDrivers) | ||||
|  */ | ||||
| 
 | ||||
| /** | ||||
|  *  \page Page_UC3Support Atmel 32-Bit UC3 AVR (UC3) | ||||
|  * | ||||
|  *  \warning The AVR32 UC3 device support is currently <b>experimental</b>, and is included for preview purposes only. | ||||
|  * | ||||
|  *  \section Sec_UC3Support_Devices Supported Microcontroller Models | ||||
|  * | ||||
|  *  Currently supported UC3 models: | ||||
|  * | ||||
|  *  <table> | ||||
|  *  <tr> | ||||
|  *   <th width="150px">Part</th> | ||||
|  *   <th width="150px">USB Device Mode</th> | ||||
|  *   <th width="150px">USB Host Mode</th> | ||||
|  *  </tr> | ||||
|  *  <tr> | ||||
|  *   <td>AT32UC3A364</td> | ||||
|  *   <td bgcolor="#00EE00">Yes</td> | ||||
|  *   <td bgcolor="#00EE00">Yes</td> | ||||
|  *  </tr> | ||||
|  *  <tr> | ||||
|  *   <td>AT32UC3A364S</td> | ||||
|  *   <td bgcolor="#00EE00">Yes</td> | ||||
|  *   <td bgcolor="#00EE00">Yes</td> | ||||
|  *  </tr> | ||||
|  *  <tr> | ||||
|  *   <td>AT32UC3A464</td> | ||||
|  *   <td bgcolor="#00EE00">Yes</td> | ||||
|  *   <td bgcolor="#00EE00">Yes</td> | ||||
|  *  </tr> | ||||
|  *  <tr> | ||||
|  *   <td>AT32UC3A464S</td> | ||||
|  *   <td bgcolor="#00EE00">Yes</td> | ||||
|  *   <td bgcolor="#00EE00">Yes</td> | ||||
|  *  </tr> | ||||
|  *  <tr> | ||||
|  *   <td>AT32UC3B064</td> | ||||
|  *   <td bgcolor="#00EE00">Yes</td> | ||||
|  *   <td bgcolor="#00EE00">Yes</td> | ||||
|  *  </tr> | ||||
|  *  <tr> | ||||
|  *   <td>AT32UC3B164</td> | ||||
|  *   <td bgcolor="#00EE00">Yes</td> | ||||
|  *   <td bgcolor="#00EE00">Yes</td> | ||||
|  *  </tr> | ||||
|  *  <tr> | ||||
|  *   <td>AT32UC3A0128</td> | ||||
|  *   <td bgcolor="#00EE00">Yes</td> | ||||
|  *   <td bgcolor="#00EE00">Yes</td> | ||||
|  *  </tr> | ||||
|  *  <tr> | ||||
|  *   <td>AT32UC3A1128</td> | ||||
|  *   <td bgcolor="#00EE00">Yes</td> | ||||
|  *   <td bgcolor="#00EE00">Yes</td> | ||||
|  *  </tr> | ||||
|  *  <tr> | ||||
|  *   <td>AT32UC3A3128</td> | ||||
|  *   <td bgcolor="#00EE00">Yes</td> | ||||
|  *   <td bgcolor="#00EE00">Yes</td> | ||||
|  *  </tr> | ||||
|  *  <tr> | ||||
|  *   <td>AT32UC3A3128S</td> | ||||
|  *   <td bgcolor="#00EE00">Yes</td> | ||||
|  *   <td bgcolor="#00EE00">Yes</td> | ||||
|  *  </tr> | ||||
|  *  <tr> | ||||
|  *   <td>AT32UC3A4128</td> | ||||
|  *   <td bgcolor="#00EE00">Yes</td> | ||||
|  *   <td bgcolor="#00EE00">Yes</td> | ||||
|  *  </tr> | ||||
|  *  <tr> | ||||
|  *   <td>AT32UC3A4128S</td> | ||||
|  *   <td bgcolor="#00EE00">Yes</td> | ||||
|  *   <td bgcolor="#00EE00">Yes</td> | ||||
|  *  </tr> | ||||
|  *  <tr> | ||||
|  *   <td>AT32UC3B0128</td> | ||||
|  *   <td bgcolor="#00EE00">Yes</td> | ||||
|  *   <td bgcolor="#00EE00">Yes</td> | ||||
|  *  </tr> | ||||
|  *  <tr> | ||||
|  *   <td>AT32UC3B1128</td> | ||||
|  *   <td bgcolor="#00EE00">Yes</td> | ||||
|  *   <td bgcolor="#00EE00">Yes</td> | ||||
|  *  </tr> | ||||
|  *  <tr> | ||||
|  *   <td>AT32UC3A0256</td> | ||||
|  *   <td bgcolor="#00EE00">Yes</td> | ||||
|  *   <td bgcolor="#00EE00">Yes</td> | ||||
|  *  </tr> | ||||
|  *  <tr> | ||||
|  *   <td>AT32UC3A1256</td> | ||||
|  *   <td bgcolor="#00EE00">Yes</td> | ||||
|  *   <td bgcolor="#00EE00">Yes</td> | ||||
|  *  </tr> | ||||
|  *  <tr> | ||||
|  *   <td>AT32UC3A3256</td> | ||||
|  *   <td bgcolor="#00EE00">Yes</td> | ||||
|  *   <td bgcolor="#00EE00">Yes</td> | ||||
|  *  </tr> | ||||
|  *  <tr> | ||||
|  *   <td>AT32UC3A3256S</td> | ||||
|  *   <td bgcolor="#00EE00">Yes</td> | ||||
|  *   <td bgcolor="#00EE00">Yes</td> | ||||
|  *  </tr> | ||||
|  *  <tr> | ||||
|  *   <td>AT32UC3A4256</td> | ||||
|  *   <td bgcolor="#00EE00">Yes</td> | ||||
|  *   <td bgcolor="#00EE00">Yes</td> | ||||
|  *  </tr> | ||||
|  *  <tr> | ||||
|  *   <td>AT32UC3A4256S</td> | ||||
|  *   <td bgcolor="#00EE00">Yes</td> | ||||
|  *   <td bgcolor="#00EE00">Yes</td> | ||||
|  *  </tr> | ||||
|  *  <tr> | ||||
|  *   <td>AT32UC3B0256</td> | ||||
|  *   <td bgcolor="#00EE00">Yes</td> | ||||
|  *   <td bgcolor="#00EE00">Yes</td> | ||||
|  *  </tr> | ||||
|  *  <tr> | ||||
|  *   <td>AT32UC3B1256</td> | ||||
|  *   <td bgcolor="#00EE00">Yes</td> | ||||
|  *   <td bgcolor="#00EE00">Yes</td> | ||||
|  *  </tr> | ||||
|  *  <tr> | ||||
|  *   <td>AT32UC3A0512</td> | ||||
|  *   <td bgcolor="#00EE00">Yes</td> | ||||
|  *   <td bgcolor="#00EE00">Yes</td> | ||||
|  *  </tr> | ||||
|  *  <tr> | ||||
|  *   <td>AT32UC3A1512</td> | ||||
|  *   <td bgcolor="#00EE00">Yes</td> | ||||
|  *   <td bgcolor="#00EE00">Yes</td> | ||||
|  *  </tr> | ||||
|  *  <tr> | ||||
|  *   <td>AT32UC3B0512</td> | ||||
|  *   <td bgcolor="#00EE00">Yes</td> | ||||
|  *   <td bgcolor="#00EE00">Yes</td> | ||||
|  *  </tr> | ||||
|  *  <tr> | ||||
|  *   <td>AT32UC3B1512</td> | ||||
|  *   <td bgcolor="#00EE00">Yes</td> | ||||
|  *   <td bgcolor="#00EE00">Yes</td> | ||||
|  *  </tr> | ||||
|  *  </table> | ||||
|  * | ||||
|  *  \section Sec_UC3Support_Boards Supported Atmel Boards | ||||
|  * | ||||
|  *  Currently supported Atmel UC3 boards (see \ref Group_BoardTypes): | ||||
|  *   - EVK1100 | ||||
|  *   - EVK1101 | ||||
|  *   - EVK1104 | ||||
|  *   - UC3-A3 Xplained | ||||
|  * | ||||
|  *  \section Sec_UC3Support_ThirdParty Supported Third Party Boards | ||||
|  * | ||||
|  *  Currently supported third-party boards (see \ref Group_BoardTypes for makefile \c BOARD constant names): | ||||
|  *   - Custom User Boards (with Board Drivers if desired, see \ref Page_WritingBoardDrivers) | ||||
|  */ | ||||
| 
 | ||||
| /** | ||||
|  *  \page Page_XMEGASupport Atmel USB XMEGA AVR (XMEGA) | ||||
|  * | ||||
|  *  \warning The XMEGA device support is currently <b>experimental</b> (incomplete and/or non-functional), and is included for preview purposes only. | ||||
|  * | ||||
|  *  \section Sec_XMEGASupport_Devices Supported Microcontroller Models | ||||
|  * | ||||
|  *  Currently supported XMEGA models: | ||||
|  * | ||||
|  *  <table> | ||||
|  *  <tr> | ||||
|  *   <th width="150px">Part</th> | ||||
|  *   <th width="150px">USB Device Mode</th> | ||||
|  *   <th width="150px">USB Host Mode</th> | ||||
|  *  </tr> | ||||
|  *  <tr> | ||||
|  *   <td>ATXMEGA16A4U</td> | ||||
|  *   <td bgcolor="#00EE00">Yes</td> | ||||
|  *   <td bgcolor="#EE0000">No</td> | ||||
|  *  </tr> | ||||
|  *  <tr> | ||||
|  *   <td>ATXMEGA32A4U</td> | ||||
|  *   <td bgcolor="#00EE00">Yes</td> | ||||
|  *   <td bgcolor="#EE0000">No</td> | ||||
|  *  </tr> | ||||
|  *  <tr> | ||||
|  *   <td>ATXMEGA64A4U</td> | ||||
|  *   <td bgcolor="#00EE00">Yes</td> | ||||
|  *   <td bgcolor="#EE0000">No</td> | ||||
|  *  </tr> | ||||
|  *  <tr> | ||||
|  *   <td>ATXMEGA128A4U</td> | ||||
|  *   <td bgcolor="#00EE00">Yes</td> | ||||
|  *   <td bgcolor="#EE0000">No</td> | ||||
|  *  </tr> | ||||
|  *  <tr> | ||||
|  *   <td>ATXMEGA64A3U</td> | ||||
|  *   <td bgcolor="#00EE00">Yes</td> | ||||
|  *   <td bgcolor="#EE0000">No</td> | ||||
|  *  </tr> | ||||
|  *  <tr> | ||||
|  *   <td>ATXMEGA128A3U</td> | ||||
|  *   <td bgcolor="#00EE00">Yes</td> | ||||
|  *   <td bgcolor="#EE0000">No</td> | ||||
|  *  </tr> | ||||
|  *  <tr> | ||||
|  *   <td>ATXMEGA192A3U</td> | ||||
|  *   <td bgcolor="#00EE00">Yes</td> | ||||
|  *   <td bgcolor="#EE0000">No</td> | ||||
|  *  </tr> | ||||
|  *  <tr> | ||||
|  *   <td>ATXMEGA256A3U</td> | ||||
|  *   <td bgcolor="#00EE00">Yes</td> | ||||
|  *   <td bgcolor="#EE0000">No</td> | ||||
|  *  </tr> | ||||
|  *  <tr> | ||||
|  *   <td>ATXMEGA256A3BU</td> | ||||
|  *   <td bgcolor="#00EE00">Yes</td> | ||||
|  *   <td bgcolor="#EE0000">No</td> | ||||
|  *  </tr> | ||||
|  *  <tr> | ||||
|  *   <td>ATXMEGA128A1U</td> | ||||
|  *   <td bgcolor="#00EE00">Yes</td> | ||||
|  *   <td bgcolor="#EE0000">No</td> | ||||
|  *  </tr> | ||||
|  *  <tr> | ||||
|  *   <td>ATXMEGA64B3</td> | ||||
|  *   <td bgcolor="#00EE00">Yes</td> | ||||
|  *   <td bgcolor="#EE0000">No</td> | ||||
|  *  </tr> | ||||
|  *  <tr> | ||||
|  *   <td>ATXMEGA128B3</td> | ||||
|  *   <td bgcolor="#00EE00">Yes</td> | ||||
|  *   <td bgcolor="#EE0000">No</td> | ||||
|  *  </tr> | ||||
|  *  <tr> | ||||
|  *   <td>ATXMEGA64B1</td> | ||||
|  *   <td bgcolor="#00EE00">Yes</td> | ||||
|  *   <td bgcolor="#EE0000">No</td> | ||||
|  *  </tr> | ||||
|  *  <tr> | ||||
|  *   <td>ATXMEGA128B1</td> | ||||
|  *   <td bgcolor="#00EE00">Yes</td> | ||||
|  *   <td bgcolor="#EE0000">No</td> | ||||
|  *  </tr> | ||||
|  *  <tr> | ||||
|  *   <td>ATXMEGA64C3</td> | ||||
|  *   <td bgcolor="#00EE00">Yes</td> | ||||
|  *   <td bgcolor="#EE0000">No</td> | ||||
|  *  </tr> | ||||
|  *  <tr> | ||||
|  *   <td>ATXMEGA128C3</td> | ||||
|  *   <td bgcolor="#00EE00">Yes</td> | ||||
|  *   <td bgcolor="#EE0000">No</td> | ||||
|  *  </tr> | ||||
|  *  <tr> | ||||
|  *   <td>ATXMEGA192C3</td> | ||||
|  *   <td bgcolor="#00EE00">Yes</td> | ||||
|  *   <td bgcolor="#EE0000">No</td> | ||||
|  *  </tr> | ||||
|  *  <tr> | ||||
|  *   <td>ATXMEGA256C3</td> | ||||
|  *   <td bgcolor="#00EE00">Yes</td> | ||||
|  *   <td bgcolor="#EE0000">No</td> | ||||
|  *  </tr> | ||||
|  *  <tr> | ||||
|  *   <td>ATXMEGA384C3</td> | ||||
|  *   <td bgcolor="#00EE00">Yes</td> | ||||
|  *   <td bgcolor="#EE0000">No</td> | ||||
|  *  </tr> | ||||
|  *  <tr> | ||||
|  *   <td>ATXMEGA16C4</td> | ||||
|  *   <td bgcolor="#00EE00">Yes</td> | ||||
|  *   <td bgcolor="#EE0000">No</td> | ||||
|  *  </tr> | ||||
|  *  <tr> | ||||
|  *   <td>ATXMEGA32C4</td> | ||||
|  *   <td bgcolor="#00EE00">Yes</td> | ||||
|  *   <td bgcolor="#EE0000">No</td> | ||||
|  *  </tr> | ||||
|  *  </table> | ||||
|  * | ||||
|  *  \section Sec_XMEGASupport_Boards Supported Atmel Boards | ||||
|  *  Currently supported Atmel XMEGA boards (see \ref Group_BoardTypes): | ||||
|  *   - XMEGA A3BU Xplained | ||||
|  *   - XMEGA B1 Xplained | ||||
|  *   - XMEGA C3 Xplained | ||||
|  * | ||||
|  *  \section Sec_XMEGASupport_ThirdParty Supported Third Party Boards | ||||
|  *  Currently supported third-party boards (see \ref Group_BoardTypes for makefile \c BOARD constant names): | ||||
|  *   - Custom User Boards (with Board Drivers if desired, see \ref Page_WritingBoardDrivers) | ||||
|  */ | ||||
| 
 | ||||
							
								
								
									
										80
									
								
								LUFA/DoxygenPages/DirectorySummaries.txt
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										80
									
								
								LUFA/DoxygenPages/DirectorySummaries.txt
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,80 @@ | |||
| /** \file | ||||
|  * | ||||
|  *  This file contains special DoxyGen information for the generation of the main page and other special | ||||
|  *  documentation pages. It is not a project source file. | ||||
|  */ | ||||
| 
 | ||||
| /** \dir Platform | ||||
|  *  \brief Platform specific drivers. | ||||
|  * | ||||
|  *  This folder contains platform specific drivers and defines for various supported architectures. These may or may | ||||
|  *  not be used in a LUFA application, and are provided for convenience purposes. | ||||
|  * | ||||
|  *  \dir Drivers | ||||
|  *  \brief Library hardware and software drivers. | ||||
|  * | ||||
|  *  This folder contains all the library hardware and software drivers for each supported board, architecture and | ||||
|  *  microcontroller model. | ||||
|  * | ||||
|  *  \dir Drivers/Misc | ||||
|  *  \brief Miscellaneous driver files. | ||||
|  * | ||||
|  *  This folder contains drivers for aspects other than the USB interface, board hardware or microcontroller peripherals. | ||||
|  * | ||||
|  *  \dir Drivers/Peripheral | ||||
|  *  \brief Microcontroller peripheral driver files. | ||||
|  * | ||||
|  *  This folder contains drivers for various low level microcontroller peripherals, usually located on the microcontroller | ||||
|  *  die within the same physical chip. | ||||
|  * | ||||
|  *  \dir Drivers/USB | ||||
|  *  \brief USB controller peripheral driver files. | ||||
|  * | ||||
|  *  This folder contains the complete LUFA USB stack and controller files, including the core driver and stack, as well | ||||
|  *  as the USB class driver implementations. | ||||
|  * | ||||
|  *  \dir Drivers/USB/Core | ||||
|  *  \brief Core USB driver files. | ||||
|  * | ||||
|  *  This folder contains the core USB stack and controller driver files, to correctly implement USB functionality on the | ||||
|  *  target architecture and microcontroller model. This | ||||
|  * | ||||
|  *  \dir Drivers/USB/Class | ||||
|  *  \brief USB Class helper driver files. | ||||
|  * | ||||
|  *  This folder contains drivers for implementing functionality of standardized USB classes. These are not used directly by the library, | ||||
|  *  but provide a standard and library-maintained way of implementing functionality from some of the defined USB classes without extensive | ||||
|  *  development effort. Is is recommended that these drivers be used where possible to reduce maintenance of user applications. | ||||
|  * | ||||
|  *  \dir Drivers/USB/Class/Device | ||||
|  *  \brief USB Device Class helper driver files. | ||||
|  * | ||||
|  *  Device mode drivers for the standard USB classes. | ||||
|  * | ||||
|  *  \dir Drivers/USB/Class/Host | ||||
|  *  \brief USB Host Class helper driver files. | ||||
|  * | ||||
|  *  Host mode drivers for the standard USB classes. | ||||
|  * | ||||
|  *  \dir Drivers/Board | ||||
|  *  \brief Board hardware driver files. | ||||
|  * | ||||
|  *  This folder contains drivers for interfacing with the physical hardware on supported commercial boards, primarily from | ||||
|  *  the Atmel corporation. Header files in this folder should be included in user applications requiring the functionality of | ||||
|  *  hardware placed on supported boards. | ||||
|  * | ||||
|  *  \dir CodeTemplates | ||||
|  *  \brief Code templates for use in LUFA powered applications. | ||||
|  * | ||||
|  *  This contains code templates for board drivers, sample LUFA project makefiles and other similar templates that can be copied into | ||||
|  *  a LUFA powered application and modified to speed up development. | ||||
|  * | ||||
|  *  \dir CodeTemplates/DriverStubs | ||||
|  *  \brief Driver stub header files for custom boards, to allow the LUFA board drivers to operate. | ||||
|  * | ||||
|  *  This contains stub files for the LUFA board drivers. If the LUFA board drivers are used with board hardware other than those | ||||
|  *  directly supported by the library, the BOARD parameter of the application's makefile can be set to "USER", and these stub files | ||||
|  *  copied to the "/Board/" directory of the application's folder. When fleshed out with working driver code for the custom board, | ||||
|  *  the corresponding LUFA board APIs will work correctly with the non-standard board hardware. | ||||
|  */ | ||||
| 
 | ||||
							
								
								
									
										25
									
								
								LUFA/DoxygenPages/Donating.txt
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										25
									
								
								LUFA/DoxygenPages/Donating.txt
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,25 @@ | |||
| /** \file | ||||
|  * | ||||
|  *  This file contains special DoxyGen information for the generation of the main page and other special | ||||
|  *  documentation pages. It is not a project source file. | ||||
|  */ | ||||
| 
 | ||||
| /** | ||||
|  *  \page Page_Donating Donating to Support This Project | ||||
|  * | ||||
|  *  \image html Images/Author.jpg "Dean Camera, LUFA Developer" | ||||
|  * | ||||
|  *  I am a software developer working on LUFA in my spare time. The development and support of this library requires | ||||
|  *  much effort from myself, as I am the sole developer, maintainer and supporter. Please consider donating a small | ||||
|  *  amount to support this and my future Open Source projects - All donations are <i>greatly</i> appreciated. | ||||
|  * | ||||
|  *  Note that commercial entities can remove the attribution portion of the LUFA license by a one-time fee - see | ||||
|  *  \ref Page_LicenseInfo for more details (<b>Note: Please do NOT pay this in advance through the donation link below - | ||||
|  *  contact author for payment details.</b>). | ||||
|  * | ||||
|  *  \htmlonly | ||||
|  *    \image html "http://www.pledgie.com/campaigns/6927.png" | ||||
|  *  \endhtmlonly | ||||
|  *  <a href="http://www.lufa-lib.org/donate">Donate to this project via PayPal</a> - Thanks in Advance! | ||||
|  */ | ||||
| 
 | ||||
							
								
								
									
										47
									
								
								LUFA/DoxygenPages/FutureChanges.txt
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										47
									
								
								LUFA/DoxygenPages/FutureChanges.txt
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,47 @@ | |||
| /** \file | ||||
|  * | ||||
|  *  This file contains special DoxyGen information for the generation of the main page and other special | ||||
|  *  documentation pages. It is not a project source file. | ||||
|  */ | ||||
| 
 | ||||
|  /** \page Page_FutureChanges Future Changes | ||||
|   * | ||||
|   *  Below is a list of future changes which are proposed for the LUFA library, but not yet started/complete. | ||||
|   *  This gives an unordered list of future changes which may be available in future releases of the library. | ||||
|   *  If you have an item to add to this list, please contact the library author via email, the LUFA mailing list, | ||||
|   *  or post your suggestion as an enhancement request to the project bug tracker. | ||||
|   * | ||||
|   *  <b>Targeted for Future Releases:</b> | ||||
|   *  - Code Features | ||||
|   *      -# Add hub support when in Host mode for multiple devices | ||||
|   *      -# Investigate virtual hubs when in device mode instead of composite devices | ||||
|   *      -# Re-add interrupt Pipe/Endpoint support | ||||
|   *      -# Update stream APIs to use DMA transfers on supported architectures | ||||
|   *      -# Pull out third party libraries into a separate folder and reference them as required | ||||
|   *      -# Add a LUFA_YIELD macro for integration into a third-party RTOS | ||||
|   *      -# Abstract out Mass Storage byte send/receive to prevent low level API use in projects | ||||
|   *      -# Fix HID report parser usage support for array types | ||||
|   *      -# Make HOST_DEVICE_SETTLE_DELAY_MS a global variable that can be changed | ||||
|   *      -# Add MANDATORY_EVENT_FUNCTIONS compile time option | ||||
|   *      -# Add watchdog support to the library and apps/bootloaders | ||||
|   *      -# Limit the maximum size of control transfers | ||||
|   *  - Testing/Verification | ||||
|   *      -# Re-run USBIF test suite on all classes to formally verify operation | ||||
|   *      -# Implement automated functional testing of all demos | ||||
|   *  - Documentation/Support | ||||
|   *      -# Add detailed overviews of how each demo works | ||||
|   *      -# Add board overviews | ||||
|   *      -# Write LUFA tutorials | ||||
|   *  - Demos/Projects | ||||
|   *      -# Add class driver support for Test and Measurement class | ||||
|   *      -# Add class driver support for EEM class | ||||
|   *      -# Add class driver support for ECM class | ||||
|   *      -# Add class driver generic HID report host demo | ||||
|   *      -# Implement flow control for USB to Serial project | ||||
|   *  - Ports | ||||
|   *      -# Port all demos to multiple architectures | ||||
|   *      -# Finish USB XMEGA port | ||||
|   *      -# Add AVR32 UC3C, UC3D and UC3L support | ||||
|   *      -# Other (commercial) C compilers | ||||
|   */ | ||||
| 
 | ||||
							
								
								
									
										37
									
								
								LUFA/DoxygenPages/GettingStarted.txt
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										37
									
								
								LUFA/DoxygenPages/GettingStarted.txt
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,37 @@ | |||
| /** \file | ||||
|  * | ||||
|  *  This file contains special DoxyGen information for the generation of the main page and other special | ||||
|  *  documentation pages. It is not a project source file. | ||||
|  */ | ||||
| 
 | ||||
| /** \page Page_GettingStarted Getting Started | ||||
|  * | ||||
|  *  Getting started with LUFA is easy; read the content below to get on your way to your first LUFA powered application. | ||||
|  * | ||||
|  *  \section Sec_DemosOverview The LUFA Demo Applications | ||||
|  * | ||||
|  *  Out of the box, LUFA contains a large number of pre-made class demos for you to test, experiment with and | ||||
|  *  ultimately build upon for your own projects. All the demos (where possible) come pre-configured to build and | ||||
|  *  run correctly on the AT90USB1287 AVR microcontroller, mounted on the Atmel USBKEY board and running at an 8MHz | ||||
|  *  master clock. This is due to two reasons; one, it is the hardware the author possesses, and two, it is the most | ||||
|  *  popular Atmel USB demonstration board to date. To learn how to reconfigure, recompile and program the included | ||||
|  *  LUFA applications using different settings, see the subsections below. | ||||
|  * | ||||
|  *  \section Sec_ClassOrLowLevel Class Driver and Low Level Demos | ||||
|  * | ||||
|  *  Most of the included demos in the /Demos/ folder come in both ClassDriver and LowLevel varieties. If you are new | ||||
|  *  to LUFA, it is highly recommended that you look at the ClassDriver versions first, which use the pre-made USB | ||||
|  *  Class Drivers (\ref Group_USBClassDrivers) to simplify the use of the standard USB classes in user applications. | ||||
|  *  These demos give a basic but easy to use interface to the USB class used in the demo application, such as HID or | ||||
|  *  CDC. | ||||
|  * | ||||
|  *  Those needing absolute control over the class implementation can look at the LowLevel demos, which implement the | ||||
|  *  required USB class directly in the demo application using the lowest level LUFA APIs. | ||||
|  * | ||||
|  * | ||||
|  *  <b>Subsections:</b> | ||||
|  *  \li \subpage Page_ConfiguringApps - How to Configure the Included Demos, Projects and Bootloaders | ||||
|  *  \li \subpage Page_CompilingApps - How to Compile the Included Demos, Projects and Bootloaders | ||||
|  *  \li \subpage Page_ProgrammingApps - How to Program an AVR with the Included Demos, Projects and Bootloaders | ||||
|  */ | ||||
| 
 | ||||
							
								
								
									
										38
									
								
								LUFA/DoxygenPages/Groups.txt
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										38
									
								
								LUFA/DoxygenPages/Groups.txt
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,38 @@ | |||
| /** \file | ||||
|  * | ||||
|  *  This file contains special DoxyGen information for the generation of the main page and other special | ||||
|  *  documentation pages. It is not a project source file. | ||||
|  */ | ||||
| 
 | ||||
| /** \defgroup Group_BoardDrivers Board Drivers | ||||
|  * | ||||
|  *  \brief Functions, macros, variables, enums and types related to the control of physical board hardware. | ||||
|  */ | ||||
| 
 | ||||
| /** \defgroup Group_PeripheralDrivers On-chip Peripheral Drivers | ||||
|  * | ||||
|  *  \brief Functions, macros, variables, enums and types related to the control of AVR subsystems. | ||||
|  */ | ||||
| 
 | ||||
| /** \defgroup Group_MiscDrivers Miscellaneous Drivers | ||||
|  * | ||||
|  *  \brief Miscellaneous driver Functions, macros, variables, enums and types. | ||||
|  */ | ||||
| 
 | ||||
| /** \defgroup Group_PlatformDrivers_AVR8 AVR8 | ||||
|  *  \ingroup Group_PlatformDrivers | ||||
|  * | ||||
|  *  \brief Drivers relating to the AVR8 architecture platform, such as clock setup and interrupt management. | ||||
|  */ | ||||
| 
 | ||||
| /** \defgroup Group_PlatformDrivers_XMEGA XMEGA | ||||
|  *  \ingroup Group_PlatformDrivers | ||||
|  * | ||||
|  *  \brief Drivers relating to the XMEGA architecture platform, such as clock setup and interrupt management. | ||||
|  */ | ||||
| 
 | ||||
| /** \defgroup Group_PlatformDrivers_UC3 UC3 | ||||
|  *  \ingroup Group_PlatformDrivers | ||||
|  * | ||||
|  *  \brief Drivers relating to the UC3 architecture platform, such as clock setup and interrupt management. | ||||
|  */ | ||||
							
								
								
									
										
											BIN
										
									
								
								LUFA/DoxygenPages/Images/Author.jpg
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								LUFA/DoxygenPages/Images/Author.jpg
									
										
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							| After Width: | Height: | Size: 28 KiB | 
							
								
								
									
										
											BIN
										
									
								
								LUFA/DoxygenPages/Images/LUFA.png
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								LUFA/DoxygenPages/Images/LUFA.png
									
										
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							| After Width: | Height: | Size: 10 KiB | 
							
								
								
									
										
											BIN
										
									
								
								LUFA/DoxygenPages/Images/LUFA_thumb.png
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								LUFA/DoxygenPages/Images/LUFA_thumb.png
									
										
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							| After Width: | Height: | Size: 3.6 KiB | 
							
								
								
									
										234
									
								
								LUFA/DoxygenPages/KnownIssues.txt
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										234
									
								
								LUFA/DoxygenPages/KnownIssues.txt
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,234 @@ | |||
| /** \file | ||||
|  * | ||||
|  *  This file contains special DoxyGen information for the generation of the main page and other special | ||||
|  *  documentation pages. It is not a project source file. | ||||
|  */ | ||||
| 
 | ||||
|  /** \page Page_KnownIssues Known Issues | ||||
|   *  The following are known issues present in each official LUFA release. This list should contain all known | ||||
|   *  issues in the library. Most of these issues should be corrected in the future release - see | ||||
|   *  \ref Page_FutureChanges for a list of planned changes in future releases. | ||||
|   * | ||||
|   *  \section Sec_KnownIssues170418 Version 170418 | ||||
|   *  - AVR8 Architecture | ||||
|   *    - No known issues. | ||||
|   *  - UC3 Architecture | ||||
|   *    \warning The UC3 device support is currently <b>experimental</b> (incomplete and/or non-functional), and is included for preview purposes only. \n | ||||
|   * | ||||
|   *    - No demos, bootloaders or projects have been ported for the UC3 devices in the current release, | ||||
|   *      although the architecture is supported in the LUFA core library. | ||||
|   *    - DMA transfers to and from the USB controller are not yet implemented for this release. | ||||
|   *    - The UC3C, UC3D and UC3L sub-families of UC3 are not currently supported by the library due to their | ||||
|   *      altered USB controller design. | ||||
|   *    - The various \c *_CreateStream() functions for creating standard \c <stdio.h> compatible virtual file | ||||
|   *      streams are not available on the UC3 architecture, due to a lack of suitable library support. | ||||
|   *  - XMEGA Architecture | ||||
|   *    \warning The XMEGA device support is currently <b>experimental</b> (incomplete and/or non-functional), and is included for preview purposes only. | ||||
|   * | ||||
|   *    - Endpoints of more than 64 bytes are not currently supported in this release. | ||||
|   *    - Isochronous endpoints are not currently supported in this release. As a result, the audio class | ||||
|   *      cannot be used on XMEGA devices. | ||||
|   *    - Multiple-bank endpoints are not currently supported in this release. | ||||
|   *    - Early silicon revisions of the ATXMEGA128A1U are incompatible with LUFA, due to their various errata | ||||
|   *      relating to the USB controller. | ||||
|   *  - Architecture Independent | ||||
|   *    - The LUFA library is not watchdog aware, and thus timeouts are possible if short periods are used | ||||
|   *      and a lengthy USB operation is initiated. | ||||
|   *    - No LUFA provided driver INF files for Windows are signed, and thus may fail to install on systems where driver signing is enforced (e.g. Windows 8/10). | ||||
|   *  - Build System | ||||
|   *    - No known issues. | ||||
|   *  - Atmel Studio Integration | ||||
|   *    - Not all devices are listed in the "Supported Parts" screen when selecting a device. To select an alternative device, change the "Show Device" drop-down to "All Parts". | ||||
|   *    - When switching boards after changing the device selection, a second conflicting \c BOARD symbol definition can be created that prevents successful compilation. To fix, open the project properties window (<i>Project->Project {name} Properties...</i> menu item), click the "Toolchain" tab, click "Symbols" under the "AVR/GNU C Compiler" section and remove the incorrect definition. | ||||
|   * | ||||
|   *  \section Sec_KnownIssues151115 Version 151115 | ||||
|   *  - AVR8 Architecture | ||||
|   *    - No known issues. | ||||
|   *  - UC3 Architecture | ||||
|   *    \warning The UC3 device support is currently <b>experimental</b> (incomplete and/or non-functional), and is included for preview purposes only. \n | ||||
|   * | ||||
|   *    - No demos, bootloaders or projects have been ported for the UC3 devices in the current release, | ||||
|   *      although the architecture is supported in the LUFA core library. | ||||
|   *    - DMA transfers to and from the USB controller are not yet implemented for this release. | ||||
|   *    - The UC3C, UC3D and UC3L sub-families of UC3 are not currently supported by the library due to their | ||||
|   *      altered USB controller design. | ||||
|   *    - The various \c *_CreateStream() functions for creating standard \c <stdio.h> compatible virtual file | ||||
|   *      streams are not available on the UC3 architecture, due to a lack of suitable library support. | ||||
|   *  - XMEGA Architecture | ||||
|   *    \warning The XMEGA device support is currently <b>experimental</b> (incomplete and/or non-functional), and is included for preview purposes only. | ||||
|   * | ||||
|   *    - Endpoints of more than 64 bytes are not currently supported in this release. | ||||
|   *    - Isochronous endpoints are not currently supported in this release. As a result, the audio class | ||||
|   *      cannot be used on XMEGA devices. | ||||
|   *    - Multiple-bank endpoints are not currently supported in this release. | ||||
|   *    - Early silicon revisions of the ATXMEGA128A1U are incompatible with LUFA, due to their various errata | ||||
|   *      relating to the USB controller. | ||||
|   *  - Architecture Independent | ||||
|   *    - The LUFA library is not watchdog aware, and thus timeouts are possible if short periods are used | ||||
|   *      and a lengthy USB operation is initiated. | ||||
|   *    - No LUFA provided driver INF files for Windows are signed, and thus may fail to install on systems where driver signing is enforced (e.g. Windows 8). | ||||
|   *  - Build System | ||||
|   *    - No known issues. | ||||
|   *  - Atmel Studio Integration | ||||
|   *    - Not all devices are listed in the "Supported Parts" screen when selecting a device. To select an alternative device, change the "Show Device" drop-down to "All Parts". | ||||
|   *    - When switching boards after changing the device selection, a second conflicting \c BOARD symbol definition can be created that prevents successful compilation. To fix, open the project properties window (<i>Project->Project {name} Properties...</i> menu item), click the "Toolchain" tab, click "Symbols" under the "AVR/GNU C Compiler" section and remove the incorrect definition. | ||||
|   * | ||||
|   *  \section Sec_KnownIssues140928 Version 140928 | ||||
|   *  - AVR8 Architecture | ||||
|   *    - No known issues. | ||||
|   *  - UC3 Architecture | ||||
|   *    \warning The UC3 device support is currently <b>experimental</b> (incomplete and/or non-functional), and is included for preview purposes only. \n | ||||
|   * | ||||
|   *    - No demos, bootloaders or projects have been ported for the UC3 devices in the current release, | ||||
|   *      although the architecture is supported in the LUFA core library. | ||||
|   *    - DMA transfers to and from the USB controller are not yet implemented for this release. | ||||
|   *    - The UC3C, UC3D and UC3L sub-families of UC3 are not currently supported by the library due to their | ||||
|   *      altered USB controller design. | ||||
|   *    - The various \c *_CreateStream() functions for creating standard \c <stdio.h> compatible virtual file | ||||
|   *      streams are not available on the UC3 architecture, due to a lack of suitable library support. | ||||
|   *  - XMEGA Architecture | ||||
|   *    \warning The XMEGA device support is currently <b>experimental</b> (incomplete and/or non-functional), and is included for preview purposes only. | ||||
|   * | ||||
|   *    - Endpoints of more than 64 bytes are not currently supported in this release. | ||||
|   *    - Isochronous endpoints are not currently supported in this release. As a result, the audio class | ||||
|   *      cannot be used on XMEGA devices. | ||||
|   *    - Multiple-bank endpoints are not currently supported in this release. | ||||
|   *    - Early silicon revisions of the ATXMEGA128A1U are incompatible with LUFA, due to their various errata | ||||
|   *      relating to the USB controller. | ||||
|   *  - Architecture Independent | ||||
|   *    - The LUFA library is not watchdog aware, and thus timeouts are possible if short periods are used | ||||
|   *      and a lengthy USB operation is initiated. | ||||
|   *    - No LUFA provided driver INF files for Windows are signed, and thus may fail to install on systems where driver signing is enforced (e.g. Windows 8). | ||||
|   *  - Build System | ||||
|   *    - No known issues. | ||||
|   *  - Atmel Studio Integration | ||||
|   *    - Not all devices are listed in the "Supported Parts" screen when selecting a device. To select an alternative device, change the "Show Device" drop-down to "All Parts". | ||||
|   *    - When switching boards after changing the device selection, a second conflicting \c BOARD symbol definition can be created that prevents successful compilation. To fix, open the project properties window (<i>Project->Project {name} Properties...</i> menu item), click the "Toolchain" tab, click "Symbols" under the "AVR/GNU C Compiler" section and remove the incorrect definition. | ||||
|   * | ||||
|   *  \section Sec_KnownIssues140302 Version 140302 | ||||
|   *  - AVR8 Architecture | ||||
|   *    - No known issues. | ||||
|   *  - UC3 Architecture | ||||
|   *    \warning The UC3 device support is currently <b>experimental</b> (incomplete and/or non-functional), and is included for preview purposes only. \n | ||||
|   * | ||||
|   *    - No demos, bootloaders or projects have been ported for the UC3 devices in the current release, | ||||
|   *      although the architecture is supported in the LUFA core library. | ||||
|   *    - DMA transfers to and from the USB controller are not yet implemented for this release. | ||||
|   *    - The UC3C, UC3D and UC3L sub-families of UC3 are not currently supported by the library due to their | ||||
|   *      altered USB controller design. | ||||
|   *    - The various \c *_CreateStream() functions for creating standard \c <stdio.h> compatible virtual file | ||||
|   *      streams are not available on the UC3 architecture, due to a lack of suitable library support. | ||||
|   *  - XMEGA Architecture | ||||
|   *    \warning The XMEGA device support is currently <b>experimental</b> (incomplete and/or non-functional), and is included for preview purposes only. | ||||
|   * | ||||
|   *    - Endpoints of more than 64 bytes are not currently supported in this release. | ||||
|   *    - Isochronous endpoints are not currently supported in this release. As a result, the audio class | ||||
|   *      cannot be used on XMEGA devices. | ||||
|   *    - Multiple-bank endpoints are not currently supported in this release. | ||||
|   *    - Early silicon revisions of the ATXMEGA128A1U are incompatible with LUFA, due to their various errata | ||||
|   *      relating to the USB controller. | ||||
|   *  - Architecture Independent | ||||
|   *    - The LUFA library is not watchdog aware, and thus timeouts are possible if short periods are used | ||||
|   *      and a lengthy USB operation is initiated. | ||||
|   *    - No LUFA provided driver INF files for Windows are signed, and thus may fail to install on systems where driver signing is enforced (e.g. Windows 8). | ||||
|   *  - Build System | ||||
|   *    - No known issues. | ||||
|   *  - Atmel Studio Integration | ||||
|   *    - Not all devices are listed in the "Supported Parts" screen when selecting a device. To select an alternative device, change the "Show Device" drop-down to "All Parts". | ||||
|   *    - When switching boards after changing the device selection, a second conflicting BOARD symbol definition can be created that prevents successful compilation. To fix, open the project properties window (<i>Project->Project {name} Properties...</i> menu item), click the Toolchain tab, click "Symbols" under the "AVR/GNU C Compiler" section and remove the incorrect definition. | ||||
|   * | ||||
|   *  \section Sec_KnownIssues130901 Version 130901 | ||||
|   *  - AVR8 Architecture | ||||
|   *    - No known issues. | ||||
|   *  - UC3 Architecture | ||||
|   *    \warning The UC3 device support is currently <b>experimental</b> (incomplete and/or non-functional), and is included for preview purposes only. \n | ||||
|   * | ||||
|   *    - No demos, bootloaders or projects have been ported for the UC3 devices in the current release, | ||||
|   *      although the architecture is supported in the LUFA core library. | ||||
|   *    - DMA transfers to and from the USB controller are not yet implemented for this release. | ||||
|   *    - The UC3C, UC3D and UC3L sub-families of UC3 are not currently supported by the library due to their | ||||
|   *      altered USB controller design. | ||||
|   *    - The various \c *_CreateStream() functions for creating standard \c <stdio.h> compatible virtual file | ||||
|   *      streams are not available on the UC3 architecture, due to a lack of suitable library support. | ||||
|   *  - XMEGA Architecture | ||||
|   *    \warning The XMEGA device support is currently <b>experimental</b> (incomplete and/or non-functional), and is included for preview purposes only. | ||||
|   * | ||||
|   *    - Endpoints of more than 64 bytes are not currently supported in this release. | ||||
|   *    - Isochronous endpoints are not currently supported in this release. As a result, the audio class | ||||
|   *      cannot be used on XMEGA devices. | ||||
|   *    - Multiple-bank endpoints are not currently supported in this release. | ||||
|   *    - Early silicon revisions of the ATXMEGA128A1U are incompatible with LUFA, due to their various errata | ||||
|   *      relating to the USB controller. | ||||
|   *  - Architecture Independent | ||||
|   *    - The LUFA library is not watchdog aware, and thus timeouts are possible if short periods are used | ||||
|   *      and a lengthy USB operation is initiated. | ||||
|   *    - No LUFA provided driver INF files for Windows are signed, and thus may fail to install on systems where driver signing is enforced (e.g. Windows 8). | ||||
|   *  - Build System | ||||
|   *    - No known issues. | ||||
|   *  - Atmel Studio Integration | ||||
|   *    - Not all devices are listed in the "Supported Parts" screen when selecting a device. To select an alternative device, change the "Show Device" drop-down to "All Parts". | ||||
|   *    - When switching boards after changing the device selection, a second conflicting BOARD symbol definition can be created that prevents successful compilation. To fix, open the project properties window (<i>Project->Project {name} Properties...</i> menu item), click the Toolchain tab, click "Symbols" under the "AVR/GNU C Compiler" section and remove the incorrect definition. | ||||
|   * | ||||
|   *  \section Sec_KnownIssues130303 Version 130303 | ||||
|   *  - AVR8 Architecture | ||||
|   *    - No known issues. | ||||
|   *  - UC3 Architecture | ||||
|   *    \warning The UC3 device support is currently <b>experimental</b> (incomplete and/or non-functional), and is included for preview purposes only. \n | ||||
|   * | ||||
|   *    - No demos, bootloaders or projects have been ported for the UC3 devices in the current release, | ||||
|   *      although the architecture is supported in the LUFA core library. | ||||
|   *    - DMA transfers to and from the USB controller are not yet implemented for this release. | ||||
|   *    - The UC3C, UC3D and UC3L sub-families of UC3 are not currently supported by the library due to their | ||||
|   *      altered USB controller design. | ||||
|   *    - The various \c CreateStream() functions for creating standard \c <stdio.h> compatible virtual file | ||||
|   *      streams are not available on the UC3 architecture, due to a lack of suitable library support. | ||||
|   *  - XMEGA Architecture | ||||
|   *    \warning The XMEGA device support is currently <b>experimental</b> (incomplete and/or non-functional), and is included for preview purposes only. | ||||
|   * | ||||
|   *    - No demos, bootloaders or projects have been ported for the XMEGA devices in the current release, | ||||
|   *      although the architecture is supported in the LUFA core library. | ||||
|   *    - Endpoints of more than 64 bytes are not currently supported in this release. | ||||
|   *    - Isochronous endpoints are not currently supported in this release. As a result, the audio class | ||||
|   *      cannot be used on XMEGA devices. | ||||
|   *    - Multiple-bank endpoints are not currently supported in this release. | ||||
|   *    - Early revisions of the ATXMEGA128A1U are incompatible with LUFA, due to their various errata | ||||
|   *      relating to the USB controller. | ||||
|   *  - Architecture Independent | ||||
|   *    - The LUFA library is not watchdog aware, and thus timeouts are possible if short periods are used | ||||
|   *      and a lengthy USB operation is initiated. | ||||
|   *    - No LUFA provided driver INF files for Windows are signed, and thus may fail to install on systems where driver signing is enforced (e.g. Windows 8). | ||||
|   *  - Build System | ||||
|   *    - No known issues. | ||||
|   * | ||||
|   *  \section Sec_KnownIssues120730 Version 120730 | ||||
|   *  - AVR8 Architecture | ||||
|   *    - No known issues. | ||||
|   *  - UC3 Architecture | ||||
|   *    \warning The UC3 device support is currently <b>experimental</b> (incomplete and/or non-functional), and is included for preview purposes only. \n | ||||
|   * | ||||
|   *    - No demos, bootloaders or projects have been ported for the UC3 devices in the current release, | ||||
|   *      although the architecture is supported in the LUFA core library. | ||||
|   *    - DMA transfers to and from the USB controller are not yet implemented for this release. | ||||
|   *    - The UC3C, UC3D and UC3L sub-families of UC3 are not currently supported by the library due to their | ||||
|   *      altered USB controller design. | ||||
|   *    - The various \c CreateStream() functions for creating standard \c <stdio.h> compatible virtual file | ||||
|   *      streams are not available on the UC3 architecture, due to a lack of suitable library support. | ||||
|   *  - XMEGA Architecture | ||||
|   *    \warning The XMEGA device support is currently <b>experimental</b> (incomplete and/or non-functional), and is included for preview purposes only. | ||||
|   * | ||||
|   *    - No demos, bootloaders or projects have been ported for the XMEGA devices in the current release, | ||||
|   *      although the architecture is supported in the LUFA core library. | ||||
|   *    - Endpoints of more than 64 bytes are not currently supported in this release. | ||||
|   *    - Isochronous endpoints are not currently supported in this release. As a result, the audio class | ||||
|   *      cannot be used on XMEGA devices. | ||||
|   *    - Multiple-bank endpoints are not currently supported in this release. | ||||
|   *    - Early revisions of the ATXMEGA128A1U are incompatible with LUFA, due to their various errata | ||||
|   *      relating to the USB controller. | ||||
|   *  - Architecture Independent | ||||
|   *    - The LUFA library is not watchdog aware, and thus timeouts are possible if short periods are used | ||||
|   *      and a lengthy USB operation is initiated. | ||||
|   *    - No LUFA provided driver INF files for Windows are signed, and thus may fail to install on systems where driver signing is enforced (e.g. Windows 8). | ||||
|   *  - Build System | ||||
|   *    - No known issues. | ||||
|   */ | ||||
| 
 | ||||
							
								
								
									
										226
									
								
								LUFA/DoxygenPages/LUFAPoweredProjects.txt
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										226
									
								
								LUFA/DoxygenPages/LUFAPoweredProjects.txt
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,226 @@ | |||
| /** \file | ||||
|  * | ||||
|  *  This file contains special DoxyGen information for the generation of the main page and other special | ||||
|  *  documentation pages. It is not a project source file. | ||||
|  */ | ||||
| 
 | ||||
| /** \page Page_LUFAPoweredProjects User Projects Powered by LUFA | ||||
|  * | ||||
|  *  LUFA is currently in use all around the world, in many applications both commercial and non-commercial. Below is a | ||||
|  *  list of known public LUFA powered projects, which all use the LUFA library in some way. Feel free to visit each project's | ||||
|  *  home page for more information on each project. | ||||
|  * | ||||
|  *  If you have a project that you would like to add to this list, please contact me via the details on the main page of this | ||||
|  *  documentation. | ||||
|  * | ||||
|  *  \section Sec_BoardsUsingLUFA AVR-USB Development Boards Using LUFA | ||||
|  * | ||||
|  *  The following is a list of known AVR USB development boards, which recommend using LUFA for the USB stack. Some of these | ||||
|  *  are open design, and all are available for purchase as completed development boards suitable for project development. | ||||
|  * | ||||
|  *  \li AVR-USB-162, a USBKEY-like development board for the AT90USB162: http://olimex.com/dev/avr-usb-162.html | ||||
|  *  \li Benito #7, a no-frills USB board: http://www.dorkbotpdx.org/wiki/benito | ||||
|  *  \li Duce, the successor to the Benito #7: http://dorkbotpdx.org/wiki/duce | ||||
|  *  \li JM-DB-U2, an ATMEGA32U2 development board: http://u2.mattair.net/index.html | ||||
|  *  \li Micropendous, an open design/source set of AVR USB development boards: http://micropendous.org/ | ||||
|  *  \li Microsin AVR-USB162 breakout board, a DIY AT90USB162 development board: http://microsin.ru/content/view/685/44/ | ||||
|  *  \li Minimus USB, a board specially designed for PSGroove: http://www.minimususb.com/ | ||||
|  *  \li Nanduino, a do-it-yourself AT90USB162 board: http://www.makestuff.eu/wordpress/?page_id=569 | ||||
|  *  \li Sparkfun ATMEGA8U2 breakout board: http://www.sparkfun.com/products/10277 | ||||
|  *  \li Teensy and Teensy++, two other AVR USB development boards: http://www.pjrc.com/teensy/index.html | ||||
|  *  \li U2DIL/U4DIL, a set of DIP layout USB AVR boards: http://www.reworld.eu/re/en/products/u2dil/ | ||||
|  *  \li USB2AX, a tiny USB to serial converter board: http://paranoidstudio.assembla.com/wiki/show/paranoidstudio/USB2AX | ||||
|  *  \li USBFOO 2, AT90USB162 based development board: http://shop.kernelconcepts.de/product_info.php?products_id=102 | ||||
|  * | ||||
|  *  \section Sec_LUFAProjects Projects Using LUFA (Hobbyist) | ||||
|  * | ||||
|  *  The following are known hobbyist projects using LUFA. Most are open source, and show off interesting ways that the LUFA library | ||||
|  *  can be incorporated into many different applications. | ||||
|  * | ||||
|  *  \li Accelerometer Game Joystick: http://www.crictor.co.il/he/episodes/joystick/ | ||||
|  *  \li Adjacent Reality Motion Tracker: http://www.adjacentreality.org/ | ||||
|  *  \li AD9833 based USB Function Generator: http://tuomasnylund.fi/drupal6/content/ad9833-based-usb-function-generator | ||||
|  *  \li AERY development platform for the AVR32 devices: http://www.aery32.com/ | ||||
|  *  \li AM Radio transmitter: http://amcinnes.info/2012/uc_am_xmit/ | ||||
|  *  \li Arcade Controller: http://fletchtronics.net/arcade-controller-made-petunia | ||||
|  *  \li Arcade Joystick: http://jamie.lentin.co.uk/embedded/arcade-joystick/ | ||||
|  *  \li AttoBasic AVR BASIC interpreter: http://cappels.org/dproj/AttoBasic_Home/AttoBasic_Home.html | ||||
|  *  \li AVR USB Modem, a 3G Wireless Modem host: http://code.google.com/p/avrusbmodem/ | ||||
|  *  \li Bicycle POV: http://www.code.google.com/p/bicycleledpov/ | ||||
|  *  \li Bluetooth Explorerbot: http://code.google.com/p/bluetooth-explorerbot/ | ||||
|  *  \li Bus Ninja, an AVR clone of the popular BusPirate project: http://blog.hodgepig.org/busninja/ | ||||
|  *  \li CAMTRIG, a remote Camera Trigger device: http://code.astraw.com/projects/motmot/camtrig | ||||
|  *  \li ChameleonMini, a smart card emulator: https://github.com/skuep/ChameleonMini | ||||
|  *  \li CD Driver Emulator Dongle for ISO Files: http://cdemu.blogspot.com/ | ||||
|  *  \li ChipWhisperer, a signal capture device: https://www.assembla.com/spaces/chipwhisperer/wiki/ChipWhisperer_Rev2_Capture_Hardware | ||||
|  *  \li ClockTamer, a configurable clock generator: http://code.google.com/p/clock-tamer/ | ||||
|  *  \li Collection of alternative Arduino Uno firmwares: http://hunt.net.nz/users/darran/ | ||||
|  *  \li Computer controlled LED matrix (Russian): http://we.easyelectronics.ru/AVR/nebolshoy-primer-s-lufa-hidapi.html | ||||
|  *  \li CULFW, a 868MHz RF packet encoder/decoder: http://www.koeniglich.de/culfw/culfw.html | ||||
|  *  \li Dashkey, a custom PC keyboard controller: http://geekhack.org/showwiki.php?title=Island:19096 | ||||
|  *  \li DIY PS3 controller emulator: https://code.google.com/p/diyps3controller/ | ||||
|  *  \li EMuSer, a USB-RS422 adapter for E-Mu samplers: http://www.emxp.net/EMuSer.htm | ||||
|  *  \li EQ Track, a telescope mount controller: http://sourceforge.net/projects/eqtrack/ | ||||
|  *  \li Estick JTAG, an ARM JTAG debugger: http://code.google.com/p/estick-jtag/ | ||||
|  *  \li "Fingerlicking Wingdinger" (WARNING: Bad language if no Javascript), a MIDI controller: http://noisybox.net/electronics/wingdinger/ | ||||
|  *  \li Flyatar, a real-time fly tracking system: https://github.com/peterpolidoro/Flyatar | ||||
|  *  \li FootJoy, a 22 button, 6-axis josystick with keyboard and mouse modes: https://bitbucket.org/sirbrialliance/foot-joy/ | ||||
|  *  \li Gamecube controller to USB adapter: https://www.facebook.com/media/set/?set=a.10150202447076304.310536.688776303&l=df53851c50 | ||||
|  *  \li Garmin GPS USB to NMEA standard serial sentence translator: http://github.com/nall/garmin-transmogrifier/tree/master | ||||
|  *  \li Geiger Counter with USB interface: http://www.hforsten.com/i-made-a-geiger-counter.html | ||||
|  *  \li Generic HID Device Creator: http://generichid.sourceforge.net/ | ||||
|  *  \li Generic HID Open Source Framework: http://www.waitingforfriday.com/index.php/USB_Generic_HID_Open_Source_Framework_for_Atmel_AVR_and_Windows | ||||
|  *  \li Ghetto Drum, a MIDI drum controller: http://noisybox.net/art/gdrum/ | ||||
|  *  \li GPS enabled lap timer for vehicles: http://www.assembla.com/code/ironlung/subversion/nodes/trunk/LapTimer | ||||
|  *  \li GSynth, an 8-bit sound synthesizer: https://github.com/gcielniak/GSynth | ||||
|  *  \li Gumbi, a Python library and USB GPIO controller: https://code.google.com/p/gumbi/ | ||||
|  *  \li Hardware Volume Control: https://github.com/davidk/hw-volume-control | ||||
|  *  \li Hiduino, a USB-MIDI replacement firmware for the Arduino Uno: http://code.google.com/p/hiduino/ | ||||
|  *  \li HoodLoader2, an Arduino Uno enhanced USB AVR coprocessor firmware: https://github.com/NicoHood/HoodLoader2 | ||||
|  *  \li IBM capacitive keybord replacement controller: http://downloads.cornall.co/ibm-capsense-usb-web/ibm-capsense-usb.html | ||||
|  *  \li Ikea RGB LED USB modification: http://slashhome.se/p/projects/id/ikea_dioder_usb/#project | ||||
|  *  \li IR electricity meter monitor: http://sourceforge.net/projects/irmetermon/ | ||||
|  *  \li IR Remote to Keyboard decoder: http://netzhansa.blogspot.com/2010/04/our-living-room-hi-fi-setup-needs-mp3.html | ||||
|  *  \li Jukebox panic button: http://thinkl33t.co.uk/the-panic-button | ||||
|  *  \li Kinesis replacement firmware: https://github.com/chrisandreae/kinesis-firmware | ||||
|  *  \li LED Panel controller: http://projects.peterpolidoro.net/caltech/panelscontroller/panelscontroller.htm | ||||
|  *  \li Linux Secure Storage Dongle: http://github.com/TomMD/teensy | ||||
|  *  \li LUFA powered DDR dance mat (French): http://logicien-parfait.fr/dokuwiki/doku.php?id=projet:ddr_repair | ||||
|  *  \li Macintosh SIMM ROM Programmer: https://code.google.com/p/mac-rom-simm-programmer/ | ||||
|  *  \li MakeTV Episode Dispenser: http://www.youtube.com/watch?v=BkWUi18hl3g | ||||
|  *  \li Mec64,a Commodore 64 keyboard: http://deskthority.net/workshop-f7/mec64-keyboard-t4522.html | ||||
|  *  \li MidiMonster, a USB-to-MIDI gateway board: http://www.dorkbotpdx.org/wiki/midimonster | ||||
|  *  \li MIDI Theremin: http://baldwisdom.com/usb-midi-controller-theremin-style-on-arduino-uno/ | ||||
|  *  \li MIDI interface hack of a toy Guitar: http://blog.x37v.info/2011/06/26/toy-guitar-hacked-midi-conroller | ||||
|  *  \li MiniBloq, a graphical Ardunio programming environment : http://minibloq.org/ | ||||
|  *  \li MiXley, a port of the Teacup 3D printer firmware for the USB AVRs: http://codaset.com/michielh/mixley | ||||
|  *  \li Mobo 4.3, a USB controlled all band (160-10m) HF SDR transceiver: http://sites.google.com/site/lofturj/mobo4_3 | ||||
|  *  \li Moco, a native Arduino Uno MIDI replacement firmware: http://web.mac.com/kuwatay/morecat_lab./MocoLUFA.html | ||||
|  *  \li Monash ECSE Smart Packet Radio Testbed: http://www.ecse.monash.edu.au/twiki/bin/view/WSRNLab/SmartPacketRadio | ||||
|  *  \li Motherboard BIOS flasher: http://www.coreboot.org/InSystemFlasher | ||||
|  *  \li Multi-button Joystick (French): http://logicien-parfait.fr/dokuwiki/doku.php?id=projet:joystick | ||||
|  *  \li Music Playing Alarm Clock (Tutorial): http://www.instructables.com/id/Music-Playing-Alarm-Clock/ | ||||
|  *  \li Nehebkau, Laptop Controlled Keyboard and Mouse: http://www.frank-zhao.com/cache/nehebkau.php | ||||
|  *  \li NeroJTAG, a JTAG dongle: https://github.com/makestuff/neroJtag | ||||
|  *  \li NES Controller USB modification: https://github.com/nfd/nes_adapter | ||||
|  *  \li Nikon wireless camera remote control (Norwegian): http://hekta.org/~hpe1119/ | ||||
|  *  \li Nintendo Four-Score, USB NES 4-player controller adapter: http://www.waitingforfriday.com/index.php/Nintendo_Four_Score_USB | ||||
|  *  \li Numpad keyboard: http://tuomasnylund.fi/drupal6/content/usb-cherry-mx-numpad | ||||
|  *  \li Opendous-JTAG, an open source ARM JTAG debugger: http://code.google.com/p/opendous-jtag/ | ||||
|  *  \li Openkubus, an open source hardware-based authentication dongle: http://code.google.com/p/openkubus/ | ||||
|  *  \li Orbee, a USB connected RGB Orb for notifications: http://www.franksworkshop.com.au/Electronics/Orbee/Orbee.htm | ||||
|  *  \li Password keyring: http://owlsan.blogspot.no/2014/06/keyring-project-version-10.html | ||||
|  *  \li Picade alternative firmware, a retro Arcade controller/cabinet: https://github.com/rktrlng/picade_lufa | ||||
|  *  \li PPM signal generator over USB: https://github.com/G33KatWork/USBPPM | ||||
|  *  \li Programmable keyboard controller: http://41j.com/blog/2011/10/a-programmable-keyboard-controller/ | ||||
|  *  \li Programmable XBOX controller: http://richard-burke.dyndns.org/wordpress/pan-galactic-gargantuan-gargle-brain-aka-xbox-360-usb-controller/ | ||||
|  *  \li Project Surface, a touch interface controller for Windows 8: https://code.google.com/p/project-surface/ | ||||
|  *  \li PSGroove, a Playstation 3 Homebrew dongle: http://github.com/psgroove | ||||
|  *  \li PS/2 to USB adapter: https://github.com/makestuff/p2ukbd | ||||
|  *  \li RaspiFace, an Arduino platform bridge for the Raspberry Pi: http://www.raspiface.com/ | ||||
|  *  \li Reflow oven controller: http://danstrother.com/2011/01/15/reflow-oven-controller/ | ||||
|  *  \li RFPirate, a RF experimentation platform: https://github.com/ebuller/RF-Pirate | ||||
|  *  \li RF Power Meter, based on the AD8307 log amp: https://sites.google.com/site/lofturj/ad8307-power-meter | ||||
|  *  \li RF Transceiver using the MRF49XA: http://alternet.us.com/?page_id=1494 | ||||
|  *  \li SD Card reader: http://elasticsheep.com/2010/04/teensy2-usb-mass-storage-with-an-sd-card/ | ||||
|  *  \li SDR1, a Software Defined Radio firmware: https://code.google.com/p/sdr-mk1/ | ||||
|  *  \li SEGA Megadrive/Genesis Development Cartridge: http://www.makestuff.eu/wordpress/?page_id=398 | ||||
|  *  \li Serial Line bus analyser: http://www.pjrc.com/teensy/projects/SerialAnalyzer.html | ||||
|  *  \li Simple USB LED Controller (SULC): https://github.com/scottbez1/sulc | ||||
|  *  \li SNES custom FLASH ROM: http://electrifiedfoolingmachine.co/?page_id=633 | ||||
|  *  \li Smartcard Detective: https://code.google.com/p/smartcarddetective/ | ||||
|  *  \li SmartportVHD Apple II Mass Storage adapter: http://pcedric3.free.fr/SmartportVHD/ | ||||
|  *  \li Single LED Matrix Display: http://guysoft.wordpress.com/2009/10/08/bumble-b/ | ||||
|  *  \li Simple USB LED Controller: https://github.com/scottbez1/sulc | ||||
|  *  \li Stripe Snoop, a Magnetic Card reader: http://www.ossguy.com/ss_usb/ | ||||
|  *  \li Stylophone, with USB MIDI connectivity: http://www.waitingforfriday.com/index.php/Stylophone_Studio_5 | ||||
|  *  \li Teensy SD Card .WAV file player: http://elasticsheep.com/2010/04/teensy2-usb-wav-player-part-1/ | ||||
|  *  \li Touch It (Fabulously), presumably art: http://touch.it.fa.bulo.us/ly/ | ||||
|  *  \li Touchscreen Input Device: http://capnstech.blogspot.com/2010/07/touchscreen-update.html | ||||
|  *  \li UDFS, a BBC Micro USB disk filing system: https://github.com/makestuff/udfs | ||||
|  *  \li Universal USB AVR Module: http://usbavr.bplaced.net/ | ||||
|  *  \li USB2AX, a USB to Dynamixel network adapter: http://paranoidstudio.assembla.com/wiki/show/paranoidstudio/USB2AX | ||||
|  *  \li USBPass, a USB password keeper: http://sroz.net/projects/usbpass/ | ||||
|  *  \li USB Business Card: http://www.limpkin.fr/index.php?post/2012/09/15/My-new-business-card | ||||
|  *  \li USB Function Generator: http://tuomasnylund.fi/drupal6/content/ad9833-based-usb-function-generator | ||||
|  *  \li USB Infrared Receiver/Transmitter: http://vaton4.web2001.cz/ | ||||
|  *  \li USB Interface for Playstation Portable Devices: http://forums.ps2dev.org/viewtopic.php?t=11001 | ||||
|  *  \li USB MIDI to DMX controller: http://github.com/hanshuebner/miDiMX | ||||
|  *  \li USB Mood Light: https://github.com/hsbp/usb_moodlight | ||||
|  *  \li USB powered Geiger Counter: http://uhrheber.wordpress.com/2011/04/28/a-usb-powered-geiger-counter-for-the-z2-and-other-computers/ | ||||
|  *  \li Userial, a USB to Serial converter with SPI, I2C and other protocols: http://www.tty1.net/userial/ | ||||
|  *  \li Wii Classic Controller to USB converter: https://github.com/crazyiop/wii-classic-2-usb | ||||
|  *  \li Wireless MIDI Guitar system: http://www.ise.pw.edu.pl/~wzab/wireless_guitar_system/ | ||||
|  *  \li XBOX 360 Startup Sound Changer: http://www.homebrew-connection.org/change-your-xbox-360-startup-sounds-yourself/ | ||||
|  *  \li Xnormidi, a C MIDI library: http://x37v.info/projects/xnormidi | ||||
|  *  \li XUM1541, a Commodore 64 floppy drive to USB adapter: http://www.root.org/~nate/c64/xum1541/ | ||||
|  *  \li Zeus, a touch screen computer for music manipulation: http://www.benbengler.com/developments_zeus.html | ||||
|  * | ||||
|  *  \section Sec_LUFACommercialProjects Projects Using LUFA (Commercial) | ||||
|  * | ||||
|  *  The following is a list of known commercial products using LUFA. Some of these are open source, although many are "black-box" | ||||
|  *  solutions with no source code given. Those companies which have purchased a Commercial License to LUFA (see \ref Page_LicenseInfo) | ||||
|  *  are not listed here unless specifically requested. | ||||
|  * | ||||
|  *  \li Alphasphere, a MIDI input sphere device for music creation: http://www.alphasphere.com/ | ||||
|  *  \li Arduino Uno and Leonardo, official Arduino boards: http://www.arduino.cc | ||||
|  *  \li ARPS Locator: http://la3t.hamradio.no/lab//?id=tracker_en | ||||
|  *  \li AsTeRICS assistive technologies project, HID actuator: http://www.asterics.eu | ||||
|  *  \li BitFury, a Bitcoin ASIC miner: https://github.com/aauer1/LUFA-BitFury/tree/master/Projects/BitfuryBTC | ||||
|  *  \li Ceberus, a MadCatz Xbox 360 arcade stick modifier: http://www.phreakmods.com/products/cerberus | ||||
|  *  \li CFFA3000, a CompactFlash interface for the Apple II: http://www.dreher.net/CFforAppleII | ||||
|  *  \li ChameleonMini, a RFID monitoring tool: https://github.com/emsec/ChameleonMini/wiki | ||||
|  *  \li Digital Survey Instruments Magnetometer and Pointer: http://www.digitalsurveyinstruments.com/ | ||||
|  *  \li FinchRobot, a robot designed for educational use: http://www.finchrobot.com/ | ||||
|  *  \li Flysight, a GPS logger for wingsuit pilots: http://flysight.ca/ | ||||
|  *  \li Goldilocks, an Arduino compatible clone: http://feilipu.me/2014/03/08/goldilocks-1284p-arduino-uno-clone/ | ||||
|  *  \li HummingBird Kit, a robotics learning platform: http://www.hummingbirdkit.com/ | ||||
|  *  \li LP1, an AVRISP-MKII Clone AVR Programmer: http://embeddedglow.com/items/LP1/LP1.php | ||||
|  *  \li Penguino, an Arduino Board With On-Board LUFA Powered Debugger/Programmer: http://wiki.icy.com.au/PenguinoAVR | ||||
|  *  \li PhatIO, a filesystem based I/O interface: http://www.phatio.com/ | ||||
|  *  \li PIR-1, an IR control interface for consumer electronics: http://www.promixis.com/pir-1.php | ||||
|  *  \li PIR-4, a USB Connected 4 port IR transmitter: http://promixis.com/pir-4.php | ||||
|  *  \li PortPilot, a USB device charger with power meter: http://portpilot.net/ | ||||
|  *  \li KeyGlove, an alternative input system: http://www.keyglove.net/ | ||||
|  *  \li Many of Busware's Products: http://www.busware.de/ | ||||
|  *  \li MIDIFighter, a USB-MIDI controller: http://www.midifighter.com/ | ||||
|  *  \li MIDI USB Arduino Shield: http://openpipe.cc/products/midi-usb-shield/ | ||||
|  *  \li Norduino, a wireless Arduino: http://norduino.robomotic.com/norduino-is-now-usb-hid/ | ||||
|  *  \li Olimex AVR-ISP-MK2, an AVRISP-MKII Clone AVR Programmer: https://www.olimex.com/dev/avr-isp-mk2.html | ||||
|  *  \li Retrode, a USB Games Console Cartridge Reader: http://www.retrode.org | ||||
|  *  \li RFI21.1EU UHF RFID reader: http://www.metra.cz/rfid/uhf-rfid-ctecky/rfi21-1eu-uhf-rfid-ctecka.htm | ||||
|  *  \li SmartCardDetective, a Smart Card analysis tool: http://www.smartcarddetective.com/ | ||||
|  *  \li TimelapsePlus, a digital camera time lapse tool: https://github.com/timelapseplus/TimelapsePlus-Firmware | ||||
|  *  \li USBTINY-MKII, an AVRISP-MKII Clone AVR Programmer: http://tom-itx.no-ip.biz:81/~webpage/boards/USBTiny_Mkii/USBTiny_Mkii_index.php | ||||
|  *  \li UDS18B20 USB Temperature sensor: http://toughlog.org/uds18b20/ | ||||
|  *  \li VMeter, a USB MIDI touch strip controller: http://www.vmeter.net/ | ||||
|  *  \li XMEGA Development Board, using LUFA as an On-Board Programmer: http://xmega.mattair.net/ | ||||
|  *  \li Zeptoprog, a multifunction AVR programmer: http://www.mattairtech.com/index.php/featured/zeptoprog.html | ||||
|  * | ||||
|  *  \section Sec_LUFAPublications Publications Mentioning LUFA | ||||
|  *  The following are published magazines which have either mentioned or featured the LUFA library. | ||||
|  * | ||||
|  *  \li Elektor Magazine, "My First AVR-USB" by Antoine Authier (feature), January 2010 Issue | ||||
|  *  \li Elektor Magazine, "USB is Cool/Sucks" by Jerry Jacobs and Chris Vossen (minor mention), January 2010 Issue | ||||
|  *  \li Elektor Magazine, "20 x Open Source" by Jens Nickel, March 2010 Issue | ||||
|  *  \li Circuit Cellar Magazine, "Advanced USB Design Debugging" by Collin O'Flynn, August 2010 Issue | ||||
|  *  \li "Some Assembly Required: Assembly Language Programming with the AVR Microcontroller" by Timothy S. Margush | ||||
|  *  \li Elektor Magazine, "Taming the Beast (2)" by Clemens Valens/Raymond Vermeulen, January 2014 Issue | ||||
|  * | ||||
|  *  \section Sec_LUFANotableMentions Other Notable Mentions of LUFA | ||||
|  *  The following are non-print but notable mentions of the LUFA library. | ||||
|  * | ||||
|  *  \li Adafruit "Ask an Engineer", 7th November 2010 | ||||
|  *  \li Arduino 2010 Keynote speech | ||||
|  *  \li The Amp Hour podcast blog #11 | ||||
|  *  \li Blackhat 2011 conference, "Exploiting USB Devices with Arduino" | ||||
|  * | ||||
|  *  \section Sec_PortsAndForks Non-Official LUFA Ports and Forks | ||||
|  *  The following are unofficial forks of the LUFA codebase, which implement different features such as support for | ||||
|  *  additional architectures. | ||||
|  * | ||||
|  *  \li NXP's official LPCOpen "LPCUSBLib" LUFA fork, for LPC devices: http://www.lpcware.com/ | ||||
|  *  \li Kevin Mehall's LUFA port to the NXP LPC13xx: https://github.com/kevinmehall/LUFA-LPC13xx | ||||
|  *  \li Mark Ding's port for the Silicon Labs SiM3U1xx: https://www.github.com/MarkDing/USB_CDC | ||||
|  *  \li Mark Ding's port for the Silicon Labs EFM32 Giant Gecko: https://github.com/MarkDing/lufa-efm32 | ||||
|  */ | ||||
							
								
								
									
										33
									
								
								LUFA/DoxygenPages/LibraryResources.txt
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										33
									
								
								LUFA/DoxygenPages/LibraryResources.txt
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,33 @@ | |||
| /** \file | ||||
|  * | ||||
|  *  This file contains special DoxyGen information for the generation of the main page and other special | ||||
|  *  documentation pages. It is not a project source file. | ||||
|  */ | ||||
| 
 | ||||
| /** | ||||
|  *  \page Page_Resources Library Resources | ||||
|  * | ||||
|  *  \section Sec_UnofficialResources Unofficial Resources | ||||
|  *  Unofficial Russian LUFA documentation translation: http://microsin.ru/Download.cnt/doc/LUFA/ \n | ||||
|  *  Tutorial for LUFA USB Control Transfers: http://www.avrbeginners.net/new/tutorials/usb-control-transfers-with-lufa/ | ||||
|  * | ||||
|  *  \section Sec_ProjectPages LUFA Related Webpages | ||||
|  *  Project Homepage: http://www.lufa-lib.org \n | ||||
|  *  Commercial Licenses: http://www.lufa-lib.org/license \n | ||||
|  *  Author's Website: http://www.fourwalledcubicle.com \n | ||||
|  *  Development Blog: http://www.fourwalledcubicle.com/blog \n | ||||
|  * | ||||
|  *  \section Sec_ProjectHelp Assistance With LUFA | ||||
|  *  Support Mailing List: http://www.lufa-lib.org/support \n | ||||
|  *  Author's Email: dean [at] fourwalledcubicle [dot] com \n | ||||
|  * | ||||
|  *  \section Sec_InDevelopment Latest In-Development Source Code | ||||
|  *  Issue Tracker: http://www.lufa-lib.org/tracker \n | ||||
|  *  Public GIT Repository: http://www.lufa-lib.org/git \n | ||||
|  *  Latest Repository Source Archive: http://www.lufa-lib.org/latest-archive \n | ||||
|  *  Commit RSS Feed: http://www.lufa-lib.org/rss \n | ||||
|  * | ||||
|  *  \section Sec_USBResources USB Resources | ||||
|  *  USB-IF Website: http://www.usb.org \n | ||||
|  */ | ||||
| 
 | ||||
							
								
								
									
										43
									
								
								LUFA/DoxygenPages/LicenseInfo.txt
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										43
									
								
								LUFA/DoxygenPages/LicenseInfo.txt
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,43 @@ | |||
| /** \file | ||||
|  * | ||||
|  *  This file contains special DoxyGen information for the generation of the main page and other special | ||||
|  *  documentation pages. It is not a project source file. | ||||
|  */ | ||||
| 
 | ||||
| /** | ||||
|  *  \page Page_LicenseInfo Source Code License | ||||
|  * | ||||
|  *  The LUFA library is currently released under the MIT license, included below. | ||||
|  * | ||||
|  *  \section Sec_LicenseForHumans License Summary for Human Beings | ||||
|  *  Everyone is free to use LUFA without payment - even in commercial applications | ||||
|  *  where the product source code is not publicly disclosed. However, use of the | ||||
|  *  library must be in accordance with the library license conditions. | ||||
|  * | ||||
|  *  If you wish to use LUFA without payment, you <b>must</b> include a copy of the | ||||
|  *  full license text below with your product or project - on your website, and in | ||||
|  *  an accompanying manual or other materials for the product. As long as the entire | ||||
|  *  license text is made available and obvious to the users of your product, you | ||||
|  *  are free to incorporate the LUFA library into your product without special | ||||
|  *  additional licensing. | ||||
|  * | ||||
|  *  \section Sec_CommercialLicenses Commercial Licensing | ||||
|  *  In some instances the small requirement for public disclosure of LUFA within a | ||||
|  *  product is unwanted; in these instances a commercial license is offered up as an | ||||
|  *  alternative to the standard LUFA license. | ||||
|  * | ||||
|  *  Commercial entities can opt out of the public disclosure clause in this license | ||||
|  *  for a one-time US$1500 payment. This provides a non-exclusive modified MIT | ||||
|  *  licensed which allows for the free use of the LUFA library, bootloaders and | ||||
|  *  (where the sole copyright is attributed to Dean Camera) demos without public | ||||
|  *  disclosure within an organization, in addition to three free hours of consultation | ||||
|  *  with the library author, and priority support. | ||||
|  * | ||||
|  *  Please visit the Commercial License link on \ref Page_Resources for more information on | ||||
|  *  ordering a commercial license for your company. | ||||
|  * | ||||
|  *  \section Sec_LicenseText LUFA License Text | ||||
|  * | ||||
|  *  \verbinclude License.txt | ||||
|  */ | ||||
| 
 | ||||
							
								
								
									
										52
									
								
								LUFA/DoxygenPages/MainPage.txt
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										52
									
								
								LUFA/DoxygenPages/MainPage.txt
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,52 @@ | |||
| /** \file | ||||
|  * | ||||
|  *  This file contains special DoxyGen information for the generation of the main page and other special | ||||
|  *  documentation pages. It is not a project source file. | ||||
|  */ | ||||
| 
 | ||||
| /** | ||||
|  *  \mainpage | ||||
|  * | ||||
|  *  \image html Images/LUFA.png | ||||
|  *  <div align="center"><small><i>Logo design by <a href="http://www.studiomonsoon.com">Studio Monsoon Photography</a></i></small></div> | ||||
|  *  \n | ||||
|  *  <div align="center"><a href="http://www.lufa-lib.org">http://www.lufa-lib.org</a></div> | ||||
|  *  \n | ||||
|  * | ||||
|  *  <b>LUFA is donationware. For author and donation information, see \ref Page_Donating.</b> | ||||
|  * | ||||
|  *  LUFA is an open-source USB library for the USB-enabled AVR microcontrollers, released under the MIT license (see \ref Page_LicenseInfo). | ||||
|  *  It supports a large number of USB AVR models and boards (see \ref Page_DeviceSupport). It is designed to provide an easy to use, | ||||
|  *  feature rich framework for the development of USB peripherals and hosts. | ||||
|  * | ||||
|  *  LUFA focuses on the microcontroller side of USB development only; it includes no PC host USB driver development facilities - other projects | ||||
|  *  such as the Windows Driver Development Kit, Windows USB Device Mode Framework and libusb may be of interest for developing custom OS drivers. | ||||
|  *  While custom USB devices can be made with LUFA using such tools, the included demos all use the inbuilt OS drivers for each USB class for | ||||
|  *  simplicity. | ||||
|  * | ||||
|  *  The library is currently in a stable release, suitable for download and incorporation into user projects for | ||||
|  *  both host and device modes. For information about the project progression, see the blog link at \ref Page_Resources. | ||||
|  * | ||||
|  *  LUFA is written specifically for the free AVR-GCC compiler, and uses several GCC-only extensions to make the | ||||
|  *  library API more streamlined and robust. You can download AVR-GCC for free in a convenient windows package, | ||||
|  *  from the the WinAVR website (see \ref Page_Resources). | ||||
|  * | ||||
|  *  The only required AVR peripherals for LUFA is the USB controller itself and interrupts - LUFA does not require the use of the | ||||
|  *  microcontroller's timers or other hardware, leaving more hardware to the application developer. | ||||
|  * | ||||
|  *  Accompanying LUFA in the download package is a set of example demo applications, plus several Bootloaders of different classes | ||||
|  *  and open source LUFA powered projects. | ||||
|  * | ||||
|  *  <b>Subsections:</b> | ||||
|  *  \li \subpage Page_LicenseInfo - Project source license and commercial use information | ||||
|  *  \li \subpage Page_Donating - Donating to support this project | ||||
|  *  \li \subpage Page_DeviceSupport - Current Device and Hardware Support | ||||
|  *  \li \subpage Page_ChangeLog - Project Changelog | ||||
|  *  \li \subpage Page_KnownIssues - Known Issues | ||||
|  *  \li \subpage Page_FutureChanges - Planned Changes to the Library | ||||
|  *  \li \subpage Page_GettingStarted - Getting started with LUFA | ||||
|  *  \li \subpage Page_DevelopingWithLUFA - Developing with LUFA | ||||
|  *  \li \subpage Page_LUFAPoweredProjects - Other Projects Using LUFA | ||||
|  *  \li \subpage Page_Resources - LUFA and USB Related Resources | ||||
|  */ | ||||
| 
 | ||||
							
								
								
									
										717
									
								
								LUFA/DoxygenPages/MigrationInformation.txt
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										717
									
								
								LUFA/DoxygenPages/MigrationInformation.txt
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,717 @@ | |||
| /** \file | ||||
|  * | ||||
|  *  This file contains special DoxyGen information for the generation of the main page and other special | ||||
|  *  documentation pages. It is not a project source file. | ||||
|  */ | ||||
| 
 | ||||
| /** \page Page_Migration Migrating from Older Versions | ||||
|  * | ||||
|  *  Below is migration information for updating existing projects based on previous versions of the LUFA library | ||||
|  *  to the next version released. It does not indicate all new additions to the library in each version change, only | ||||
|  *  areas relevant to making older projects compatible with the API changes of each new release. | ||||
|  * | ||||
|  *  \section Sec_Migration170418 Version 170418 | ||||
|  *  <b>Device Mode</b> | ||||
|  *   - The \c CALLBACK_USB_GetDescriptor() callback function into the user application's \c wIndex parameter is now \c uint16_t, not \c uint8_t. | ||||
|  * | ||||
|  *  \section Sec_Migration151115 Migrating from 140928 to 151115 | ||||
|  *  <b>Non-USB Library Components</b> | ||||
|  *    - The ATPROGRAM LUFA build system module now defaults to the Atmel ICE debugger tool, instead of the Atmel JTAG ICE3. | ||||
|  *    - The \c Serial_CreateStream() and \c Serial_CreateBlockingStream() functions now require a USART base pointer for XMEGA devices as the first parameter. | ||||
|  * | ||||
|  *  \section Sec_Migration140928 Migrating from 140302 to 140928 | ||||
|  *  <b>Device Mode</b> | ||||
|  *    - The device mode RNDIS class driver now requires a user-supplied buffer and buffer length to operate, rather | ||||
|  *      than allocating this buffer internally. | ||||
|  * | ||||
|  *  \section Sec_Migration140302 Migrating from 130901 to 140302 | ||||
|  *  <b>USB Core</b> | ||||
|  *    - The \c VERSION_BCD() macro has changed from accepting one floating point parameter to taking three distinct major/minor/revision integer parameters, as | ||||
|  *      some edge cases caused incorrect parsing of the input float into the final integer BCD encoded value. | ||||
|  * | ||||
|  *  <b>Non-USB Library Components</b> | ||||
|  *    - The \c ATTR_NEVER_INLINE macro, erroneously introduced in a previous release has been removed, as it duplicates the existing \c ATTR_NO_INLINE macro. | ||||
|  * | ||||
|  *  <b>Build System</b> | ||||
|  *    - The default configuration file for Doxygen is now "doxyfile" rather than "Doxygen.conf", to conform to the Doxygen project's own default file name. | ||||
|  *      Set \c DOXYGEN_CONF to override the new default file name. | ||||
|  * | ||||
|  *  \section Sec_Migration130901 Migrating from 130303 to 130901 | ||||
|  *  <b>Non-USB Library Components</b> | ||||
|  *    - The Board Dataflash \c Dataflash_Init() function now automatically configures the appropriate communication interface. | ||||
|  * | ||||
|  *  \section Sec_Migration130303 Migrating from 120730 to 130303 | ||||
|  *  <b>Device Mode</b> | ||||
|  *    - The \ref HID_KEYBOARD_LED_KANA macro was previously misspelled as \c HID_KEYBOARD_LED_KATANA, and had an incorrect value. User applications requiring this | ||||
|  *      constant should use the new name, and remove any workarounds for the previously incorrect macro definition. | ||||
|  *    - The \c HID_KEYBOARD_SC_EQUAL_SIGN macro has been renamed to \ref HID_KEYBOARD_SC_KEYPAD_EQUAL_SIGN, and the previous definition of | ||||
|  *      \c HID_KEYBOARD_SC_KEYPAD_EQUAL_SIGN has been renamed \ref HID_KEYBOARD_SC_KEYPAD_EQUAL_SIGN_AS400 to conform to the definitions in the HID specification. | ||||
|  * | ||||
|  *  <b>Host Mode</b> | ||||
|  *    - The \ref HID_KEYBOARD_LED_KANA macro was previously misspelled as \c HID_KEYBOARD_LED_KATANA, and had an incorrect value. User applications requiring this | ||||
|  *      constant should use the new name, and remove any workarounds for the previously incorrect macro definition. | ||||
|  *    - The \c HID_KEYBOARD_SC_EQUAL_SIGN macro has been renamed to \ref HID_KEYBOARD_SC_KEYPAD_EQUAL_SIGN, and the previous definition of | ||||
|  *      \c HID_KEYBOARD_SC_KEYPAD_EQUAL_SIGN has been renamed \ref HID_KEYBOARD_SC_KEYPAD_EQUAL_SIGN_AS400 to conform to the definitions in the HID specification. | ||||
|  * | ||||
|  *  \section Sec_Migration120730 Migrating from 120219 to 120730 | ||||
|  *  <b>Device Mode</b> | ||||
|  *    - The device mode Audio Class driver now requires an additional configuration parameter, the Audio Control interface index. Existing applications should | ||||
|  *      be adjusted to specify the additional configuration parameter. | ||||
|  *    - The HID_DESCRIPTOR_JOYSTICK() macro no longer takes a variable number of axis as a parameter, due to OS incompatibilities; this macro now uses a fixed | ||||
|  *      3 axis of data. User applications should update their calls to this macro and their report structures to suit a fixed 3-axis joystick report. If a user | ||||
|  *      application requires more than 3 axis' of data, a custom report descriptor will need to be constructed by hand. | ||||
|  *    - The \ref Endpoint_ConfigureEndpoint() function no longer takes in masks for the banks and direction; the number of banks is now an integer argument, and | ||||
|  *      the direction is obtained from the full endpoint address within the device. Applications calling Endpoint_ConfigureEndpoint() should update their API | ||||
|  *      call to use a full endpoint address (including ENDPOINT_DIR_IN or ENDPOINT_DIR_OUT direction in the MSB of the endpoint address) and an integer number | ||||
|  *      of banks. | ||||
|  *    - All endpoint functions now operate on full endpoint addresses within the device, rather than a directionless endpoint index. Applications should update | ||||
|  *      their API calls to use full endpoint addresses when required within the device. | ||||
|  *    - All device mode class drivers have been updated to use a new unified endpoint description structure for all endpoints; existing applications will need | ||||
|  *      to update their class driver struct instantiation to match the new scheme (see \ref USB_Endpoint_Table_t). | ||||
|  *    - The \c ENDPOINT_BANKS_SUPPORTED() and \c ENDPOINT_MAX_ENDPOINT_SIZE() macros have been removed, as these do not function correctly with the new addressing | ||||
|  *      scheme for the endpoint APIs. Please refer to the target device's datasheet for the maximum bank size of each endpoint. | ||||
|  *    - The MIDI class driver \ref MIDI_EventPacket_t event packet no longer contains separate \c CableIndex and \c Command entries; these have been combined | ||||
|  *      into a single \c Event element which can be constructed using the new macro \ref MIDI_EVENT(). Existing applications should use the new macro and structure | ||||
|  *      element name. | ||||
|  * | ||||
|  *  <b>Host Mode</b> | ||||
|  *    - The Android Accessory Host class driver property strings are now a array of \c char* rather than a struct of named pointers. Existing applications | ||||
|  *      should use C99 Designated Initializers with the property string indexes located in \ref AOA_Strings_t instead. | ||||
|  *    - The \ref Pipe_ConfigurePipe() function no longer takes in masks for the banks and token; the number of banks is now an integer argument, and the token | ||||
|  *      is now inferred from the full pipe address within the device, and the pipe type. Applications calling Pipe_ConfigurePipe() should update their API | ||||
|  *      call to use a full pipe address (including PIPE_DIR_IN or PIPE_DIR_OUT direction in the MSB of the pipe address) and an integer number of banks. | ||||
|  *    - All pipe functions now operate on full pipe addresses within the device, rather than a directionless pipe index. Applications should update their API | ||||
|  *      calls to use full pipe addresses when required within the device. | ||||
|  *    - All host mode class drivers have been updated to use a new unified pipe description structure for all pipes; existing applications will need to update | ||||
|  *      their class driver struct instantiation to match the new scheme (see \ref USB_Pipe_Table_t). | ||||
|  *    - The MIDI class driver \ref MIDI_EventPacket_t event packet no longer contains seperate \c CableIndex and \c Command entries; these have been combined | ||||
|  *      into a single \c Event element which can be constructed using the new macro \ref MIDI_EVENT(). Existing applications should use the new macro and structure | ||||
|  *      element name. | ||||
|  *    - The library "LUFA/Drivers/USB/Core/ConfigDescriptor.c" source file has been renamed "LUFA/Drivers/USB/Core/ConfigDescriptors.c" as this was clashing with | ||||
|  *      files in some low level host mode demo applications, preventing parallel project builds. If you are referencing the project source files directly instead | ||||
|  *      of using the makefile module names, you will need to adjust your project makefile. | ||||
|  * | ||||
|  *  \section Sec_Migration120219 Migrating from 111009 to 120219 | ||||
|  *  <b>USB Core</b> | ||||
|  *    - The HID_KEYBOARD_MODIFER_* macros in the HID class driver have been corrected to HID_KEYBOARD_MODIFIER_* (note the spelling of "modifier"). | ||||
|  *      Existing applications should switch over to the correctly spelled macro names. | ||||
|  *    - The names of the USB Device and USB Host class driver files have changed; a new "ClassDevice" and "ClassHost" postfix has been added to the | ||||
|  *      respective class driver files. Projects referencing the class driver source files by filename rather than the LUFA_SRC_USBCLASS makefile | ||||
|  *      variable should append these postfixes to the source file names. Projects including the USB class driver dispatch headers directly should either | ||||
|  *      switch to including the main USB driver header instead, or use the updated header filenames. | ||||
|  *    - The USB_CONFIG_ATTR_BUSPOWERED constant has been renamed to USB_CONFIG_ATTR_RESERVED, as this was misnamed. All devices must set this bit in | ||||
|  *      the Configuration descriptor's attributes field. As all devices are assumed to be bus-powered unless stated otherwise with the | ||||
|  *      USB_CONFIG_ATTR_SELFPOWERED flag a replacement constant for bus powered devices is not provided. | ||||
|  * | ||||
|  *  <b>Device Mode</b> | ||||
|  *    - The device mode Audio class driver now requires a new user application callback, \ref CALLBACK_Audio_Device_GetSetInterfaceProperty(). | ||||
|  *      Existing applications must implement this new callback, however if no audio entities are defined in the audio device's descriptors, | ||||
|  *      this function may be hard-coded to always return false for previous behaviour to be retained. | ||||
|  * | ||||
|  *  \section Sec_Migration111009 Migrating from 110528 to 111009 | ||||
|  *  <b>Non-USB Library Components</b> | ||||
|  *    - The \c JTAG_DEBUG_ASSERT() macro has been renamed \ref JTAG_ASSERT() to be consistent with \ref STDOUT_ASSERT(). | ||||
|  * | ||||
|  *  <b>USB Core</b> | ||||
|  *    - By default, unordered Endpoint and Pipe configuration is now allowed once again, via the previous workaround of | ||||
|  *      reconfiguring all Endpoints/Pipes in order each time a new Endpoint/Pipe is created. To minimize the compiled program | ||||
|  *      size, the new \c ORDERED_EP_CONFIG compile time option may be defined in the project makefile to restrict the ordering | ||||
|  *      in exchange for a smaller compiled binary size. | ||||
|  *    - The previous \c F_CLOCK symbol, required in the project makefile, has been renamed to \c F_USB. This is due to the previous name | ||||
|  *      being far too generic for use in future architecture ports, where multiple clock domains are used. | ||||
|  * | ||||
|  *  <b>Device Mode</b> | ||||
|  *    - The Endpoint stream functions now all require a \c BytesProcessed parameter instead of the previous callback parameter. | ||||
|  *      This should be set to \c NULL to retain previous behaviour of the functions, or point to a location where the number of bytes | ||||
|  *      processed in the current transaction can be stored. If the \c BytesProcessed parameter is non \c NULL, each time the endpoint | ||||
|  *      bank becomes full and the packet is sent, the routine will exit with the new \ref ENDPOINT_RWSTREAM_IncompleteTransfer | ||||
|  *      error code to allow the user application to determine when to send the next chunk of data. | ||||
|  *    - The \ref CDC_Device_SendString() function now expects a null terminated string instead of an explicit length. Existing code | ||||
|  *      should use the new \ref CDC_Device_SendData() function, or remove the length parameter from the function call. | ||||
|  *    - The \c Endpoint_ResetFIFO() function has been renamed to \ref Endpoint_ResetEndpoint(), to make the API function names more | ||||
|  *      consistent. Existing applications using the old function name should simply replace it with a call to the new function name. | ||||
|  *    - The \c Endpoint_*_Byte() functions have been renamed Endpoint_*_8() to ensure they are correct across all architectures. Existing | ||||
|  *      code using these functions should replace the previous function names with the new function names. | ||||
|  *    - The \c Endpoint_*_Word() functions have been renamed Endpoint_*_16() to ensure they are correct across all architectures. Existing | ||||
|  *      code using these functions should replace the previous function names with the new function names. | ||||
|  *    - The \c Endpoint_*_DWord() functions have been renamed Endpoint_*_32() to ensure they are correct across all architectures. Existing | ||||
|  *      code using these functions should replace the previous function names with the new function names. | ||||
|  *    - The Device mode RNDIS class driver no longer stores the incoming and outgoing packets in the class driver instance; the user is | ||||
|  *      now expected to manually define a storage location for the packet data. Packets must now be sent and received manually via a call | ||||
|  *      to \ref RNDIS_Device_ReadPacket() and/or \ref RNDIS_Device_SendPacket(). | ||||
|  *    - The definition of the Audio class \ref USB_Audio_Descriptor_Format_t has been altered, to remove the fixed singular | ||||
|  *      audio sample rate in the descriptor definition, and to rename the \c SampleFrequencyType to the more appropriate | ||||
|  *      \c TotalDiscreteSampleRates. Existing applications will need to add an array of \ref USB_Audio_SampleFreq_t elements | ||||
|  *      immediately following any \ref USB_Audio_Descriptor_Format_t descriptors, and insert the appropriate sampling rates | ||||
|  *      supported by the device, as well as rename the descriptor elements to match the updated element names. | ||||
|  *    - The device mode Audio class driver now requires a new user application callback, \ref CALLBACK_Audio_Device_GetSetEndpointProperty(). | ||||
|  *      Existing applications must implement this new callback, however if multiple sample rates or pitch control is not used, | ||||
|  *      this function may be hard-coded to always return false for previous behaviour to be retained. | ||||
|  *    - The \c USB_ConfigurationNumber, \c USB_RemoteWakeupEnabled and \c USB_CurrentlySelfPowered globals have been renamed to | ||||
|  *      \ref USB_Device_ConfigurationNumber, \ref USB_Device_RemoteWakeupEnabled and \ref USB_Device_CurrentlySelfPowered to clearly indicate | ||||
|  *      the USB mode they relate to. Existing applications using these variables should rename all references to the previous names. | ||||
|  *    - The \c ENDPOINT_DESCRIPTOR_DIR_IN and \c ENDPOINT_DESCRIPTOR_DIR_OUT macros have now been replaced by \ref ENDPOINT_DIR_IN and | ||||
|  *      \ref ENDPOINT_DIR_OUT to improve code clarity. | ||||
|  *    - The \ref HID_DESCRIPTOR_JOYSTICK() macro now takes an additional (first) parameter indicating the number of axis in the joystick. | ||||
|  * | ||||
|  *  <b>Host Mode</b> | ||||
|  *    - The Pipe stream functions now all require a \c BytesProcessed parameter instead of the previous callback parameter. | ||||
|  *      This should be set to \c NULL to retain previous behaviour of the functions, or point to a location where the number of bytes | ||||
|  *      processed in the current transaction can be stored. If the BytesProcessed parameter is non \c NULL, each time the pipe | ||||
|  *      bank becomes full and the packet is sent, the routine will exit with the new \ref PIPE_RWSTREAM_IncompleteTransfer | ||||
|  *      error code to allow the user application to determine when to send the next chunk of data. | ||||
|  *    - The \ref PRNT_Host_SendString() and \ref CDC_Host_SendString() functions now expect a null terminated string instead of an explicit | ||||
|  *      length. Existing code should use the new \ref PRNT_Host_SendData() and \ref CDC_Host_SendData() functions, or remove the | ||||
|  *      length parameter from the function call. | ||||
|  *    - The \c Pipe_ClearErrorFlags() function has been removed, as the pipe error flags are now automatically cleared when the | ||||
|  *      \ref Pipe_ClearError() function is called. | ||||
|  *    - The \c Pipe_*_Byte() functions have been renamed Pipe_*_8() to ensure they are correct across all architectures. Existing code using | ||||
|  *      these functions should replace the previous function names with the new function names. | ||||
|  *    - The \c Pipe_*_Word() functions have been renamed Pipe_*_16() to ensure they are correct across all architectures. Existing code using | ||||
|  *      these functions should replace the previous function names with the new function names. | ||||
|  *    - The \c Pipe_*_DWord() functions have been renamed Pipe_*_32() to ensure they are correct across all architectures. Existing code using | ||||
|  *      these functions should replace the previous function names with the new function names. | ||||
|  *    - The \c USB_Host_ClearPipeStall() function has been renamed to USB_Host_ClearEndpointStall(), as it operates on a full endpoint address | ||||
|  *      within the attached device and not a pipe within the host. Existing code using the old function name should update the function calls and | ||||
|  *      check for correct usage. | ||||
|  * | ||||
|  *  \section Sec_Migration101122 Migrating from 100807 to 101122 | ||||
|  *  <b>USB Core</b> | ||||
|  *    - A new USB driver source file, \c Drivers/USB/HighLevel/EndpointStream.c now exists. This source file should be added | ||||
|  *      to all project makefiles using the USB driver of LUFA, or the makefile should be updated to use the new module source | ||||
|  *      variables. | ||||
|  *    - A new USB driver source file, \c Drivers/USB/HighLevel/PipeStream.c now exists. This source file should be added to all | ||||
|  *      project makefiles using the USB driver of LUFA, or the makefile should be updated to use the new module source variables. | ||||
|  *    - The \c EVENT_USB_InitFailure() event has been removed, as the \ref USB_Init() function will no longer fail; if not USB mode is | ||||
|  *      specified, the controller will default to UID selection mode. | ||||
|  *    - The USB mode specifier constants have been moved into a new enum and renamed. Existing projects should use the equivalent | ||||
|  *      value in the new \ref USB_Modes_t enum. | ||||
|  *    - All class driver headers are now included as part of the standard \c LUFA/Drivers/USB/USB.h master dispatch header, and should | ||||
|  *      no longer be included separately. Class driver module source files must still be added as a separate module in the project's | ||||
|  *      makefile if used. | ||||
|  * | ||||
|  *  <b>Device Mode</b> | ||||
|  *    - Endpoints MUST be allocated in ascending order to ensure that bank corruption does not occur. Ensure that your user application | ||||
|  *      allocated endpoints in ascending order - or if your application uses the USB device mode class drivers, ensure that each instance's | ||||
|  *      endpoint indexes are not overlapped with other interface's endpoints. | ||||
|  *    - The signature for the \ref CALLBACK_USB_GetDescriptor() callback has changed, the \c void** \c const \c DescriptorAddress parameter is | ||||
|  *      now \c const \c void** \c const \c DescriptorAddress. Existing applications should update their callback signatures to match this, and | ||||
|  *      eliminate any casting of descriptor pointers to a non \c const pointer. | ||||
|  *    - The names of the class specific descriptor type defines in the USB Class drivers have changed - refer to the driver documentation | ||||
|  *      for each class driver for the new class specific descriptor type names. | ||||
|  *    - The \c ENDPOINT_DOUBLEBANK_SUPPORTED() macro is has been renamed \c ENDPOINT_BANKS_SUPPORTED() and now returns the total number of | ||||
|  *      banks supported by the given endpoint. Existing code should switch to the new naming scheme, and test that the return value of the | ||||
|  *      macro is equal to or greater than 2 to regain the previous functionality. | ||||
|  *    - The \c EVENT_USB_Device_UnhandledControlRequest() event is now named \ref EVENT_USB_Device_ControlRequest() and fires before (not after) | ||||
|  *      the internal library event handlers. Existing code should rename the event handlers in the user application to match the new event | ||||
|  *      name, and should ensure that the new execution order does not affect the application's operation. | ||||
|  * | ||||
|  *  <b>Host Mode</b> | ||||
|  *    - Pipes MUST be allocated in ascending order to ensure that bank corruption does not occur. Ensure that your user application | ||||
|  *      allocated pipes in ascending order - or if your application uses the USB host mode class drivers, ensure that each instance's | ||||
|  *      pipe indexes are not overlapped with other interface's pipes. | ||||
|  *    - The \c PRNT_Host_SendData() function has been renamed to \ref PRNT_Host_SendString(). Existing applications should simply | ||||
|  *      replace all references to the obsolete function name with the new function name. | ||||
|  *    - The names of the class specific descriptor type defines in the USB Class drivers have changed - refer to the driver documentation | ||||
|  *      for each class driver for the new class specific descriptor type names. | ||||
|  *    - The Still Image Host class' function prefix has been changed from \c SImage_ to  \c SI_, to remain consistent with the rest of the | ||||
|  *      driver's enums, type defines and constants. | ||||
|  * | ||||
|  *  \section Sec_Migration100807 Migrating from 100513 to 100807 | ||||
|  * | ||||
|  *  <b>Non-USB Library Components</b> | ||||
|  *    - The Dataflash board driver stub file has changed, as dataflash functions previously located in the internal | ||||
|  *      Dataflash driver of the library have now been moved to the individual board files. Existing drivers can | ||||
|  *      copy-paste the new functions from the board Dataflash stub driver. | ||||
|  * | ||||
|  *  <b>USB Core</b> | ||||
|  *    - A new USB driver source file, \c Drivers/USB/LowLevel/Device.c now exists. This source file should be added to all project | ||||
|  *      makefiles using the USB driver of LUFA, or the makefile should be updated to use the new module source variables. | ||||
|  *    - The \c Drivers/USB/LowLevel/DevChapter9.c source file has moved to \c Drivers/USB/HighLevel/DeviceStandardReq.c - this should | ||||
|  *      be updated in all project makefiles, or the makefile should be updated to use the new module source variables. | ||||
|  *    - The \c Drivers/USB/LowLevel/HostChapter9.h source file has moved to \c Drivers/USB/HighLevel/HostStandardReq.c - this should | ||||
|  *      be updated in all project makefiles, or the makefile should be updated to use the new module source variables. | ||||
|  *    - The \c Drivers/USB/LowLevel/LowLevel.c source file has moved to \c Drivers/LowLevel/USBController.c - this should be updated | ||||
|  *      in all project makefiles, or the makefile should be updated to use the new module source variables. | ||||
|  * | ||||
|  *  <b>Device Mode</b> | ||||
|  *    - The \c USB_Device_IsRemoteWakeupSent() macro has been removed, as the remote wakeup request is now fully handled by the | ||||
|  *      enhanced \ref USB_Device_SendRemoteWakeup() function. Existing code may now discard any checks to \c USB_Device_IsRemoteWakeupSent(). | ||||
|  *    - The \c USB_Device_IsUSBSuspended() macro has been removed, as it is obsolete. Existing code should compare \ref USB_DeviceState | ||||
|  *      to see if it the device is in the \ref DEVICE_STATE_Suspended state instead. | ||||
|  *    - The \ref CDC_Device_ReceiveByte() function has changed, and now returns a signed 16-bit integer, with -1 indicating no data was | ||||
|  *      received. This allows for more efficient coding, as a call to \ref CDC_Device_BytesReceived() is no longer needed if the exact | ||||
|  *      number of queued bytes received is not needed. | ||||
|  * | ||||
|  *  <b>Host Mode</b> | ||||
|  *    - The \ref CDC_Host_ReceiveByte() function has changed, and now returns a signed 16-bit integer, with -1 indicating no data was | ||||
|  *      received. This allows for more efficient coding, as a call to \ref CDC_Host_BytesReceived() is no longer needed if the exact | ||||
|  *      number of queued bytes received is not needed. | ||||
|  *    - The \ref CDC_Host_USBTask() now calls \ref CDC_Host_Flush() automatically, flushing any queued data to the attached device. Manual | ||||
|  *      flushing of the interface is no longer needed if the flushes should be in sync with calls to \ref CDC_Host_USBTask(). | ||||
|  * | ||||
|  *  \section Sec_Migration100513 Migrating from 100219 to 100513 | ||||
|  * | ||||
|  *  <b>Non-USB Library Components</b> | ||||
|  *    - The \ref TWI_StartTransmission() function now takes in a timeout period, expressed in milliseconds, within which the addressed | ||||
|  *      device must respond or the function will abort. | ||||
|  * | ||||
|  *  <b>Device Mode</b> | ||||
|  *    - The \ref USB_Init() function no longer calls \c sei() to enable global interrupts, as the user application may need | ||||
|  *      to perform other initialization before it is ready to handle global interrupts. The user application is now responsible | ||||
|  *      for enabling global interrupts before or shortly after calling \ref USB_Init() to ensure that the enumeration process | ||||
|  *      functions correctly. | ||||
|  *    - The \c USBInterrupt.c USB driver source file has been relocated from \c LUFA/Drivers/USB/HighLevel/ to \c LUFA/Drivers/USB/LowLevel. | ||||
|  *      Projects must update their makefile SRC values accordingly. | ||||
|  *    - The HID Device Class driver's function signature for the \ref CALLBACK_HID_Device_ProcessHIDReport() function has been changed, to | ||||
|  *      allow for a new \c ReportType parameter. This new parameter must be added in all user applications using the Device mode HID Class | ||||
|  *      Driver, but may be ignored unless Host-to-Device FEATURE HID reports are used. | ||||
|  * | ||||
|  *  <b>Host Mode</b> | ||||
|  *    - The \ref USB_Init() function no longer calls \c sei() to enable global interrupts, as the user application may need | ||||
|  *      to perform other initialization before it is ready to handle global interrupts. The user application is now responsible | ||||
|  *      for enabling global interrupts before or shortly after calling \ref USB_Init() to ensure that the enumeration process | ||||
|  *      functions correctly. | ||||
|  *    - The \c USBInterrupt.c USB driver source file has been relocated from \c LUFA/Drivers/USB/HighLevel/ to \c LUFA/Drivers/USB/LowLevel. | ||||
|  *      Projects must update their makefile \c SRC values accordingly. | ||||
|  *    - The HID Host Class driver's function signature for the \ref HID_Host_SendReportByID() function has been changed, to allow for a new | ||||
|  *      ReportType parameter. Existing calls to this function should substitute \c REPORT_ITEM_TYPE_Out as this parameter's value. | ||||
|  * | ||||
|  *  \section Sec_Migration100219 Migrating from 091223 to 100219 | ||||
|  * | ||||
|  *  <b>Non-USB Library Components</b> | ||||
|  *    - Due to some ADC channels not being identical to their ADC MUX selection masks for single-ended conversions on some AVR models, | ||||
|  *      the ADC driver now has explicit masks for each of the standard ADC channels (see \ref Group_ADC). These masks should be used | ||||
|  *      when calling the ADC functions to ensure proper operation across all AVR models. Note that the \ref ADC_SetupChannel() function | ||||
|  *      is an exception, and should always be called with a channel number rather than a channel mask. | ||||
|  * | ||||
|  *  <b>Host Mode</b> | ||||
|  *    - The MIDI Host Class driver send and receive routines now operate on packed events, where multiple MIDI events may be | ||||
|  *      packed into a single USB packet. This means that the sending of MIDI events will now be delayed until the MIDI send | ||||
|  *      pipe bank is full. To override this new behaviour and revert to the previous behaviour, the user application may manually | ||||
|  *      flush the queued event(s) to the device by calling \ref MIDI_Host_Flush(). | ||||
|  *    - The \ref Pipe_IsEndpointBound() function now takes the endpoint's direction into account, by checking if the MSB of the endpoint's address | ||||
|  *      is set to denote IN endpoints. If the previous functionality where the direction is to be discounted is required, mask the endpoint | ||||
|  *      address against the \ref PIPE_EPNUM_MASK token before calling \ref Pipe_IsEndpointBound(). | ||||
|  * | ||||
|  *  <b>Device Mode</b> | ||||
|  *    - The MIDI Device Class driver send and receive routines now operate on packed events, where multiple MIDI events may be | ||||
|  *      packed into a single USB packet. This means that the sending of MIDI events will now be delayed until the MIDI send | ||||
|  *      endpoint bank is full. To override this new behaviour and revert to the previous behaviour, the user application may manually | ||||
|  *      flush the queued event(s) to the host by calling \ref MIDI_Device_Flush(). | ||||
|  * | ||||
|  *  \section Sec_Migration091223 Migrating from 091122 to 091223 | ||||
|  * | ||||
|  *  <b>Host Mode</b> | ||||
|  *    - The Still Image Host Class driver \ref SI_Host_USBTask() and \ref SI_Host_ConfigurePipes() functions were misnamed, and are | ||||
|  *      now named \c SImage_Host_USBTask() and \c SImage_Host_ConfigurePipes() respectively. | ||||
|  *    - The \c HOST_SENDCONTROL_DeviceDisconnect enum value has been renamed to \ref HOST_SENDCONTROL_DeviceDisconnected to be in | ||||
|  *      line with the rest of the library error codes. | ||||
|  *    - The HID Parser item usages no longer contain separate minimum and maximum values, as this was a violation of the HID | ||||
|  *      specification. Instead, the values are distributed evenly across each item as its usage value, to ensure that all items | ||||
|  *      can be distinguished from one-another. | ||||
|  * | ||||
|  *  <b>Device Mode</b> | ||||
|  *    - The \ref CALLBACK_HID_Device_CreateHIDReport() HID Device Class driver callback now has a new \c ReportType parameter to | ||||
|  *      indicate the report type to generate. Existing applications may simply add and ignore this additional parameter. | ||||
|  * | ||||
|  *  \section Sec_Migration091122 Migrating from 090924 to 091122 | ||||
|  * | ||||
|  *  <b>Host Mode</b> | ||||
|  *    - The \c HID_PARSE_UsageStackOverflow HID parser error constant is now named \ref HID_PARSE_UsageListOverflow | ||||
|  *    - The \ref CALLBACK_HIDParser_FilterHIDReportItem() HID Parser callback now passes a complete \ref HID_ReportItem_t to the | ||||
|  *      user application, instead of just its attributes. | ||||
|  *    - The \c USB_GetDeviceConfigDescriptor() function was incorrectly named and is now called \ref USB_Host_GetDeviceConfigDescriptor(). | ||||
|  * | ||||
|  *  \section Sec_Migration090924 Migrating from 090810 to 090924 | ||||
|  * | ||||
|  *  <b>Non-USB Library Components</b> | ||||
|  *    - The \c ADC_Off() function has been renamed to \c ADC_ShutDown() to be consistent with the rest of the library. | ||||
|  *    - The \ref SPI_Init() routine's parameters have changed, so that the clock polarity and data sampling modes can be set. See | ||||
|  *      the \ref SPI_Init() function documentation for more details | ||||
|  *    - The \ref Dataflash_Init() routine no longer initializes the SPI bus - the SPI bus should be initialized manually via a | ||||
|  *      call to \ref SPI_Init() before using the Dataflash driver | ||||
|  * | ||||
|  *  <b>Host Mode</b> | ||||
|  *    - The \c USB_GetDeviceConfigDescriptor() function's parameters and behaviour has changed; the user is required to | ||||
|  *      preallocate the largest allowable buffer, and pass the size of the buffer to the function. This allows for a single | ||||
|  *      call to the function to retrieve, size check and validate the Configuration Descriptor rather than having the user | ||||
|  *      application perform these intermediary steps. | ||||
|  *    - The HID report parser now requires a mandatory callback in the user code, to filter only the items the application | ||||
|  *      is interested in into the processed HID report item structure to save RAM. See \ref CALLBACK_HIDParser_FilterHIDReportItem(). | ||||
|  *    - The HID report parser now always parses FEATURE and always ignores constant-data items - the \c HID_ENABLE_FEATURE_PROCESSING | ||||
|  *      and \c HID_INCLUDE_CONSTANT_DATA_ITEMS compile time tokens now have no effect. | ||||
|  *    - The \c USE_NONSTANDARD_DESCRIPTOR_NAMES compile time token has been removed - there are now separate \c USB_Descriptor_* | ||||
|  *      and \c USB_StdDescriptor_* structures for both the LUFA and standardized element naming conventions so that both may be used in | ||||
|  *      the one project. For existing projects using the standardized names, change all code to use the \c USB_StdDescriptor_* variants. | ||||
|  * | ||||
|  *  <b>Device Mode</b> | ||||
|  *    - The \c USE_NONSTANDARD_DESCRIPTOR_NAMES compile time token has been removed - there are now separate \c USB_Descriptor_* | ||||
|  *      and \c USB_StdDescriptor_* structures for both the LUFA and standardized element naming conventions so that both may be used in | ||||
|  *      the one project. For existing projects using the standardized names, change all code to use the \c USB_StdDescriptor_* variants. | ||||
|  * | ||||
|  *  \section Sec_Migration090810 Migrating from 090605 to 090810 | ||||
|  * | ||||
|  *  <b>All</b> | ||||
|  *    - The "Simple Scheduler" has been <i>deprecated</i>, as it was little more than an abstracted loop and caused much confusion. | ||||
|  *      User applications using the scheduler should switch to regular loops instead. The scheduler code will be removed in a future | ||||
|  *      release. | ||||
|  *    - The "Dynamic Memory Block Allocator" has been removed, as it was unused in (and unrelated to) the LUFA library and never | ||||
|  *      used in user applications. | ||||
|  * | ||||
|  *  <b>Non-USB Library Components</b> | ||||
|  *    - The \c ATTR_NOINLINE function attribute macro has been renamed to \ref ATTR_NO_INLINE to be in line with the rest of the function attribute | ||||
|  *      macro names. | ||||
|  * | ||||
|  *  <b>Library Demos</b> | ||||
|  *    - Most demos now have a corresponding Class Driver implementation, which uses the new internal library class drivers for the standard | ||||
|  *      USB classes. This allows for more rapid device and host development, and so should be used in preference to the low level APIs where | ||||
|  *      possible so that fixes to the class drivers propagate to all applications which use them automatically with each new LUFA release. | ||||
|  * | ||||
|  *  <b>Host Mode</b> | ||||
|  *    - The \c HIDParser.c module has moved from \c LUFA/Drivers/USB/Class/ to \c LUFA/Drivers/USB/Class/Host/. | ||||
|  *    - The \c USB_GetDeviceConfigDescriptor() function now requires the desired configuration index within the device as its first | ||||
|  *      parameter, to add support for multi-configuration devices. Existing code should use a configuration index of 1 to indicate the | ||||
|  *      first configuration descriptor within the device. | ||||
|  *    - The non-standard "Ready" host state has been removed. Existing \ref HOST_STATE_Configured code should be moved to the end of | ||||
|  *      the existing \ref HOST_STATE_Addressed state, and the existing HOST_STATE_Ready state code should be moved to the \ref HOST_STATE_Configured | ||||
|  *      state. | ||||
|  *    - The \c USB_IsConnected global has been removed, as it is too vague for general use. Test \ref USB_HostState explicitly to ensure the host is | ||||
|  *      in the desired state instead. | ||||
|  *    - The USB event names have been changed and their firing conditions changed to properly separate out Host mode events from Device mode | ||||
|  *      events. See the \ref Group_Events page for details on the new event names and firing conditions. | ||||
|  * | ||||
|  *  <b>Device Mode</b> | ||||
|  *    - The \ref CALLBACK_USB_GetDescriptor() function now takes an extra parameter to specify the descriptor's memory space so that | ||||
|  *      descriptors in mixed memory spaces can be used. The previous functionality can be returned by defining the \c USE_FLASH_DESCRIPTORS | ||||
|  *      token in the project makefile to fix all descriptors into FLASH space and remove the extra function parameter. | ||||
|  *    - The \c USB_IsSuspended global has been removed - test \ref USB_DeviceState against \ref DEVICE_STATE_Suspended instead. | ||||
|  *    - The \c USB_IsConnected global has been removed, as it is too vague for general use. Test \ref USB_DeviceState explicitly to ensure the device | ||||
|  *      is in the desired state instead. | ||||
|  *    - The VBUS events have been removed, as they are already exposed to the user via the \c USB_Connect and \c USB_Disconnect events. | ||||
|  *    - The USB event names have been changed and their firing conditions changed to properly separate out Host mode events from Device mode | ||||
|  *      events. See the \ref Group_Events page for details on the new event names and firing conditions. | ||||
|  * | ||||
|  *  \section Sec_Migration090605 Migrating from 090510 to 090605 | ||||
|  * | ||||
|  *  <b>Device Mode</b> | ||||
|  *    - Support for non-control data endpoint interrupts has been dropped due to many issues in the implementation. All existing | ||||
|  *      projects using interrupts on non-control endpoints should switch to polling. For control interrupts, the library can | ||||
|  *      manage the control endpoint via interrupts automatically by compiling with the \c INTERRUPT_CONTROL_ENDPOINT token defined. | ||||
|  *    - The \c DESCRIPTOR_ADDRESS() macro has been removed. User applications should use normal casts to obtain a descriptor's memory | ||||
|  *      address. | ||||
|  *    - The library events system has been rewritten, so that all macros have been removed to allow for clearer user code. See | ||||
|  *      \ref Group_Events for new API details. | ||||
|  *    - The \c STREAM_CALLBACK() macro has been removed. User applications should replace all instances of the macro with regular | ||||
|  *      function signatures of a function accepting no arguments and returning a \c uint8_t value. | ||||
|  *    - The \c Event_DeviceError() event no longer exists, as its sole caller (unlinked \c USB_GetDescriptor() function) now produces a | ||||
|  *      compilation error rather than a runtime error. The \c StdDescriptors.c file no longer exists as a result, and should be removed | ||||
|  *      from project makefiles. | ||||
|  *    - The \c USB_GetDescriptor() function has been renamed to \ref CALLBACK_USB_GetDescriptor() to be in line with the new \c CALLBACK_ | ||||
|  *      function prefixes for functions which <i>must</i> be implemented in the user application. | ||||
|  * | ||||
|  *  <b>Host Mode</b> | ||||
|  *    - Support for non-control data pipe interrupts has been dropped due to many issues in the implementation. All existing | ||||
|  *      projects using interrupts on non-control pipes should switch to polling. | ||||
|  *    - The library events system has been rewritten, so that all macros have been removed to allow for clearer user code. See | ||||
|  *      \ref Group_Events for new API details. | ||||
|  *    - The \c STREAM_CALLBACK() macro has been removed. User applications should replace all instances of the macro with regular | ||||
|  *      function signatures of a function accepting no arguments and returning a \c uint8_t value. | ||||
|  *    - The \c DESCRIPTOR_COMPARATOR() macro has been removed. User applications should replace all instances of the macro with | ||||
|  *      regular function signatures of a function accepting a void pointer to the descriptor to test, and returning a \c uint8_t value. | ||||
|  * | ||||
|  *  \section Sec_Migration090510 Migrating from 090401 to 090510 | ||||
|  * | ||||
|  *  <b>All</b> | ||||
|  *    - The \c ButtLoadTag.h header has been removed, as it was never used for its intended purpose. Projects should either remove all | ||||
|  *      \c BUTTLOADTAG() elements, or download and extract \c ButtLoadTag.h header from the ButtLoad project. | ||||
|  *    - The \c Drivers/AT90USBXXX/ directory has been renamed to \c Drivers/Peripheral/. | ||||
|  *    - The \c Serial_Stream driver has been renamed to \c SerialStream to remain consistent with the rest of the library naming scheme. | ||||
|  *    - The HWB driver has changed to the \c Buttons driver. See the board Buttons driver documentation for the new API. | ||||
|  * | ||||
|  *  <b>Dual Role Mode</b> | ||||
|  *    - The \c USB_PowerOnFail event has been renamed to \c USB_InitFailure. | ||||
|  *    - The functions in \c OTG.h have been renamed to remain more consistent with the library API. See the functions in \c OTG.h for more | ||||
|  *      details. | ||||
|  * | ||||
|  *  <b>Device Mode</b> | ||||
|  *    - The \c Endpoint_ClearCurrentBank() macro has been removed, and is now replaced with the \ref Endpoint_ClearIN(), \ref Endpoint_ClearOUT() | ||||
|  *      macros. See \c Endpoint.h documentation for more details on the new endpoint management macros. | ||||
|  *    - The \c Endpoint_ReadWriteAllowed() macro has been renamed to \ref Endpoint_IsReadWriteAllowed() to be more consistent with the rest of | ||||
|  *      the API naming scheme. | ||||
|  *    - The \c Endpoint_IsSetupINReady() and \c Endpoint_IsSetupOUTReceived() macros have been renamed to \ref Endpoint_IsINReady() and | ||||
|  *      \ref Endpoint_IsOUTReceived() respectively. | ||||
|  *    - The \c Endpoint_IsSetupReceived() macro has been renamed to \ref Endpoint_IsSETUPReceived(). | ||||
|  *    - The \c Endpoint_ClearSetupReceived() macro has been renamed to \ref Endpoint_ClearSETUP(). | ||||
|  *    - All endpoint read/write/discard aliases which did not have an explicitly endianness specifier (such as \c Endpoint_Read_Word()) have | ||||
|  *      been removed for clarity. Existing projects should use the \c _LE suffix on such calls to use the explicit Little Endian versions. | ||||
|  *    - The \c USB_UnhandledControlPacket event no longer has any parameters. User code should no longer attempt to read in the remainder of | ||||
|  *      the Control Request header as all Control Request header data is now preloaded by the library and made available in the | ||||
|  *      USB_ControlRequest structure. | ||||
|  *    - The \c FEATURELESS_CONTROL_ONLY_DEVICE token has been renamed to \c CONTROL_ONLY_DEVICE. | ||||
|  *    - The \c STATIC_ENDPOINT_CONFIGURATION is no longer applicable as the library will apply this optimization when appropriate automatically. | ||||
|  *    - The values of the \ref Endpoint_Stream_RW_ErrorCodes_t and \ref Endpoint_ControlStream_RW_ErrorCodes_t enums have had the \c ERROR_ portion | ||||
|  *      of their names removed. | ||||
|  * | ||||
|  *  <b>Host Mode</b> | ||||
|  *    - The \ref USB_Host_SendControlRequest() function no longer automatically selects the Control pipe (pipe 0) to allow it to be used on | ||||
|  *      other control type pipes. Care should be taken to ensure that the Control pipe is always selected before the function is called | ||||
|  *      in existing projects where the Control pipe is to be operated on. | ||||
|  *    - The USB Host management task now saves and restores the currently selected pipe before and after the task runs. Projects no longer | ||||
|  *      need to manage this manually when calling the USB management task. | ||||
|  *    - The \c Pipe_ClearCurrentBank() macro has been removed, and is now replaced with the Pipe_ClearIN(), Pipe_ClearOUT() macros. See | ||||
|  *      Pipe.h documentation for more details on the new pipe management macros. | ||||
|  *    - The \c Pipe_ReadWriteAllowed() macro has been renamed to \ref Pipe_IsReadWriteAllowed() to be more consistent with the rest of the API | ||||
|  *      naming scheme. | ||||
|  *    - The \c Pipe_IsSetupINReceived() and \c Pipe_IsOutReady() macros have been renamed to \ref Pipe_IsINReceived() and \ref Pipe_IsOUTReady() | ||||
|  *      respectively. | ||||
|  *    - The new \ref Pipe_ClearSETUP() macro should be used to send SETUP transactions, rather than the previous \c Pipe_ClearSetupOUT() macro. | ||||
|  *    - The \c Pipe_IsSetupSent() macro has been renamed to \ref Pipe_IsSETUPSent(). | ||||
|  *    - The \c Pipe_ClearSetupSent() macro is no longer applicable and should be removed. | ||||
|  *    - All pipe read/write/discard aliases which did not have an explicitly endianness specifier (such as \c Pipe_Read_Word()) have | ||||
|  *      been removed for clarity. Existing projects should use the \c _LE suffix on such calls to use the explicit Little Endian versions. | ||||
|  *    - The \c Host_IsResetBusDone() macro has been renamed to \c Host_IsBusResetComplete(). | ||||
|  *    - The \c Pipe_Ignore_Word() and \c Pipe_Ignore_DWord() functions have been renamed to \c Pipe_Discard_Word() and \c Pipe_Discard_DWord() | ||||
|  *      to remain consistent with the rest of the pipe API. | ||||
|  *    - It is no longer needed to manually include the headers from \c LUFA/Drivers/USB/Class, as they are now included along with the rest | ||||
|  *      of the USB headers when \c LUFA/Drivers/USB/USB.h is included. | ||||
|  *    - Functions in the \c ConfigDescriptor.h header file no longer have \c Host_ as part of their names. | ||||
|  *    - The \c ProcessHIDReport() has been renamed to \ref USB_ProcessHIDReport(), \c GetReportItemInfo() has been renamed to \ref USB_GetHIDReportItemInfo() | ||||
|  *      and \c SetReportItemInfo() has been renamed to \ref USB_GetHIDReportItemInfo(). | ||||
|  *    - The values of the \ref DSearch_Return_ErrorCodes_t and \ref DSearch_Comp_Return_ErrorCodes_t enums have had their respective \c Descriptor_Search | ||||
|  *      and \c Descriptor_Search_Comp prefixes changed to all caps. | ||||
|  *    - The \c USB_HostRequest global has been renamed to \ref USB_ControlRequest, and is used in Device mode also. The \c USB_Host_Request_Header_t | ||||
|  *      structure type has been renamed to \ref USB_Request_Header_t. | ||||
|  *    - The values of the \ref Pipe_Stream_RW_ErrorCodes_t enum have had the \c ERROR_ portion of their names removed. | ||||
|  * | ||||
|  *  \section Sec_Migration090401 Migrating from 090209 to 090401 | ||||
|  * | ||||
|  *  <b>All</b> | ||||
|  *    - LUFA projects must now give the raw input clock frequency (before any prescaling) as a compile time constant \c F_USB, | ||||
|  *      defined in the project makefile and passed to the compiler via the -D switch. | ||||
|  *    - The makefile EEPROM programming targets for FLIP and dfu-programmer no longer program in the FLASH data in addition to the | ||||
|  *      EEPROM data into the device. If both are to be programmed, both the EEPROM and FLASH programming targets must be called. | ||||
|  *    - As the avr-libc macro has been corrected in recent avr-libc distributions, the \c SetSystemClockPrescaler() macro has been removed. | ||||
|  *      Include \c <avr/power.h> and call \c clock_prescale_set(clock_div_1); instead on recent avr-libc distributions. | ||||
|  * | ||||
|  *  <b>Library Demos</b> | ||||
|  *    - The USBtoSerial demo now discards all data when not connected to a host, rather than buffering it for later transmission. | ||||
|  * | ||||
|  *  <b>Non-USB Library Components</b> | ||||
|  *    - The \c ATTR_ALWAYSINLINE function attribute macro has been renamed to \ref ATTR_ALWAYS_INLINE. | ||||
|  *    - Custom board Dataflash drivers now require the implementation of \ref Dataflash_SelectChipFromPage() and \ref Dataflash_SendAddressBytes(). | ||||
|  * | ||||
|  *  <b>Device Mode</b> | ||||
|  *    - The \c NO_CLEARSET_FEATURE_REQUEST compile time token has been renamed to \c FEATURELESS_CONTROL_ONLY_DEVICE, and its function expanded | ||||
|  *      to also remove parts of the Get Status chapter 9 request to further reduce code usage. On all applications currently using the | ||||
|  *      \c NO_CLEARSET_FEATURE_REQUEST compile time token, it can be replaced with the \c FEATURELESS_CONTROL_ONLY_DEVICE token with no further | ||||
|  *      modifications required. | ||||
|  * | ||||
|  *  \section Sec_Migration090209 Migrating from 081217 to 090209 | ||||
|  * | ||||
|  *  <b>Device Mode</b> | ||||
|  *    - The \c ENDPOINT_MAX_ENDPOINTS constant has been renamed to the more appropriate name of \c ENDPOINT_TOTAL_ENDPOINTS. | ||||
|  *    - The \c USB_STREAM_TIMEOUT_MS stream timeout default period has been extended to 100ms. This can be overridden in the user | ||||
|  *      makefile if desired to restore the previous 50ms timeout. | ||||
|  * | ||||
|  *  <b>Host Mode</b> | ||||
|  *    - The \c PIPE_MAX_ENDPOINTS constant has been renamed to the more appropriate name of \c PIPE_TOTAL_ENDPOINTS. | ||||
|  *    - The \c USB_STREAM_TIMEOUT_MS stream timeout default period has been extended to 100ms. This can be overridden in the user | ||||
|  *      makefile if desired to restore the previous 50ms timeout. | ||||
|  *    - The \c USB_DeviceEnumerationFailed event now contains a second \c SubErrorCode parameter, giving the error code of the function | ||||
|  *      which failed. | ||||
|  *    - The \c HID_PARSE_Sucessful enum member constant name has been corrected to \ref HID_PARSE_Successful. | ||||
|  * | ||||
|  *  <b>Non-USB Library Components</b> | ||||
|  *    - The previous \c SPI_SendByte() functionality is now located in \ref SPI_TransferByte(). \ref SPI_SendByte() now discards the return byte | ||||
|  *      for speed, to compliment the new \ref SPI_ReceiveByte() function. If bidirectional SPI transfers are required, calls to \ref SPI_SendByte() | ||||
|  *      should be changed to \ref SPI_TransferByte(). | ||||
|  *    - The serial driver now sets the Tx line as an output explicitly, and enables the pull-up of the Rx line. | ||||
|  *    - The \ref Serial_Init() and \c SerialStream_Init() functions now take a second \c DoubleSpeed parameter, which indicates if the USART | ||||
|  *      should be initialized in double speed mode - useful in some circumstances for attaining baud rates not usually possible at the given AVR | ||||
|  *      clock speed. | ||||
|  * | ||||
|  *  \section Sec_Migration171208 Migrating from V1.5.3 to 081217 | ||||
|  * | ||||
|  *  <b>All</b> | ||||
|  *    - The MyUSB project name has been changed to LUFA (Lightweight Framework for USB AVRs). All references to MyUSB, including macro names, | ||||
|  *      have been changed to LUFA. | ||||
|  * | ||||
|  *  <b>Library Demos</b> | ||||
|  *    - The ReconfigureUSART() routine in the USBtoSerial demo was not being called after new line encoding | ||||
|  *      parameters were set by the host. Projects built on the USBtoSerial code should update to the latest version. | ||||
|  *    - The HID Parser now supports multiple report (on a single endpoint) HID devices. The MouseHostWithParser and | ||||
|  *      KeyboardHostWithPaser demos use the updated API functions to function correctly on such devices. Projects | ||||
|  *      built on either "WithParser" demo should update to the latest code. | ||||
|  *    - The RNDIS demo TCP stack has been modified so that connections can be properly closed. It is still not | ||||
|  *      recommended that the MyUSB RNDIS demo TCP/IP stack be used for anything other than demonstration purposes, | ||||
|  *      as it is neither a full nor a standards compliant implementation. | ||||
|  * | ||||
|  *  <b>Non-USB Library Components</b> | ||||
|  *    - The Serial_IsCharReceived() macro has been changed to the correct spelling of Serial_IsCharReceived() in Serial.h. | ||||
|  * | ||||
|  *  <b>Device Mode</b> | ||||
|  *    - The MANUAL_PLL_CONTROL compile time token has been removed, and replaced with a USB_OPT_MANUAL_PLL mask | ||||
|  *      to be used in the Options parameter of the USB_Init() function. | ||||
|  *    - Calling USB_Init() now forces a complete USB interface reset and enumeration, even if the USB interface is | ||||
|  *      currently initialized. | ||||
|  *    - Interrupts are now disabled when processing control requests, to avoid problems with interrupts causing the library | ||||
|  *      or user request processing code to exceed the strict USB timing requirements on control transfers. | ||||
|  *    - The USB Reset event now resets and disables all device endpoints. If user code depends on endpoints remaining configured | ||||
|  *      after a Reset event, it should be altered to explicitly re-initialize all user endpoints. | ||||
|  *    - The prototype for the GetDescriptor function has been changed, as the return value was redundant. The function now | ||||
|  *      returns the size of the descriptor, rather than passing it back via a parameter, or returns NO_DESCRIPTOR if the specified | ||||
|  *      descriptor does not exist. | ||||
|  *    - The NO_DESCRIPTOR_STRING macro has been renamed NO_DESCRIPTOR, and is now also used as a possible return value for the | ||||
|  *      GetDescriptor function. | ||||
|  * | ||||
|  *  <b>Host Mode</b> | ||||
|  *    - The MANUAL_PLL_CONTROL compile time token has been removed, and replaced with a USB_OPT_MANUAL_PLL mask | ||||
|  *      to be used in the Options parameter of the USB_Init() function. | ||||
|  *    - The HID report parser now supports multiple Report IDs. The HID report parser GetReportItemInfo() and | ||||
|  *      SetReportItemInfo() routines now return a boolean, set if the requested report item was located in the | ||||
|  *      current report. If sending a report to a multi-report device, the first byte of the report is automatically | ||||
|  *      set to the report ID of the given report item. | ||||
|  *    - Calling USB_Init() now forces a complete USB interface reset and enumeration, even if the USB interface is | ||||
|  *      currently initialized. | ||||
|  * | ||||
|  *  \section Sec_Migration152 Migrating from V1.5.2 to V1.5.3 | ||||
|  * | ||||
|  *  <b>Library Demos</b> | ||||
|  *    - Previously, all demos contained a serial number string descriptor, filled with all zeros. A serial number | ||||
|  *      string is required in Mass Storage devices, or devices which are to retain settings when moved between | ||||
|  *      ports on a machine. As people were not changing the serial number value, this was causing conflicts and so | ||||
|  *      the serial number descriptor has been removed from all but the Mass Storage demo, which requires it. | ||||
|  *    - The AudioOut and AudioIn demos did not previously silence their endpoints when the host has deactivated | ||||
|  *      them. Projects built upon either demo should upgrade to the latest code. | ||||
|  *    - The FEATURE_ENDPOINT macro has been renamed FEATURE_ENDPOINT_HALT, and is now correctly documented. | ||||
|  *    - The MassStoreHost demo contained errors which caused it to lock up randomly on certain devices. Projects built | ||||
|  *      on the MassStoreDemo code should update to the latest version. | ||||
|  *    - The Interrupt type endpoint in the CDC based demos previously had a polling interval of 0x02, which caused | ||||
|  *      problems on some Linux systems. This has been changed to 0xFF, projects built on the CDC demos should upgrade | ||||
|  *      to the latest code. | ||||
|  *    - The HID keyboard and mouse demos were not previously boot mode compatible. To enable boot mode support, projects | ||||
|  *      built on the keyboard or mouse demos (or derivatives) should upgrade to the latest code. | ||||
|  *    - The Mass Storage demo was not previously standards compliant. Projects built on the Mass Storage demo should | ||||
|  *      upgrade to the latest code. | ||||
|  *    - The USART was not being reconfigured after the host sent new encoding settings in the USBtoSerial demo. This was | ||||
|  *      previously discovered and fixed, but the change was lost. Projects built on the USBtoSerial demo should update | ||||
|  *      to the latest code. | ||||
|  * | ||||
|  *  <b>Device Mode</b> | ||||
|  *    - The endpoint non-control stream functions now have a default timeout of 50ms between packets in the stream. | ||||
|  *      If this timeout is exceeded, the function returns the new ENDPOINT_RWSTREAM_ERROR_Timeout error value. The | ||||
|  *      timeout value can be overridden by defining the USB_STREAM_TIMEOUT_MS in the project makefile to the desired | ||||
|  *      timeout duration in ms. | ||||
|  *    - Rather than returning fixed values, the flags indicating if the device has Remote Wakeup currently enabled | ||||
|  *      and/or is self-powered are now accessed and set through the new USB_RemoteWakeupEnabled and | ||||
|  *      USB_CurrentlySelfPowered macros. See the DevChapter9.h documentation for more details. | ||||
|  *    - All endpoint stream functions now require an extra Callback function parameter. Existing code may be updated | ||||
|  *      to either supply NO_STREAM_CALLBACK as the extra parameter, or disable stream callbacks altogether by passing | ||||
|  *      the token NO_STREAM_CALLBACKS to the compiler using the -D switch. | ||||
|  * | ||||
|  *  <b>Host Mode</b> | ||||
|  *    - The pipe non-control stream functions now have a default timeout of 50ms between packets in the stream. | ||||
|  *      If this timeout is exceeded, the function returns the new PIPE_RWSTREAM_ERROR_Timeout error value. The | ||||
|  *      timeout value can be overridden by defining the USB_STREAM_TIMEOUT_MS in the project makefile to the desired | ||||
|  *      timeout duration in ms. | ||||
|  *    - CollectionPath_t has been renamed to HID_CollectionPath_t to be more in line with the other HID parser structures. | ||||
|  *    - All pipe stream functions now require an extra Callback function parameter. Existing code may be updated | ||||
|  *      to either supply NO_STREAM_CALLBACK as the extra parameter, or disable stream callbacks altogether by passing | ||||
|  *      the token NO_STREAM_CALLBACKS to the compiler using the -D switch. | ||||
|  * | ||||
|  *  \section Sec_Migration151 Migrating from V1.5.1 to V1.5.2 | ||||
|  * | ||||
|  *  <b>Library Demos</b> | ||||
|  *    - The RNDIS demo application has been updated so that it is functional on Linux under earlier implementations | ||||
|  *      of the RNDIS specification, which had non-standard behaviour. Projects built upon the demo should upgrade | ||||
|  *      to the latest code. | ||||
|  *    - The DFU class bootloader has had several bugs corrected in this release. It is recommended that where | ||||
|  *      possible any existing devices upgrade to the latest bootloader code. | ||||
|  * | ||||
|  *  \section Sec_Migration150 Migrating from V1.5.0 to V1.5.1 | ||||
|  * | ||||
|  *  <b>Library Demos</b> | ||||
|  *    - The USBtoSerial demo was broken in the 1.5.0 release, due to incorrect register polling in place of the | ||||
|  *      global "Transmitting" flag. The change has been reverted in this release. Projects built upon the demo | ||||
|  *      should upgrade to the latest code. | ||||
|  *    - The HID class demos did not implement the mandatory GetReport HID class request. Projects built upon the HID | ||||
|  *      demos should upgrade to the latest code. | ||||
|  *    - The HID class demos incorrectly reported themselves as boot-protocol enabled HID devices in their descriptors. | ||||
|  *      Projects built upon the HID demos should upgrade to the latest code. | ||||
|  *    - The MIDI device demo had incorrect AudioStreaming interface descriptors. Projects built upon the MIDI demo | ||||
|  *      should upgrade to the latest code. | ||||
|  *    - The AudioOut demo did not correctly tristate the speaker pins when USB was disconnected, wasting power. | ||||
|  *      Projects built upon the AudioOut demo should upgrade to the latest code. | ||||
|  * | ||||
|  *  \section Sec_Migration141 Migrating from V1.4.1 to V1.5.0 | ||||
|  * | ||||
|  *  <b>Library Demos</b> | ||||
|  *    - Previous versions of the library demos had incorrectly encoded BCD version numbers in the descriptors. To | ||||
|  *      avoid such mistakes in the future, the VERSION_BCD macro has been added to StdDescriptors.h. Existing | ||||
|  *      projects should at least manually correct the BCD version numbers, or preferably update the descriptors to | ||||
|  *      encode the version number in BCD format using the new macro. | ||||
|  *    - The mandatory GetReport class-specific request was accidentally omitted from previous versions of the demos | ||||
|  *      based on the Human Interface Device (HID) class. This has been corrected, and any user projects based on the | ||||
|  *      HID demos should also be updated accordingly. | ||||
|  *    - The CDC demos now correctly send an empty packet directly after a full packet, to end the transmission. | ||||
|  *      Failure to do this on projects which always or frequently send full packets will cause buffering issues on | ||||
|  *      the host OS. All CDC user projects are advised to update their transmission routines in the same manner as | ||||
|  *      the library CDC demos. | ||||
|  *    - The previous interrupt-driven Endpoint/Pipe demos did not properly save and restore the currently selected | ||||
|  *      Endpoint/Pipe when the ISR fired. This has been corrected - user projects based on the interrupt driven | ||||
|  *      demos should also update to properly save and restore the selected Endpoint/Pipe. | ||||
|  * | ||||
|  *  <b>Non-USB Library Components</b> | ||||
|  *    - The Atomic.h and ISRMacro.h header files in MyUSB/Common have been removed, as the library is now only | ||||
|  *      compatible with avr-libc library versions newer than the time before the functionality of the deleted | ||||
|  *      headers was available. | ||||
|  * | ||||
|  *  <b>Device Mode</b> | ||||
|  *    - The GetDescriptor function (see StdDescriptors.h) now has a new prototype, with altered parameter names and | ||||
|  *      functions. Existing projects will need to update the GetDescriptor implementation to reflect the new API. | ||||
|  *      The previously split Type and Index parameters are now passed as the original wValue parameter to the | ||||
|  *      function, to make way for the USB specification wIndex parameter which is <i>not</i> the same as the | ||||
|  *      previous Index parameter. | ||||
|  *    - The USB_UnhandledControlPacket event (see Events.h) now has new parameter names, to be in line with the | ||||
|  *      official USB specification. Existing code will need to be altered to use the new parameter names. | ||||
|  *    - The USB_CreateEndpoints event (see Events.h) has been renamed to USB_ConfigurationChanged, which is more | ||||
|  *      appropriate. It fires in an identical manner to the previously named event, thus the only change to be made | ||||
|  *      is the event name itself in the user project. | ||||
|  *    - The USB_Descriptor_Language_t structure no longer exists in StdDescriptors.h, as this was a | ||||
|  *      pseudo-descriptor modeled on the string descriptor. It is replaced by the true USB_Descriptor_String_t type | ||||
|  *      descriptor as indicated in the USB specification, thus all device code must be updated accordingly. | ||||
|  *    - The names of several Endpoint macros have been changed to be more consistent with the rest of the library, | ||||
|  *      with no implementation changes. This means that existing code can be altered to use the new macro names | ||||
|  *      with no other considerations required. See Endpoint.h for the new macro names. | ||||
|  *    - The previous version of the MassStorage demo had an incorrect value in the SCSI_Request_Sense_Response_t | ||||
|  *      structure named SenseData in SCSI.c which caused some problems with some hosts. User projects based on this | ||||
|  *      demo should correct the structure value to maintain compatibility across multiple OS platforms. | ||||
|  *    - By default, the descriptor structures use the official USB specification names for the elements. Previous | ||||
|  *      versions of the library used non-standard (but more verbose) names, which are still usable in the current | ||||
|  *      and future releases when the correct compile time option is enabled. See the StdDescriptors.h file | ||||
|  *      documentation for more details. | ||||
|  * | ||||
|  *  <b>Host Mode</b> | ||||
|  *    - The USB_Host_Request_Header_t structure in HostChapter9.h (used for issuing control requests) has had its | ||||
|  *      members renamed to the official USB specification names for requests. Existing code will need to be updated | ||||
|  *      to use the new names. | ||||
|  *    - The names of several Pipe macros have been changed to be more consistent with the rest of the library, | ||||
|  *      with no implementation changes. This means that existing code can be altered to use the new macro names | ||||
|  *      with no other considerations required. See Pipe.h for the new macro names. | ||||
|  *    - By default, the descriptor structures use the official USB specification names for the elements. Previous | ||||
|  *      versions of the library used non-standard (but more verbose) names, which are still usable in the current | ||||
|  *      and future releases when the correct compile time option is enabled. See the StdDescriptors.h file | ||||
|  *      documentation for more details. | ||||
|  *    - The names of the macros in Host.h for controlling the SOF generation have been renamed, see the Host.h | ||||
|  *      module documentation for the new macro names. | ||||
|  * | ||||
|  *  <b>Dual Role Mode</b> | ||||
|  *    - The OTG.h header file has been corrected so that the macros now perform their stated functions. Any existing | ||||
|  *      projects using custom headers to fix the broken OTG header should now be altered to once again use the OTG | ||||
|  *      header inside the library. | ||||
|  *    - The USB_DeviceEnumerationComplete event (see Events.h) now also fires in Device mode, when the host has | ||||
|  *      finished enumerating the device. Projects relying on the event only firing in Host mode should be updated | ||||
|  *      so that the event action only occurs when the USB_Mode global is set to USB_MODE_HOST. | ||||
|  */ | ||||
| 
 | ||||
							
								
								
									
										111
									
								
								LUFA/DoxygenPages/OSDrivers.txt
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										111
									
								
								LUFA/DoxygenPages/OSDrivers.txt
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,111 @@ | |||
| /** \file | ||||
|  * | ||||
|  *  This file contains special DoxyGen information for the generation of the main page and other special | ||||
|  *  documentation pages. It is not a project source file. | ||||
|  */ | ||||
| 
 | ||||
| /** \page Page_OSDrivers Operating System Drivers | ||||
|  * | ||||
|  *  Most of the USB classes supported by LUFA are also supported natively in | ||||
|  *  most operating systems, without extra drivers being required. However, in | ||||
|  *  some cases, a driver file is required in order for the device to enumerate | ||||
|  *  and function correctly. | ||||
|  * | ||||
|  *  \section Sec_OSClassSupport Operating System USB Class Support | ||||
|  *  The table below lists the supported LUFA USB classes, and their associated | ||||
|  *  <i>native</i> support on modern operating systems. | ||||
|  * | ||||
|  *  <table> | ||||
|  *  <tr> | ||||
|  *   <th width="200px">USB Class</th> | ||||
|  *   <th width="150px">Android</th> | ||||
|  *   <th width="150px">Windows</th> | ||||
|  *   <th width="150px">Linux</th> | ||||
|  *   <th width="150px">OS X</th> | ||||
|  *  </tr> | ||||
|  *  <tr> | ||||
|  *   <td>Android Open Accessory</td> | ||||
|  *   <td>2.3.4+</td> | ||||
|  *   <td>N/A</td> | ||||
|  *   <td>N/A</td> | ||||
|  *   <td>N/A</td> | ||||
|  *  </tr> | ||||
|  *  <tr> | ||||
|  *   <td>Audio 1.0</td> | ||||
|  *   <td>N/A</td> | ||||
|  *   <td>XP+</td> | ||||
|  *   <td>2.6.?+</td> | ||||
|  *   <td>10.?+</td> | ||||
|  *  </tr> | ||||
|  *  <tr> | ||||
|  *   <td>CDC-ACM</td> | ||||
|  *   <td>N/A</td> | ||||
|  *   <td>XP+</td> | ||||
|  *   <td>2.6.?+</td> | ||||
|  *   <td>10.?+</td> | ||||
|  *  </tr> | ||||
|  *  <tr> | ||||
|  *   <td>HID</td> | ||||
|  *   <td>3.?+</td> | ||||
|  *   <td>XP+</td> | ||||
|  *   <td>2.6.?+</td> | ||||
|  *   <td>10.?+</td> | ||||
|  *  </tr> | ||||
|  *  <tr> | ||||
|  *   <td>MIDI</td> | ||||
|  *   <td>N/A</td> | ||||
|  *   <td>XP+</td> | ||||
|  *   <td>2.6.?+</td> | ||||
|  *   <td>10.?+</td> | ||||
|  *  </tr> | ||||
|  *  <tr> | ||||
|  *   <td>Mass Storage</td> | ||||
|  *   <td>N/A</td> | ||||
|  *   <td>XP+</td> | ||||
|  *   <td>2.6.?+</td> | ||||
|  *   <td>10.?+</td> | ||||
|  *  </tr> | ||||
|  *  <tr> | ||||
|  *   <td>Printer</td> | ||||
|  *   <td>N/A</td> | ||||
|  *   <td>XP+</td> | ||||
|  *   <td>2.6.?+</td> | ||||
|  *   <td>10.?+</td> | ||||
|  *  </tr> | ||||
|  *  <tr> | ||||
|  *   <td>RNDIS</td> | ||||
|  *   <td>N/A</td> | ||||
|  *   <td>XP+</td> | ||||
|  *   <td>2.6.?+</td> | ||||
|  *   <td>N/A</td> | ||||
|  *  </tr> | ||||
|  *  <tr> | ||||
|  *   <td>Still Image</td> | ||||
|  *   <td>N/A</td> | ||||
|  *   <td>XP+</td> | ||||
|  *   <td>2.6.?+</td> | ||||
|  *   <td>10.?+</td> | ||||
|  *  </tr> | ||||
|  *  </table> | ||||
|  * | ||||
|  *  \section Sec_WinINFTemplates Windows INF Drivers | ||||
|  *  Windows uses INF driver files to associate a USB device of a specific class, | ||||
|  *  VID/PID ID pair, Windows Compatibility ID or other characteristic to a kernel | ||||
|  *  driver. In most cases these files are build into the operating system, and | ||||
|  *  no special user action or driver files are required for a device using a | ||||
|  *  standard USB class to enumerate. However, for some classes, a specific INF | ||||
|  *  driver must be created and given to the operating system for the device to | ||||
|  *  enumerate. | ||||
|  * | ||||
|  *  Those USB classes requiring a custom INF driver file in Windows are listed | ||||
|  *  below, along with a basic INF template for each class. | ||||
|  * | ||||
|  *  \subsection SSec_WinINF_CDC Windows CDC INF Template | ||||
|  *  This template is required for all CDC-ACM devices on Windows XP or newer. | ||||
|  *  \verbinclude "WindowsINF/LUFA CDC-ACM.inf" | ||||
|  * | ||||
|  *  \subsection SSec_WinINF_RNDIS Windows RNDIS INF Template | ||||
|  *  This template is required for all RNDIS devices on Windows XP or newer. | ||||
|  *  \verbinclude "WindowsINF/LUFA RNDIS.inf" | ||||
|  */ | ||||
| 
 | ||||
							
								
								
									
										27
									
								
								LUFA/DoxygenPages/ProgrammingApps.txt
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										27
									
								
								LUFA/DoxygenPages/ProgrammingApps.txt
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,27 @@ | |||
| /** \file | ||||
|  * | ||||
|  *  This file contains special DoxyGen information for the generation of the main page and other special | ||||
|  *  documentation pages. It is not a project source file. | ||||
|  */ | ||||
| 
 | ||||
| /** \page Page_ProgrammingApps Programming an Application into a USB AVR | ||||
|  * | ||||
|  *  Once you have built an application, you will need a way to program in the resulting ".HEX" file (and, if your | ||||
|  *  application uses EEPROM variables with initial values, also a ".EEP" file) into your USB AVR. Normally, the | ||||
|  *  reprogramming of an AVR device must be performed using a special piece of programming hardware, through one of the | ||||
|  *  supported AVR programming protocols - ISP, HVSP, HVPP, JTAG, dW or PDI. This can be done through a custom programmer, | ||||
|  *  a third party programmer, or an official Atmel AVR tool - for more information, see the <a>atmel.com</a> website. | ||||
|  * | ||||
|  *  Alternatively, you can use the bootloader. From the Atmel factory, each USB AVR comes preloaded with the Atmel | ||||
|  *  DFU (Device Firmware Update) class bootloader, a small piece of AVR firmware which allows the remainder of the | ||||
|  *  AVR to be programmed through a non-standard interface such as the serial USART port, SPI, or (in this case) USB. | ||||
|  *  Bootloaders have the advantage of not requiring any special hardware for programming, and cannot usually be erased | ||||
|  *  or broken without an external programming device. They have disadvantages however; they cannot change the fuses of | ||||
|  *  the AVR (special configuration settings that control the operation of the chip itself) and a small portion of the | ||||
|  *  AVR's FLASH program memory must be reserved to contain the bootloader firmware, and thus cannot be used by the | ||||
|  *  loaded application. | ||||
|  * | ||||
|  *  If you wish to use the DFU bootloader to program in your application, refer to your DFU programmer's documentation. | ||||
|  *  Atmel provides a free utility called FLIP which is USB AVR compatible, and an open source (Linux compatible) | ||||
|  *  alternative exists called "dfu-programmer". | ||||
|  */ | ||||
							
								
								
									
										71
									
								
								LUFA/DoxygenPages/SoftwareBootloaderJump.txt
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										71
									
								
								LUFA/DoxygenPages/SoftwareBootloaderJump.txt
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,71 @@ | |||
| /** \file | ||||
|  * | ||||
|  *  This file contains special DoxyGen information for the generation of the main page and other special | ||||
|  *  documentation pages. It is not a project source file. | ||||
|  */ | ||||
| 
 | ||||
| /** | ||||
|  *  \page Page_SoftwareBootloaderStart Entering the Bootloader via Software | ||||
|  * | ||||
|  *  A common requirement of many applications is the ability to jump to the programmed bootloader of a chip | ||||
|  *  on demand, via the code's firmware (i.e. not as a result of any physical user interaction with the | ||||
|  *  hardware). This might be required because the device does not have any physical user input, or simply | ||||
|  *  just to streamline the device upgrade process on the host PC. | ||||
|  * | ||||
|  *  The following C code snippets may be used to enter the bootloader upon request by the user application. | ||||
|  *  By using the watchdog to physically reset the controller, it is ensured that all system hardware is | ||||
|  *  completely reset to their defaults before the bootloader is run. This is important; since bootloaders | ||||
|  *  are written to occupy a very limited space, they usually make assumptions about the register states based | ||||
|  *  on the default values after a hard-reset of the chip. | ||||
|  * | ||||
|  *  \section Sec_SoftareBootAVR8 AVR8 Architecture | ||||
|  *  The following software bootloader jump code is written for the AVR8 architecture. | ||||
|  * | ||||
|  *  \code | ||||
|  *  #include <avr/wdt.h> | ||||
|  *  #include <avr/io.h> | ||||
|  *  #include <util/delay.h> | ||||
|  * | ||||
|  *  #include <LUFA/Common/Common.h> | ||||
|  *  #include <LUFA/Drivers/USB/USB.h> | ||||
|  * | ||||
|  *  uint32_t Boot_Key ATTR_NO_INIT; | ||||
|  * | ||||
|  *  #define MAGIC_BOOT_KEY            0xBADCAFE5 | ||||
|  *  #define BOOTLOADER_START_ADDRESS  ((FLASH_SIZE_BYTES - BOOTLOADER_SEC_SIZE_BYTES) >> 1) | ||||
|  * | ||||
|  *  void Bootloader_Jump_Check(void) ATTR_INIT_SECTION(3); | ||||
|  *  void Bootloader_Jump_Check(void) | ||||
|  *  { | ||||
|  *      // If the reset source was the bootloader and the key is correct, clear it and jump to the bootloader | ||||
|  *      if ((MCUSR & (1 << WDRF)) && (Boot_Key == MAGIC_BOOT_KEY)) | ||||
|  *      { | ||||
|  *          Boot_Key = 0; | ||||
|  *          ((void (*)(void))BOOTLOADER_START_ADDRESS)(); | ||||
|  *      } | ||||
|  *  } | ||||
|  * | ||||
|  *  void Jump_To_Bootloader(void) | ||||
|  *  { | ||||
|  *      // If USB is used, detach from the bus and reset it | ||||
|  *      USB_Disable(); | ||||
|  * | ||||
|  *      // Disable all interrupts | ||||
|  *      cli(); | ||||
|  * | ||||
|  *      // Wait two seconds for the USB detachment to register on the host | ||||
|  *      Delay_MS(2000); | ||||
|  * | ||||
|  *      // Set the bootloader key to the magic value and force a reset | ||||
|  *      Boot_Key = MAGIC_BOOT_KEY; | ||||
|  *      wdt_enable(WDTO_250MS); | ||||
|  *      for (;;); | ||||
|  *  } | ||||
|  *  \endcode | ||||
|  * | ||||
|  *  Note that the bootloader magic key can be any arbitrary value. The <em>FLASH_SIZE_BYTES</em> and | ||||
|  *  <em>BOOTLOADER_SEC_SIZE_BYTES</em> tokens should be replaced with the total flash size of the AVR | ||||
|  *  in bytes, and the allocated size of the bootloader section for the target AVR. | ||||
|  * | ||||
|  */ | ||||
| 
 | ||||
							
								
								
									
										35
									
								
								LUFA/DoxygenPages/Style/Footer.htm
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										35
									
								
								LUFA/DoxygenPages/Style/Footer.htm
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,35 @@ | |||
| <!--BEGIN GENERATE_TREEVIEW--> | ||||
| 	<div id="nav-path" class="navpath"><!-- id is needed for treeview function! --> | ||||
| 		<ul> | ||||
| 			<li class="footer" style="float:left !important;"> | ||||
| 				$generatedby | ||||
| 				<a href="http://www.doxygen.org/index.html"> | ||||
| 					<img class="footer" src="$relpath$doxygen.png" alt="doxygen"/> | ||||
| 				</a> | ||||
| 				$doxygenversion | ||||
| 			</li> | ||||
| 
 | ||||
| 			<li class="footer"> | ||||
| 				<a href="http://www.lufa-lib.org" title="LUFA Project Page">LUFA Project Page</a> | <a href="http://www.lufa-lib.org/support" title="LUFA Support List">Support Mailing List</a> | <a href="http://www.lufa-lib.org/donate" title="Donate to Support LUFA">Donate</a> | <a href="http://www.fourwalledcubicle.com" title="Four Walled Cubicle Website">Four Walled Cubicle</a> - LUFA, the Lightweight USB Framework for AVRs | ||||
| 			</li> | ||||
| 		</ul> | ||||
| 	</div> | ||||
| <!--END GENERATE_TREEVIEW--> | ||||
| <!--BEGIN !GENERATE_TREEVIEW--> | ||||
| 		<hr class="footer"/> | ||||
| 		<div class="footer"> | ||||
| 			<span style="float: left;"> | ||||
| 				$generatedby | ||||
| 				<a href="http://www.doxygen.org/index.html"> | ||||
| 					<img class="footer" src="$relpath$doxygen.png" alt="doxygen"/> | ||||
| 				</a> | ||||
| 				$doxygenversion | ||||
| 			</span> | ||||
| 
 | ||||
| 			<span style="margin-right: 20px; float: right;"> | ||||
| 				<a href="http://www.lufa-lib.org" title="LUFA Project Page">LUFA Project Page</a> | <a href="http://www.lufa-lib.org/support" title="LUFA Support List">Support Mailing List</a> | <a href="http://www.lufa-lib.org/donate" title="Donate to Support LUFA">Donate</a> | <a href="http://www.fourwalledcubicle.com" title="Four Walled Cubicle Website">Four Walled Cubicle</a> - LUFA, the Lightweight USB Framework for AVRs | ||||
| 			</span> | ||||
| 		</div> | ||||
| <!--END !GENERATE_TREEVIEW--> | ||||
| 	</body> | ||||
| </html> | ||||
							
								
								
									
										93
									
								
								LUFA/DoxygenPages/Style/Style.css
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										93
									
								
								LUFA/DoxygenPages/Style/Style.css
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,93 @@ | |||
| /* ============================= */ | ||||
| /*    Page Header Formattings    */ | ||||
| /* ============================= */ | ||||
| #titlearea { | ||||
| 	background-color:#E1E7F4; | ||||
| 	background-image:url('nav_f.png'); | ||||
| 	background-repeat:repeat-x; | ||||
| 	color:#20335A; | ||||
| 	font-weight:bold; | ||||
| 	text-shadow:0 1px 1px rgba(255, 255, 255, 0.9); | ||||
| } | ||||
| 
 | ||||
| #projectlogo { | ||||
| 	padding-left: 10px; | ||||
| } | ||||
| 
 | ||||
| /* ============================= */ | ||||
| /*    General Text Formattings   */ | ||||
| /* ============================= */ | ||||
| body,table,div,p,dl { | ||||
| 	font-family:Lucida Grande, Verdana, Geneva, Arial, sans-serif; | ||||
| 	font-size:13px; | ||||
| 	line-height:1.3; | ||||
| } | ||||
| 
 | ||||
| div.header, div.contents p { | ||||
| 	padding-left:12px; | ||||
| } | ||||
| 
 | ||||
| /* ============================= */ | ||||
| /* API Documentation Formattings */ | ||||
| /* ============================= */ | ||||
| div.contents table.memberdecls, .paramname { | ||||
| 	font-family:Consolas, Monaco, courier, sans-serif; | ||||
| 	font-size:105%; | ||||
| 	padding-right:20px; | ||||
| } | ||||
| 
 | ||||
| /* ============================= */ | ||||
| /*    HTML Heading Formattings   */ | ||||
| /* ============================= */ | ||||
| h1, h2, h3, h4 { | ||||
| 	font-family:Lucida Grande, Verdana, Geneva, Arial, sans-serif; | ||||
| } | ||||
| 
 | ||||
| h1 { | ||||
| 	font-size:25px; | ||||
| 	margin-bottom:10px; | ||||
| } | ||||
| 
 | ||||
| h2 { | ||||
| 	color:#42657B; | ||||
| 	font-size:17px; | ||||
| } | ||||
| 
 | ||||
| h3 { | ||||
| 	font-size:15px; | ||||
| } | ||||
| 
 | ||||
| h4 { | ||||
| 	font-size:13px; | ||||
| } | ||||
| 
 | ||||
| /* ============================= */ | ||||
| /*    Code Snippet Formattings   */ | ||||
| /* ============================= */ | ||||
| span.keyword { | ||||
| 	color:#008000; | ||||
| } | ||||
| 
 | ||||
| span.keywordtype { | ||||
| 	color:#604020; | ||||
| } | ||||
| 
 | ||||
| span.keywordflow { | ||||
| 	color:#e08000; | ||||
| } | ||||
| 
 | ||||
| span.comment { | ||||
| 	color:#008000; | ||||
| } | ||||
| 
 | ||||
| span.preprocessor { | ||||
| 	color:#806020; | ||||
| } | ||||
| 
 | ||||
| span.stringliteral { | ||||
| 	color:#002080; | ||||
| } | ||||
| 
 | ||||
| span.charliteral { | ||||
| 	color:#008080; | ||||
| } | ||||
							
								
								
									
										199
									
								
								LUFA/DoxygenPages/VIDAndPIDValues.txt
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										199
									
								
								LUFA/DoxygenPages/VIDAndPIDValues.txt
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,199 @@ | |||
| /** \file | ||||
|  * | ||||
|  *  This file contains special DoxyGen information for the generation of the main page and other special | ||||
|  *  documentation pages. It is not a project source file. | ||||
|  */ | ||||
| 
 | ||||
| /** \page Page_VIDPID VID and PID values | ||||
|  * | ||||
|  *  \section Sec_VIDPID_Allocations VID and PID Allocations | ||||
|  *  The LUFA library uses VID/PID combinations generously donated by Atmel. The following VID/PID combinations | ||||
|  *  are used within the LUFA demos, and thus may be re-used by derivations of each demo. Free PID values may be | ||||
|  *  used by future LUFA demo projects. | ||||
|  * | ||||
|  *  <b>These VID/PID values should not be used in commercial designs under any circumstances.</b> Private projects | ||||
|  *  may use the following values freely, but must accept any collisions due to other LUFA derived private projects | ||||
|  *  sharing identical values. It is suggested that private projects using interfaces compatible with existing | ||||
|  *  demos share the same VID/PID value. | ||||
|  * | ||||
|  *  <table> | ||||
|  *   <tr> | ||||
|  *    <th>VID</th> | ||||
|  *    <th>PID</th> | ||||
|  *    <th>Usage</th> | ||||
|  *   </tr> | ||||
|  *   <tr> | ||||
|  *    <td>0x03EB</td> | ||||
|  *    <td>0x2040</td> | ||||
|  *    <td>Test VID/PID (See \ref Sec_Test_VIDPID)</td> | ||||
|  *   </tr> | ||||
|  *   <tr> | ||||
|  *    <td>0x03EB</td> | ||||
|  *    <td>0x2041</td> | ||||
|  *    <td>Mouse Demo Application</td> | ||||
|  *   </tr> | ||||
|  *   <tr> | ||||
|  *    <td>0x03EB</td> | ||||
|  *    <td>0x2042</td> | ||||
|  *    <td>Keyboard Demo Application</td> | ||||
|  *   </tr> | ||||
|  *   <tr> | ||||
|  *    <td>0x03EB</td> | ||||
|  *    <td>0x2043</td> | ||||
|  *    <td>Joystick Demo Application</td> | ||||
|  *   </tr> | ||||
|  *   <tr> | ||||
|  *    <td>0x03EB</td> | ||||
|  *    <td>0x2044</td> | ||||
|  *    <td>CDC Demo Application</td> | ||||
|  *   </tr> | ||||
|  *   <tr> | ||||
|  *    <td>0x03EB</td> | ||||
|  *    <td>0x2045</td> | ||||
|  *    <td>Mass Storage Demo Application</td> | ||||
|  *   </tr> | ||||
|  *   <tr> | ||||
|  *    <td>0x03EB</td> | ||||
|  *    <td>0x2046</td> | ||||
|  *    <td>Audio Output Demo Application</td> | ||||
|  *   </tr> | ||||
|  *   <tr> | ||||
|  *    <td>0x03EB</td> | ||||
|  *    <td>0x2047</td> | ||||
|  *    <td>Audio Input Demo Application</td> | ||||
|  *   </tr> | ||||
|  *   <tr> | ||||
|  *    <td>0x03EB</td> | ||||
|  *    <td>0x2048</td> | ||||
|  *    <td>MIDI Demo Application</td> | ||||
|  *   </tr> | ||||
|  *   <tr> | ||||
|  *    <td>0x03EB</td> | ||||
|  *    <td>0x2049</td> | ||||
|  *    <td>MagStripe Project</td> | ||||
|  *   </tr> | ||||
|  *   <tr> | ||||
|  *    <td>0x03EB</td> | ||||
|  *    <td>0x204A</td> | ||||
|  *    <td>CDC Class Bootloader</td> | ||||
|  *   </tr> | ||||
|  *   <tr> | ||||
|  *    <td>0x03EB</td> | ||||
|  *    <td>0x204B</td> | ||||
|  *    <td>USB to Serial Demo Application</td> | ||||
|  *   </tr> | ||||
|  *   <tr> | ||||
|  *    <td>0x03EB</td> | ||||
|  *    <td>0x204C</td> | ||||
|  *    <td>RNDIS Demo Application</td> | ||||
|  *   </tr> | ||||
|  *   <tr> | ||||
|  *    <td>0x03EB</td> | ||||
|  *    <td>0x204D</td> | ||||
|  *    <td>Combined Keyboard and Mouse Demo Application</td> | ||||
|  *   </tr> | ||||
|  *   <tr> | ||||
|  *    <td>0x03EB</td> | ||||
|  *    <td>0x204E</td> | ||||
|  *    <td>Dual CDC Demo Application</td> | ||||
|  *   </tr> | ||||
|  *   <tr> | ||||
|  *    <td>0x03EB</td> | ||||
|  *    <td> | ||||
|  *     0x204F | ||||
|  *    </td> | ||||
|  *    <td>Generic HID Demo Application</td> | ||||
|  *   </tr> | ||||
|  *   <tr> | ||||
|  *    <td>0x03EB</td> | ||||
|  *    <td>0x2060</td> | ||||
|  *    <td>Benito Programmer Project</td> | ||||
|  *   </tr> | ||||
|  *   <tr> | ||||
|  *    <td>0x03EB</td> | ||||
|  *    <td>0x2061</td> | ||||
|  *    <td>Combined Mass Storage and Keyboard Demo</td> | ||||
|  *   </tr> | ||||
|  *   <tr> | ||||
|  *    <td>0x03EB</td> | ||||
|  *    <td>0x2062</td> | ||||
|  *    <td>Combined CDC and Mouse Demo</td> | ||||
|  *   </tr> | ||||
|  *   <tr> | ||||
|  *    <td>0x03EB</td> | ||||
|  *    <td>0x2063</td> | ||||
|  *    <td>Mass Storage/HID Interface Datalogger Project</td> | ||||
|  *   </tr> | ||||
|  *   <tr> | ||||
|  *    <td>0x03EB</td> | ||||
|  *    <td>0x2064</td> | ||||
|  *    <td>Interfaceless Control-Only LUFA Devices</td> | ||||
|  *   </tr> | ||||
|  *   <tr> | ||||
|  *    <td>0x03EB</td> | ||||
|  *    <td>0x2065</td> | ||||
|  *    <td>Test and Measurement Demo</td> | ||||
|  *   </tr> | ||||
|  *   <tr> | ||||
|  *    <td>0x03EB</td> | ||||
|  *    <td> | ||||
|  *     0x2066 | ||||
|  *    </td> | ||||
|  *    <td>Multiple Report Keyboard/Mouse HID Demo</td> | ||||
|  *   </tr> | ||||
|  *   <tr> | ||||
|  *    <td>0x03EB</td> | ||||
|  *    <td>0x2067</td> | ||||
|  *    <td>HID Class Bootloader</td> | ||||
|  *   </tr> | ||||
|  *   <tr> | ||||
|  *    <td>0x03EB</td> | ||||
|  *    <td>0x2068</td> | ||||
|  *    <td>Virtual Serial/Mass Storage Demo</td> | ||||
|  *   </tr> | ||||
|  *   <tr> | ||||
|  *    <td>0x03EB</td> | ||||
|  *    <td> | ||||
|  *     0x2069 | ||||
|  *    </td> | ||||
|  *    <td>Webserver Project</td> | ||||
|  *   </tr> | ||||
|  *   <tr> | ||||
|  *    <td>0x03EB</td> | ||||
|  *    <td>0x206A</td> | ||||
|  *    <td>Media Control Project</td> | ||||
|  *   </tr> | ||||
|  *   <tr> | ||||
|  *    <td>0x03EB</td> | ||||
|  *    <td>0x206B</td> | ||||
|  *    <td>Printer Class Bootloader</td> | ||||
|  *   </tr> | ||||
|  *   <tr> | ||||
|  *    <td>0x03EB</td> | ||||
|  *    <td>0x206C</td> | ||||
|  *    <td>Bulk Vendor Demo Application</td> | ||||
|  *   </tr> | ||||
|  *   <tr> | ||||
|  *    <td>0x03EB</td> | ||||
|  *    <td>0x206D</td> | ||||
|  *    <td>Dual MIDI Demo Application</td> | ||||
|  *   </tr> | ||||
|  *   <tr> | ||||
|  *    <td>0x03EB</td> | ||||
|  *    <td>0x206E</td> | ||||
|  *    <td><i>Currently Unallocated</i></td> | ||||
|  *   </tr> | ||||
|  *   <tr> | ||||
|  *    <td>0x03EB</td> | ||||
|  *    <td>0x206F</td> | ||||
|  *    <td><i>Currently Unallocated</i></td> | ||||
|  *   </tr> | ||||
|  *  </table> | ||||
|  * | ||||
|  *  \section Sec_Test_VIDPID The Test VID/PID Combination | ||||
|  *  For use in testing of LUFA powered devices during development only, by non-commercial entities. | ||||
|  *  All devices must accept collisions on this VID/PID range (from other in-development LUFA devices) | ||||
|  *  to be resolved by using a unique release number in the Device Descriptor. No devices using this | ||||
|  *  VID/PID combination may be released to the general public. | ||||
|  */ | ||||
| 
 | ||||
							
								
								
									
										47
									
								
								LUFA/DoxygenPages/WritingBoardDrivers.txt
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										47
									
								
								LUFA/DoxygenPages/WritingBoardDrivers.txt
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,47 @@ | |||
| /** \file | ||||
|  * | ||||
|  *  This file contains special DoxyGen information for the generation of the main page and other special | ||||
|  *  documentation pages. It is not a project source file. | ||||
|  */ | ||||
| 
 | ||||
| /** \page Page_WritingBoardDrivers Writing LUFA Board Drivers | ||||
|  * | ||||
|  *  LUFA ships with several basic pre-made board drivers, to control hardware present on the supported board | ||||
|  *  hardware - such as Dataflash ICs, LEDs, Joysticks, or other hardware peripherals. When compiling an application | ||||
|  *  which makes use of one or more board drivers located in <i>LUFA/Drivers/Board</i>, you must also indicate which | ||||
|  *  board hardware you are using in your project makefile. This is done by defining the <tt>BOARD</tt> macro using | ||||
|  *  the <tt>-D</tt> switch passed to the compiler, with a constant of <tt>BOARD_{Name}</tt>. For example, | ||||
|  *  <tt>-DBOARD=BOARD_USBKEY</tt> instructs the compiler to use the USBKEY board hardware drivers. | ||||
|  * | ||||
|  *  If your application does not use <i>any</i> board level drivers, you can omit the definition of the <tt>BOARD</tt> | ||||
|  *  macro. However, some users may wish to write their own custom board hardware drivers which are to remain compatible | ||||
|  *  with the LUFA hardware API. To do this, the <tt>BOARD</tt> macro should be defined to the value <tt>BOARD_USER</tt>. | ||||
|  *  This indicates that the board level drivers should be located in a folder named "Board" located inside the | ||||
|  *  application's folder. | ||||
|  * | ||||
|  *  When used, the driver stub files located in the <tt>LUFA/CodeTemplates/DriverStubs</tt> folder should be copied to | ||||
|  *  the user application's <tt>Board/</tt> directory, and filled out to include the values and code needed to control | ||||
|  *  the custom board hardware. Once done, the existing LUFA board level APIs (accessed in the regular | ||||
|  *  <tt>LUFA/Drivers/Board/</tt> folder) will redirect to the user board drivers, maintaining code compatibility and | ||||
|  *  allowing for a different board to be selected through the project makefile with no code changes. | ||||
|  * | ||||
|  *  \section Sec_BoardTemplates Board Driver Templates | ||||
|  * | ||||
|  *  The templates for each board driver are reproduced below. | ||||
|  * | ||||
|  *  \subsection SSec_BoardTemplates_Board Template for USER <Board/Board.h> | ||||
|  *  \include "DriverStubs/Board.h" | ||||
|  * | ||||
|  *  \subsection SSec_BoardTemplates_Buttons Template for USER <Board/Buttons.h> | ||||
|  *  \include "DriverStubs/Buttons.h" | ||||
|  * | ||||
|  *  \subsection SSec_BoardTemplates_Dataflash Template for USER <Board/Dataflash.h> | ||||
|  *  \include "DriverStubs/Dataflash.h" | ||||
|  * | ||||
|  *  \subsection SSec_BoardTemplates_Joystick Template for USER <Board/Joystick.h> | ||||
|  *  \include "DriverStubs/Joystick.h" | ||||
|  * | ||||
|  *  \subsection SSec_BoardTemplates_LEDs Template for USER <Board/LEDs.h> | ||||
|  *  \include "DriverStubs/LEDs.h" | ||||
|  */ | ||||
| 
 | ||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 Jack Humbert
						Jack Humbert