Combined Mouse, MouseViaInt and MouseFullInt demos into a single unified demo.
authorDean Camera <dean@fourwalledcubicle.com>
Thu, 19 Mar 2009 14:16:12 +0000 (14:16 +0000)
committerDean Camera <dean@fourwalledcubicle.com>
Thu, 19 Mar 2009 14:16:12 +0000 (14:16 +0000)
Corrections to Keyboard demo.

Removed AVRISP_Programmer project due to code quality concerns.

54 files changed:
Bootloaders/CDC/BootloaderCDC.txt
Bootloaders/DFU/BootloaderDFU.txt
Bootloaders/TeensyHID/TeensyHID.h
Bootloaders/TeensyHID/TeensyHID.txt
Demos/AudioInput/AudioInput.c
Demos/AudioInput/AudioInput.txt
Demos/AudioOutput/AudioOutput.c
Demos/AudioOutput/AudioOutput.txt
Demos/AudioOutput/makefile
Demos/CDC/CDC.txt
Demos/CDCHost/CDCHost.txt
Demos/DualCDC/DualCDC.txt
Demos/Joystick/Joystick.txt
Demos/Keyboard/Keyboard.c
Demos/Keyboard/Keyboard.txt
Demos/KeyboardHost/KeyboardHost.txt
Demos/KeyboardHostViaInt/KeyboardHostViaInt.h
Demos/KeyboardHostViaInt/KeyboardHostViaInt.txt
Demos/KeyboardHostWithParser/KeyboardHostWithParser.txt
Demos/KeyboardMouse/KeyboardMouse.txt
Demos/MIDI/MIDI.txt
Demos/MassStorage/MassStorage.h
Demos/MassStorage/MassStorage.txt
Demos/MassStorageHost/MassStorageHost.txt
Demos/Mouse/Mouse.c
Demos/Mouse/Mouse.h
Demos/Mouse/Mouse.txt
Demos/Mouse/makefile
Demos/MouseHost/MouseHost.txt
Demos/MouseHostViaInt/MouseHostViaInt.txt
Demos/MouseHostWithParser/MouseHostWithParser.txt
Demos/RNDISEthernet/RNDISEthernet.txt
Demos/StillImageHost/StillImageHost.txt
Demos/TestApp/TestApp.txt
Demos/USBtoSerial/USBtoSerial.txt
Demos/makefile
LUFA.pnproj
LUFA/ChangeLog.txt
Projects/AVRISP_Programmer/AVRISP_Firmware_Design.txt [deleted file]
Projects/AVRISP_Programmer/AVRISP_Programmer.aps [deleted file]
Projects/AVRISP_Programmer/AVRISP_Programmer.c [deleted file]
Projects/AVRISP_Programmer/AVRISP_Programmer.h [deleted file]
Projects/AVRISP_Programmer/AVRISP_Programmer.txt [deleted file]
Projects/AVRISP_Programmer/AVRISP_Programmer_Picture.jpg [deleted file]
Projects/AVRISP_Programmer/Descriptors.c [deleted file]
Projects/AVRISP_Programmer/Descriptors.h [deleted file]
Projects/AVRISP_Programmer/Doxygen.conf [deleted file]
Projects/AVRISP_Programmer/LUFA AVRISP_Programmer.inf [deleted file]
Projects/AVRISP_Programmer/RingBuff.c [deleted file]
Projects/AVRISP_Programmer/RingBuff.h [deleted file]
Projects/AVRISP_Programmer/Sample_Programming_Session.txt [deleted file]
Projects/AVRISP_Programmer/makefile [deleted file]
Projects/Magstripe/Magstripe.txt
Projects/makefile

index cb6f9f0..1f8970d 100644 (file)
@@ -5,15 +5,10 @@
  */\r
  \r
 /** \mainpage CDC Class USB AVR Bootloader\r
- * \r
- * This bootloader enumerates to the host as a CDC Class device (virtual serial port), allowing for AVR109\r
- * protocol compatible programming software to load firmware onto the AVR.     \r
- *  \r
- * Out of the box this bootloader builds for the USB1287, and will fit into 4KB of bootloader space. If\r
- * you wish to enlarge this space and/or change the AVR model, you will need to edit the BOOT_START and MCU\r
- * values in the accompanying makefile.\r
- *  \r
- * This bootloader is compatible with the open source application AVRDUDE, or Atmel's AVRPROG.\r
+ *\r
+ *  \section SSec_Info USB Information:\r
+ *\r
+ *  The following table gives a rundown of the USB utilization of this demo.\r
  *\r
  * <table>\r
  *  <tr>\r
  *   <td>Full Speed Mode</td>\r
  *  </tr>\r
  * </table>\r
- */\r
+ *\r
+ *  \section SSec_Description Project Description: \r
+ *\r
+ * This bootloader enumerates to the host as a CDC Class device (virtual serial port), allowing for AVR109\r
+ * protocol compatible programming software to load firmware onto the AVR.     \r
+ *  \r
+ * Out of the box this bootloader builds for the USB1287, and will fit into 4KB of bootloader space. If\r
+ * you wish to enlarge this space and/or change the AVR model, you will need to edit the BOOT_START and MCU\r
+ * values in the accompanying makefile.\r
+ *  \r
+ * This bootloader is compatible with the open source application AVRDUDE, or Atmel's AVRPROG.\r
+ *\r
+ *  \section SSec_Options Project Options\r
+ *\r
+ *  The following defines can be found in this demo, which can control the demo behaviour when defined, or changed in value.\r
+ *\r
+ *  <table>\r
+ *   <tr>\r
+ *    <td>\r
+ *     None\r
+ *    </td>\r
+ *   </tr>\r
+ *  </table>\r
+ */
\ No newline at end of file
index 091ce40..7107cc1 100644 (file)
@@ -5,27 +5,10 @@
  */\r
  \r
 /** \mainpage DFU Class USB AVR Bootloader\r
- *  \r
- *  This bootloader enumerates to the host as a DFU Class device, allowing for DFU-compatible programming\r
- *  software to load firmware onto the AVR.\r
- *  \r
- *  This bootloader is compatible with Atmel's FLIP application. However, it requires the use of Atmel's\r
- *  DFU drivers. You will need to install Atmel's DFU drivers prior to using this bootloader.\r
- *  \r
- *  As an open-source option, this bootloader is also compatible with the Linux Atmel USB DFU Programmer\r
- *  software, available for download at http://sourceforge.net/projects/dfu-programmer/.\r
- *  \r
- *  If SECURE_MODE is defined as true, upon startup the bootloader will be locked, with only the chip erase\r
- *  function available (similar to Atmel's DFU bootloader). If SECURE_MODE is defined as false, all functions \r
- *  are usable on startup without the prerequisite firmware erase.\r
- *  \r
- *  Out of the box this bootloader builds for the USB1287, and should fit into 4KB of bootloader space. If\r
- *  you wish to enlarge this space and/or change the AVR model, you will need to edit the BOOT_START and MCU\r
- *  values in the accompanying makefile.\r
- *  \r
- *  <b>NOTE:</b> This device spoofs Atmel's DFU Bootloader USB VID and PID so that the Atmel DFU bootloader\r
- *               drivers included with FLIP will work. If you do not wish to use Atmel's ID codes, please\r
- *               manually change them in Descriptors.c and alter your driver's INF file accordingly.\r
+ *\r
+ *  \section SSec_Info USB Information:\r
+ *\r
+ *  The following table gives a rundown of the USB utilization of this demo.\r
  *\r
  * <table>\r
  *  <tr>\r
  *   <td>Full Speed Mode</td>\r
  *  </tr>\r
  * </table>\r
- */\r
+ *\r
+ *  \section SSec_Description Project Description: \r
+ *\r
+ *  This bootloader enumerates to the host as a DFU Class device, allowing for DFU-compatible programming\r
+ *  software to load firmware onto the AVR.\r
+ *  \r
+ *  This bootloader is compatible with Atmel's FLIP application. However, it requires the use of Atmel's\r
+ *  DFU drivers. You will need to install Atmel's DFU drivers prior to using this bootloader.\r
+ *  \r
+ *  As an open-source option, this bootloader is also compatible with the Linux Atmel USB DFU Programmer\r
+ *  software, available for download at http://sourceforge.net/projects/dfu-programmer/.\r
+ *  \r
+ *  If SECURE_MODE is defined as true, upon startup the bootloader will be locked, with only the chip erase\r
+ *  function available (similar to Atmel's DFU bootloader). If SECURE_MODE is defined as false, all functions \r
+ *  are usable on startup without the prerequisite firmware erase.\r
+ *  \r
+ *  Out of the box this bootloader builds for the USB1287, and should fit into 4KB of bootloader space. If\r
+ *  you wish to enlarge this space and/or change the AVR model, you will need to edit the BOOT_START and MCU\r
+ *  values in the accompanying makefile.\r
+ *  \r
+ *  <b>NOTE:</b> This device spoofs Atmel's DFU Bootloader USB VID and PID so that the Atmel DFU bootloader\r
+ *               drivers included with FLIP will work. If you do not wish to use Atmel's ID codes, please\r
+ *               manually change them in Descriptors.c and alter your driver's INF file accordingly.\r
+ *\r
+ *  \section SSec_Options Project Options\r
+ *\r
+ *  The following defines can be found in this demo, which can control the demo behaviour when defined, or changed in value.\r
+ *\r
+ *  <table>\r
+ *   <tr>\r
+ *    <td><b>Define Name:</b></td>\r
+ *    <td><b>Location:</b></td>\r
+ *    <td><b>Description:</b></td>\r
+ *   </tr>\r
+ *   <tr>\r
+ *    <td>SECURE_MODE</td>\r
+ *    <td>BootloaderDFU.h</td>\r
+ *    <td>If defined to true, the bootloader will not accept any memory commands other than a chip erase on statup, until an\r
+ *        erase has been perfomed. This can be used in conjunction with the AVR's lockbits to prevent the AVRs firmware from\r
+ *        being dumped by unauthorized persons.</td>\r
+ *   </tr>\r
+ *  </table>\r
+ */
\ No newline at end of file
index a4773f8..ae180f7 100644 (file)
@@ -57,9 +57,9 @@
 \r
        /* Macros: */\r
                /** HID Class specific request to send the next HID report to the device. */\r
-               #define REQ_SetReport           0x09\r
+               #define REQ_SetReport             0x09\r
                \r
-               #define TEENSY_STARTAPPLICATION 0xFFFF\r
+               #define TEENSY_STARTAPPLICATION   0xFFFF\r
 \r
        /* Event Handlers: */\r
                /** Indicates that this module will catch the USB_Disconnect event when thrown by the library. */\r
index 973819c..1d83510 100644 (file)
@@ -5,15 +5,11 @@
  */\r
  \r
 /** \mainpage Teensy HID Class USB AVR Bootloader\r
- * \r
- * This bootloader enumerates to the host as a HID Class device, allowing for Teensy compatible programming\r
- * software to load firmware onto the AVR, such as the official software at http://www.pjrc.com/teensy/.\r
- *  \r
- * Out of the box this bootloader builds for the USB162, and will fit into 2KB of bootloader space.\r
  *\r
- * This spoofs (with permission) the offical Teensy bootloader's VID and PID, so that the software remains\r
- * compatible with no changes.\r
- *  \r
+ *  \section SSec_Info USB Information:\r
+ *\r
+ *  The following table gives a rundown of the USB utilization of this demo.\r
+ *\r
  * <table>\r
  *  <tr>\r
  *   <td><b>USB Mode:</b></td>\r
  *   <td>Full Speed Mode</td>\r
  *  </tr>\r
  * </table>\r
- */\r
+ *\r
+ *  \section SSec_Description Project Description: \r
+ *\r
+ * This bootloader enumerates to the host as a HID Class device, allowing for Teensy compatible programming\r
+ * software to load firmware onto the AVR, such as the official software at http://www.pjrc.com/teensy/.\r
+ *  \r
+ * Out of the box this bootloader builds for the USB162, and will fit into 2KB of bootloader space.\r
+ *\r
+ * This spoofs (with permission) the offical Teensy bootloader's VID and PID, so that the software remains\r
+ * compatible with no changes.\r
+ *\r
+ *  \section SSec_Options Project Options\r
+ *\r
+ *  The following defines can be found in this demo, which can control the demo behaviour when defined, or changed in value.\r
+ *\r
+ *  <table>\r
+ *   <tr>\r
+ *    <td>\r
+ *     None\r
+ *    </td>\r
+ *   </tr>\r
+ *  </table>\r
+ */
\ No newline at end of file
index 6ead7a0..f41306f 100644 (file)
  *  Main source file for the Audio Input demo. This file contains the main tasks of the demo and\r
  *  is responsible for the initial application hardware configuration.\r
  */\r
\r
-/* ---  Project Configuration  --- */\r
-//#define MICROPHONE_BIASED_TO_HALF_RAIL\r
-/* --- --- --- --- --- --- --- --- */\r
 \r
 #include "AudioInput.h"\r
 \r
index 09b77f7..36e71e9 100644 (file)
@@ -5,21 +5,10 @@
  */\r
  \r
 /** \mainpage Audio Input Device Demo\r
- *  \r
- *  Audio demonstration application. This gives a simple reference\r
- *  application for implementing a USB Audio Input device using the\r
- *  basic USB Audio drivers in all modern OSes (i.e. no special drivers\r
- *  required).\r
- *  \r
- *  On startup the system will automatically enumerate and function\r
- *  as a USB microphone. Incomming audio from the ADC channel 1 will\r
- *  be sampled and sent to the host computer.\r
- *  \r
- *  To use, connect a microphone to the ADC channel 2.\r
- *  \r
- *  Under Windows, if a driver request dialogue pops up, select the option\r
- *  to automatically install the appropriate drivers.\r
- *  \r
+ *\r
+ *  \section SSec_Info USB Information:\r
+ *\r
+ *  The following table gives a rundown of the USB utilization of this demo.\r
  *\r
  *  <table>\r
  *   <tr>\r
  *    <td>Full Speed Mode</td>\r
  *   </tr>\r
  *  </table>\r
+ *\r
+ *  \section SSec_Description Project Description: \r
+ *\r
+ *  Audio demonstration application. This gives a simple reference\r
+ *  application for implementing a USB Audio Input device using the\r
+ *  basic USB Audio drivers in all modern OSes (i.e. no special drivers\r
+ *  required).\r
+ *  \r
+ *  On startup the system will automatically enumerate and function\r
+ *  as a USB microphone. Incomming audio from the ADC channel 1 will\r
+ *  be sampled and sent to the host computer.\r
+ *  \r
+ *  To use, connect a microphone to the ADC channel 2.\r
+ *  \r
+ *  Under Windows, if a driver request dialogue pops up, select the option\r
+ *  to automatically install the appropriate drivers.\r
+ *\r
+ *  \section SSec_Options Project Options\r
+ *\r
+ *  The following defines can be found in this demo, which can control the demo behaviour when defined, or changed in value.\r
+ *\r
+ *  <table>\r
+ *   <tr>\r
+ *    <td><b>Define Name:</b></td>\r
+ *    <td><b>Location:</b></td>\r
+ *    <td><b>Description:</b></td>\r
+ *   </tr>\r
+ *   <tr>\r
+ *    <td>MICROPHONE_BIASED_TO_HALF_RAIL</td>\r
+ *    <td>Makefile CDEFS</td>\r
+ *    <td>When defined, this alters the demo so that the half VCC bias of the microphone input is subtracted.</td>\r
+ *   </tr>\r
+ *  </table>\r
  */
\ No newline at end of file
index 87afd36..0f390f0 100644 (file)
  *  is responsible for the initial application hardware configuration.\r
  */\r
  \r
-/* ---   Project Configuration (Choose ONE)   --- */\r
-//#define AUDIO_OUT_MONO\r
-#define AUDIO_OUT_STEREO\r
-//#define AUDIO_OUT_LEDS\r
-//#define AUDIO_OUT_PORTC\r
-/* --- --- --- --- --- --- --- ---  ---  ---  --- */\r
-\r
 #include "AudioOutput.h"\r
 \r
 /* Project Tags, for reading out using the ButtLoad project */\r
index ce7d4ed..0638c47 100644 (file)
@@ -5,7 +5,38 @@
  */\r
  \r
 /** \mainpage Audio Output Device Demo\r
- *  \r
+ *\r
+ *  \section SSec_Info USB Information:\r
+ *\r
+ *  The following table gives a rundown of the USB utilization of this demo.\r
+ *\r
+ *  <table>\r
+ *   <tr>\r
+ *    <td><b>USB Mode:</b></td>\r
+ *    <td>Device</td>\r
+ *   </tr>\r
+ *   <tr>\r
+ *    <td><b>USB Class:</b></td>\r
+ *    <td>Audio Class</td>\r
+ *   </tr>\r
+ *   <tr> \r
+ *    <td><b>USB Subclass:</b></td>\r
+ *    <td>Standard Audio Device</td>\r
+ *   </tr>\r
+ *   <tr>\r
+ *    <td><b>Relevant Standards:</b></td>\r
+ *    <td>USBIF Audio Class Specification</td>\r
+ *    <td>USBIF Audio Class Terminal Types Specification</td>\r
+ *    <td>USBIF Audio Data Formats Specification</td>\r
+ *   </tr>\r
+ *   <tr>\r
+ *    <td><b>Usable Speeds:</b></td>\r
+ *    <td>Full Speed Mode</td>\r
+ *   </tr>\r
+ *  </table>\r
+ *\r
+ *  \section SSec_Description Project Description: \r
+ *\r
  *  Audio demonstration application. This gives a simple reference\r
  *  application for implementing a USB Audio Output device using the\r
  *  basic USB Audio drivers in all modern OSes (i.e. no special drivers\r
  *  \r
  *  Under Windows, if a driver request dialogue pops up, select the option\r
  *  to automatically install the appropriate drivers.\r
- *  \r
+ *\r
+ *  \section SSec_Options Project Options\r
+ *\r
+ *  The following defines can be found in this demo, which can control the demo behaviour when defined, or changed in value.\r
  *\r
  *  <table>\r
  *   <tr>\r
- *    <td><b>USB Mode:</b></td>\r
- *    <td>Device</td>\r
+ *    <td><b>Define Name:</b></td>\r
+ *    <td><b>Location:</b></td>\r
+ *    <td><b>Description:</b></td>\r
  *   </tr>\r
  *   <tr>\r
- *    <td><b>USB Class:</b></td>\r
- *    <td>Audio Class</td>\r
+ *    <td>AUDIO_OUT_STEREO</td>\r
+ *    <td>Makefile CDEFS</td>\r
+ *    <td>When defined, this outputs the audio samples in stereo to the timer output pins of the microcontroller.</td>\r
  *   </tr>\r
- *   <tr> \r
- *    <td><b>USB Subclass:</b></td>\r
- *    <td>Standard Audio Device</td>\r
+ *   <tr>\r
+ *    <td>AUDIO_OUT_MONO</td>\r
+ *    <td>Makefile CDEFS</td>\r
+ *    <td>When defined, this outputs the audio samples in mono to the timer output pin of the microcontroller.</td>\r
  *   </tr>\r
  *   <tr>\r
- *    <td><b>Relevant Standards:</b></td>\r
- *    <td>USBIF Audio Class Specification</td>\r
- *    <td>USBIF Audio Class Terminal Types Specification</td>\r
- *    <td>USBIF Audio Data Formats Specification</td>\r
+ *    <td>AUDIO_OUT_LEDS</td>\r
+ *    <td>Makefile CDEFS</td>\r
+ *    <td>When defined, this outputs the audio samples in stereo to the board LEDs.</td>\r
  *   </tr>\r
  *   <tr>\r
- *    <td><b>Usable Speeds:</b></td>\r
- *    <td>Full Speed Mode</td>\r
+ *    <td>AUDIO_OUT_PORTC</td>\r
+ *    <td>Makefile CDEFS</td>\r
+ *    <td>When defined, this outputs the audio samples in mono to port C of the microcontroller, for connection to an\r
+ *        external DAC.</td>\r
  *   </tr>\r
  *  </table>\r
  */
\ No newline at end of file
index 3584d55..af99358 100644 (file)
@@ -176,7 +176,7 @@ CSTANDARD = -std=gnu99
 CDEFS  = -DF_CPU=$(F_CPU)UL -DF_CLOCK=$(F_CLOCK)UL -DBOARD=BOARD_$(BOARD)\r
 CDEFS += -DUSE_NONSTANDARD_DESCRIPTOR_NAMES -DNO_STREAM_CALLBACKS -DUSB_DEVICE_ONLY\r
 CDEFS += -DUSE_STATIC_OPTIONS="(USB_DEVICE_OPT_FULLSPEED | USB_OPT_REG_ENABLED | USB_OPT_AUTO_PLL)"\r
-\r
+CDEFS += -DAUDIO_OUT_STEREO\r
 \r
 # Place -D or -U options here for ASM sources\r
 ADEFS = -DF_CPU=$(F_CPU)\r
index 34e1c82..8e13b55 100644 (file)
@@ -6,19 +6,9 @@
  \r
 /** \mainpage Communications Device Class Device (Virtual Serial Port)\r
  *\r
- *  Communications Device Class demonstration application.\r
- *  This gives a simple reference application for implementing\r
- *  a CDC device acting as a virtual serial port. Joystick\r
- *  actions are transmitted to the host as strings. The device\r
- *  does not respond to serial data sent from the host.\r
- *  \r
- *  After running this demo for the first time on a new computer,\r
- *  you will need to supply the .INF file located in this demo\r
- *  project's directory as the device's driver when running under\r
- *  Windows. This will enable Windows to use its inbuilt CDC drivers,\r
- *  negating the need for custom drivers for the device. Other\r
- *  Operating Systems should automatically use their own inbuilt\r
- *  CDC-ACM drivers.\r
+ *  \section SSec_Info USB Information:\r
+ *\r
+ *  The following table gives a rundown of the USB utilization of this demo.\r
  *\r
  *  <table>\r
  *   <tr>\r
  *    <td>Full Speed Mode</td>\r
  *   </tr>\r
  *  </table>\r
+ *\r
+ *  \section SSec_Description Project Description: \r
+ *\r
+ *  Communications Device Class demonstration application.\r
+ *  This gives a simple reference application for implementing\r
+ *  a CDC device acting as a virtual serial port. Joystick\r
+ *  actions are transmitted to the host as strings. The device\r
+ *  does not respond to serial data sent from the host.\r
+ *  \r
+ *  After running this demo for the first time on a new computer,\r
+ *  you will need to supply the .INF file located in this demo\r
+ *  project's directory as the device's driver when running under\r
+ *  Windows. This will enable Windows to use its inbuilt CDC drivers,\r
+ *  negating the need for custom drivers for the device. Other\r
+ *  Operating Systems should automatically use their own inbuilt\r
+ *  CDC-ACM drivers.\r
+ *\r
+ *  \section SSec_Options Project Options\r
+ *\r
+ *  The following defines can be found in this demo, which can control the demo behaviour when defined, or changed in value.\r
+ *\r
+ *  <table>\r
+ *   <tr>\r
+ *    <td>\r
+ *     None\r
+ *    </td>\r
+ *   </tr>\r
+ *  </table>\r
  */
\ No newline at end of file
index 5f8dc8c..39e2357 100644 (file)
@@ -5,17 +5,10 @@
  */\r
  \r
 /** \mainpage CDC Host Demo\r
- *  \r
- *  CDC host demonstration application. This gives a simple reference application\r
- *  for implementing a USB CDC host, for CDC devices using the standard ACM profile.\r
- *  \r
- *  This demo prints out received CDC data through the serial port.\r
- *  \r
- *  Not that this demo is only compatible with devices which report the correct CDC\r
- *  and ACM class, subclass and protocol values. Most USB-Serial cables have vendor\r
- *  specific features, thus use vendor-specfic class/subclass/protocol codes to force\r
- *  the user to use specialized drivers. This demo is not compaible with such devices.\r
- *  \r
+ *\r
+ *  \section SSec_Info USB Information:\r
+ *\r
+ *  The following table gives a rundown of the USB utilization of this demo.\r
  *\r
  *  <table>\r
  *   <tr>\r
  *    <td>Full Speed Mode</td>\r
  *   </tr>\r
  *  </table>\r
+ *\r
+ *  \section SSec_Description Project Description: \r
+ *\r
+ *  CDC host demonstration application. This gives a simple reference application\r
+ *  for implementing a USB CDC host, for CDC devices using the standard ACM profile.\r
+ *  \r
+ *  This demo prints out received CDC data through the serial port.\r
+ *  \r
+ *  Not that this demo is only compatible with devices which report the correct CDC\r
+ *  and ACM class, subclass and protocol values. Most USB-Serial cables have vendor\r
+ *  specific features, thus use vendor-specfic class/subclass/protocol codes to force\r
+ *  the user to use specialized drivers. This demo is not compaible with such devices.\r
+ *\r
+ *  \section SSec_Options Project Options\r
+ *\r
+ *  The following defines can be found in this demo, which can control the demo behaviour when defined, or changed in value.\r
+ *\r
+ *  <table>\r
+ *   <tr>\r
+ *    <td>\r
+ *     None\r
+ *    </td>\r
+ *   </tr>\r
+ *  </table>\r
  */
\ No newline at end of file
index aebbec3..6e08602 100644 (file)
@@ -6,6 +6,38 @@
  \r
 /** \mainpage Dual Communications Device Class Device (Dual Virtual Serial Port)\r
  *\r
+ *  \section SSec_Info USB Information:\r
+ *\r
+ *  The following table gives a rundown of the USB utilization of this demo.\r
+ *\r
+ *  <table>\r
+ *   <tr>\r
+ *    <td><b>USB Mode:</b></td>\r
+ *    <td>Device</td>\r
+ *   </tr>\r
+ *   <tr>\r
+ *    <td><b>USB Class:</b></td>\r
+ *    <td>Miscellaneous Device Class</td>\r
+ *    <td>( Sub-Interface: Communications Device Class (CDC) )</td>\r
+ *   </tr>\r
+ *   <tr> \r
+ *    <td><b>USB Subclass:</b></td>\r
+ *    <td>Common Class</td> \r
+ *    <td>( Sub-Interface: Abstract Control Model (ACM) )</td>\r
+ *   </tr>\r
+ *   <tr>\r
+ *    <td><b>Relevant Standards:</b></td>\r
+ *    <td>USBIF Interface Association Descriptor ECN</td>\r
+ *    <td>USBIF CDC Class Standard</td>\r
+ *   </tr>\r
+ *   <tr>\r
+ *    <td><b>Usable Speeds:</b></td>\r
+ *    <td>Full Speed Mode</td>\r
+ *   </tr>\r
+ *  </table>\r
+ *\r
+ *  \section SSec_Description Project Description: \r
+ *\r
  *  Dual Communications Device Class demonstration application.\r
  *  This gives a simple reference application for implementing\r
  *  a compound device with dual CDC functions acting as a pair\r
  *  Operating Systems should automatically use their own inbuilt\r
  *  CDC-ACM drivers.\r
  *\r
+ *  \section SSec_Options Project Options\r
+ *\r
+ *  The following defines can be found in this demo, which can control the demo behaviour when defined, or changed in value.\r
+ *\r
  *  <table>\r
  *   <tr>\r
- *    <td><b>USB Mode:</b></td>\r
- *    <td>Device</td>\r
- *   </tr>\r
- *   <tr>\r
- *    <td><b>USB Class:</b></td>\r
- *    <td>Miscellaneous Device Class</td>\r
- *    <td>( Sub-Interface: Communications Device Class (CDC) )</td>\r
- *   </tr>\r
- *   <tr> \r
- *    <td><b>USB Subclass:</b></td>\r
- *    <td>Common Class</td> \r
- *    <td>( Sub-Interface: Abstract Control Model (ACM) )</td>\r
- *   </tr>\r
- *   <tr>\r
- *    <td><b>Relevant Standards:</b></td>\r
- *    <td>USBIF Interface Association Descriptor ECN</td>\r
- *    <td>USBIF CDC Class Standard</td>\r
- *   </tr>\r
- *   <tr>\r
- *    <td><b>Usable Speeds:</b></td>\r
- *    <td>Full Speed Mode</td>\r
+ *    <td>\r
+ *     None\r
+ *    </td>\r
  *   </tr>\r
  *  </table>\r
  */
\ No newline at end of file
index 6229aa0..7d47ae9 100644 (file)
@@ -6,18 +6,9 @@
  \r
 /** \mainpage Joystick Device Demo\r
  *\r
- *  Joystick demonstration application. This gives a simple reference\r
- *  application for implementing a USB Keyboard device, for USB Joysticks\r
- *  using the standard Keyboard HID profile.\r
- *  \r
- *  This device will show up as a generic joystick device, with two buttons.\r
- *  Pressing the joystick inwards is the first button, and the HWB button\r
- *  is the second.\r
- *  \r
- *  Moving the joystick on the selected board moves the joystick location on\r
- *  the host computer.\r
- *  \r
- *  Currently only single interface joysticks are supported.\r
+ *  \section SSec_Info USB Information:\r
+ *\r
+ *  The following table gives a rundown of the USB utilization of this demo.\r
  *\r
  *  <table>\r
  *   <tr>\r
  *    <td>Low Speed Mode, Full Speed Mode</td>\r
  *   </tr>\r
  *  </table>\r
+ *\r
+ *  \section SSec_Description Project Description: \r
+ *\r
+ *  Joystick demonstration application. This gives a simple reference\r
+ *  application for implementing a USB Keyboard device, for USB Joysticks\r
+ *  using the standard Keyboard HID profile.\r
+ *  \r
+ *  This device will show up as a generic joystick device, with two buttons.\r
+ *  Pressing the joystick inwards is the first button, and the HWB button\r
+ *  is the second.\r
+ *  \r
+ *  Moving the joystick on the selected board moves the joystick location on\r
+ *  the host computer.\r
+ *  \r
+ *  Currently only single interface joysticks are supported.\r
+ *\r
+ *  \section SSec_Options Project Options\r
+ *\r
+ *  The following defines can be found in this demo, which can control the demo behaviour when defined, or changed in value.\r
+ *\r
+ *  <table>\r
+ *   <tr>\r
+ *    <td>\r
+ *     None\r
+ *    </td>\r
+ *   </tr>\r
+ *  </table>\r
  */
\ No newline at end of file
index 3884eeb..f506070 100644 (file)
@@ -140,6 +140,15 @@ EVENT_HANDLER(USB_Reset)
  */\r
 EVENT_HANDLER(USB_Disconnect)\r
 {\r
+       /* Stop running keyboard reporting and USB management tasks */\r
+       #if !defined(INTERRUPT_DATA_ENDPOINT)\r
+       Scheduler_SetTaskMode(USB_Keyboard_Report, TASK_STOP);\r
+       #endif\r
+\r
+       #if !defined(INTERRUPT_CONTROL_ENDPOINT)\r
+       Scheduler_SetTaskMode(USB_USBTask, TASK_STOP);\r
+       #endif\r
+       \r
        /* Indicate USB not ready */\r
        UpdateStatus(Status_USBNotReady);\r
 }\r
@@ -171,6 +180,11 @@ EVENT_HANDLER(USB_ConfigurationChanged)
 \r
        /* Indicate USB connected and ready */\r
        UpdateStatus(Status_USBReady);\r
+\r
+       #if !defined(INTERRUPT_DATA_ENDPOINT)\r
+       /* Start running keyboard reporting task */\r
+       Scheduler_SetTaskMode(USB_Keyboard_Report, TASK_RUN);\r
+       #endif\r
 }\r
 \r
 /** Event handler for the USB_UnhandledControlPacket event. This is used to catch standard and class specific\r
index 7939035..a09d835 100644 (file)
@@ -34,6 +34,7 @@
  *  </table>\r
  *\r
  *  \section SSec_Description Project Description:\r
+ *\r
  *  Keyboard demonstration application. This gives a simple reference application\r
  *  for implementing a USB Keyboard using the basic USB HID drivers in all modern\r
  *  OSes (i.e. no special drivers required). It is boot protocol compatible, and thus\r
index 92e3807..db0e14a 100644 (file)
@@ -5,21 +5,10 @@
  */\r
  \r
 /** \mainpage Keyboard Host Demo\r
- *  \r
- *  Keyboard host demonstration application. This gives a simple reference\r
- *  application for implementing a USB Mouse keyboard, for USB keyboards using\r
- *  the standard keyboard HID profile.\r
- *  \r
- *  Pressed alpha-numeric, enter or space key is transmitted through the serial\r
- *  USART at serial settings 9600, 8, N, 1.\r
- *  \r
- *  This uses a naive method where the keyboard is set to Boot Protocol mode, so\r
- *  that the report structure is fixed and known. A better implementation\r
- *  uses the HID report parser for correct report data processing across\r
- *  all compatable mice with advanced characteristics, as shown in the\r
- *  KeyboardHostWithParser demo application.\r
- *  \r
- *  Currently only single interface keyboards are supported.   \r
+ *\r
+ *  \section SSec_Info USB Information:\r
+ *\r
+ *  The following table gives a rundown of the USB utilization of this demo.\r
  *\r
  *  <table>\r
  *   <tr>\r
  *    <td>Low Speed Mode, Full Speed Mode</td>\r
  *   </tr>\r
  *  </table>\r
+ *\r
+ *  \section SSec_Description Project Description: \r
+ *\r
+ *  Keyboard host demonstration application. This gives a simple reference\r
+ *  application for implementing a USB Mouse keyboard, for USB keyboards using\r
+ *  the standard keyboard HID profile.\r
+ *  \r
+ *  Pressed alpha-numeric, enter or space key is transmitted through the serial\r
+ *  USART at serial settings 9600, 8, N, 1.\r
+ *  \r
+ *  This uses a naive method where the keyboard is set to Boot Protocol mode, so\r
+ *  that the report structure is fixed and known. A better implementation\r
+ *  uses the HID report parser for correct report data processing across\r
+ *  all compatable mice with advanced characteristics, as shown in the\r
+ *  KeyboardHostWithParser demo application.\r
+ *  \r
+ *  Currently only single interface keyboards are supported.\r
+ *\r
+ *  \section SSec_Options Project Options\r
+ *\r
+ *  The following defines can be found in this demo, which can control the demo behaviour when defined, or changed in value.\r
+ *\r
+ *  <table>\r
+ *   <tr>\r
+ *    <td>\r
+ *     None\r
+ *    </td>\r
+ *   </tr>\r
+ *  </table>\r
  */
\ No newline at end of file
index 7ae54e6..06cd02a 100644 (file)
@@ -59,7 +59,7 @@
                #define KEYBOARD_DATAPIPE              1\r
 \r
                /** HID Class Specific request to set the report protocol mode */\r
-               #define REQ_SetProtocol             0x0B\r
+               #define REQ_SetProtocol                0x0B\r
 \r
        /* Type Defines: */\r
                /** Type define for a standard Boot Protocol Keyboard report */\r
index 07c1108..de61d32 100644 (file)
@@ -4,23 +4,11 @@
  *  documentation pages. It is not a project source file.\r
  */\r
  \r
-/** \mainpage Keyboard Host Demo\r
- *  \r
- *  Keyboard host demonstration application, using pipe interrupts. This gives\r
- *  a simple reference application for implementing a USB Keyboard host utilizing\r
- *  the LUFA pipe interrupt system, for USB keyboards using the standard Keyboard\r
- *  HID profile.\r
- *  \r
- *  Pressed alpha-numeric, enter or space key is transmitted through the serial\r
- *  USART at serial settings 9600, 8, N, 1.\r
- *  \r
- *  This uses a naive method where the keyboard is set to Boot Protocol mode, so\r
- *  that the report structure is fixed and known. A better implementation\r
- *  uses the HID report parser for correct report data processing across\r
- *  all compatable mice with advanced characteristics, as shown in the\r
- *  KeyboardHostWithParser demo application.\r
- *  \r
- *  Currently only single interface keyboards are supported.   \r
+/** \mainpage Keyboard Host Demo (via interrupts)\r
+ *\r
+ *  \section SSec_Info USB Information:\r
+ *\r
+ *  The following table gives a rundown of the USB utilization of this demo.\r
  *\r
  *  <table>\r
  *   <tr>\r
  *    <td>Low Speed Mode, Full Speed Mode</td>\r
  *   </tr>\r
  *  </table>\r
+ *\r
+ *  \section SSec_Description Project Description: \r
+ *\r
+ *  Keyboard host demonstration application, using pipe interrupts. This gives\r
+ *  a simple reference application for implementing a USB Keyboard host utilizing\r
+ *  the LUFA pipe interrupt system, for USB keyboards using the standard Keyboard\r
+ *  HID profile.\r
+ *  \r
+ *  Pressed alpha-numeric, enter or space key is transmitted through the serial\r
+ *  USART at serial settings 9600, 8, N, 1.\r
+ *  \r
+ *  This uses a naive method where the keyboard is set to Boot Protocol mode, so\r
+ *  that the report structure is fixed and known. A better implementation\r
+ *  uses the HID report parser for correct report data processing across\r
+ *  all compatable mice with advanced characteristics, as shown in the\r
+ *  KeyboardHostWithParser demo application.\r
+ *  \r
+ *  Currently only single interface keyboards are supported.\r
+ *\r
+ *  \section SSec_Options Project Options\r
+ *\r
+ *  The following defines can be found in this demo, which can control the demo behaviour when defined, or changed in value.\r
+ *\r
+ *  <table>\r
+ *   <tr>\r
+ *    <td>\r
+ *     None\r
+ *    </td>\r
+ *   </tr>\r
+ *  </table>\r
  */
\ No newline at end of file
index 09a83ca..cd36706 100644 (file)
@@ -5,19 +5,10 @@
  */\r
  \r
 /** \mainpage Keyboard Host With HID Descriptor Parser Demo\r
- *  \r
- *  Keyboard host demonstration application. This gives a simple reference\r
- *  application for implementing a USB Keyboard host, for USB keyboards using\r
- *  the standard Keyboard HID profile. It uses a HID parser for the HID reports,\r
- *  allowing for correct operation across all USB keyboards. This demo supports\r
- *  keyboards with a single HID report.\r
- *  \r
- *  Pressed alpha-numeric, enter or space key is transmitted through the serial\r
- *  USART at serial settings 9600, 8, N, 1. On connection to a USB keyboard, the\r
- *  report items will be processed and printed as a formatted list through the\r
- *  USART before the keyboard is fully enumerated.\r
- *  \r
- *  Currently only single interface keyboards are supported.   \r
+ *\r
+ *  \section SSec_Info USB Information:\r
+ *\r
+ *  The following table gives a rundown of the USB utilization of this demo.\r
  *\r
  *  <table>\r
  *   <tr>\r
  *    <td>Low Speed Mode, Full Speed Mode</td>\r
  *   </tr>\r
  *  </table>\r
+ *\r
+ *  \section SSec_Description Project Description: \r
+ *\r
+ *  Keyboard host demonstration application. This gives a simple reference\r
+ *  application for implementing a USB Keyboard host, for USB keyboards using\r
+ *  the standard Keyboard HID profile. It uses a HID parser for the HID reports,\r
+ *  allowing for correct operation across all USB keyboards. This demo supports\r
+ *  keyboards with a single HID report.\r
+ *  \r
+ *  Pressed alpha-numeric, enter or space key is transmitted through the serial\r
+ *  USART at serial settings 9600, 8, N, 1. On connection to a USB keyboard, the\r
+ *  report items will be processed and printed as a formatted list through the\r
+ *  USART before the keyboard is fully enumerated.\r
+ *  \r
+ *  Currently only single interface keyboards are supported.   \r
+ *\r
+ *  \section SSec_Options Project Options\r
+ *\r
+ *  The following defines can be found in this demo, which can control the demo behaviour when defined, or changed in value.\r
+ *\r
+ *  <table>\r
+ *   <tr>\r
+ *    <td>\r
+ *     None\r
+ *    </td>\r
+ *   </tr>\r
+ *  </table>\r
  */
\ No newline at end of file
index 969e287..6388e98 100644 (file)
@@ -6,22 +6,9 @@
  \r
 /** \mainpage Dual HID Keyboard and Mouse Device Demo\r
  *\r
- *  Keyboard/Mouse demonstration application. This gives a simple reference\r
- *  application for implementing a composite device containing both USB Keyboard\r
- *  and USB Mouse functionality using the basic USB HID drivers in all modern OSes\r
- *  (i.e. no special drivers required). This example uses two seperate HID\r
- *  interfaces for each function. It is boot protocol compatible, and thus works under\r
- *  compatible BIOS as if it was a native keyboard and mouse (e.g. PS/2).\r
- *  \r
- *  On startup the system will automatically enumerate and function\r
- *  as a keyboard when the USB connection to a host is present and the HWB is not\r
- *  pressed. When enabled, manipulate the joystick to send the letters\r
- *  a, b, c, d and e. See the USB HID documentation for more information\r
- *  on sending keyboard event and keypresses.\r
- *  \r
- *  When the HWB is pressed, the mouse mode is enabled. When enabled, move the\r
- *  joystick to move the pointer, and push the joystick inwards to simulate a\r
- *  left-button click.\r
+ *  \section SSec_Info USB Information:\r
+ *\r
+ *  The following table gives a rundown of the USB utilization of this demo.\r
  *\r
  *  <table>\r
  *   <tr>\r
  *    <td>Low Speed Mode, Full Speed Mode</td>\r
  *   </tr>\r
  *  </table>\r
+ *\r
+ *  \section SSec_Description Project Description: \r
+ *\r
+ *  Keyboard/Mouse demonstration application. This gives a simple reference\r
+ *  application for implementing a composite device containing both USB Keyboard\r
+ *  and USB Mouse functionality using the basic USB HID drivers in all modern OSes\r
+ *  (i.e. no special drivers required). This example uses two seperate HID\r
+ *  interfaces for each function. It is boot protocol compatible, and thus works under\r
+ *  compatible BIOS as if it was a native keyboard and mouse (e.g. PS/2).\r
+ *  \r
+ *  On startup the system will automatically enumerate and function\r
+ *  as a keyboard when the USB connection to a host is present and the HWB is not\r
+ *  pressed. When enabled, manipulate the joystick to send the letters\r
+ *  a, b, c, d and e. See the USB HID documentation for more information\r
+ *  on sending keyboard event and keypresses.\r
+ *  \r
+ *  When the HWB is pressed, the mouse mode is enabled. When enabled, move the\r
+ *  joystick to move the pointer, and push the joystick inwards to simulate a\r
+ *  left-button click.\r
+ *\r
+ *  \section SSec_Options Project Options\r
+ *\r
+ *  The following defines can be found in this demo, which can control the demo behaviour when defined, or changed in value.\r
+ *\r
+ *  <table>\r
+ *   <tr>\r
+ *    <td>\r
+ *     None\r
+ *    </td>\r
+ *   </tr>\r
+ *  </table>\r
  */
\ No newline at end of file
index 0b34ccb..3eb60cd 100644 (file)
@@ -5,21 +5,10 @@
  */\r
  \r
 /** \mainpage MIDI Input Device Demo\r
- *  \r
- *  MIDI demonstration application. This gives a simple reference\r
- *  application for implementing the USB-MIDI class in USB devices.\r
- *  It is built upon the USB Audio class.\r
- *  \r
- *  Joystick movements are translated into note on/off messages and\r
- *  are sent to the host PC as MIDI streams which can be read by any\r
- *  MIDI program supporting MIDI IN devices.\r
- *  \r
- *  If the HWB is not pressed, channel 1 (default piano) is used. If\r
- *  the HWB is set, then channel 10 (default percussion) is selected.\r
- *  \r
- *  This device implements MIDI-THRU mode, with the IN MIDI data being\r
- *  generated by the device itself. OUT MIDI data is discarded.\r
- *  \r
+ *\r
+ *  \section SSec_Info USB Information:\r
+ *\r
+ *  The following table gives a rundown of the USB utilization of this demo.\r
  *\r
  *  <table>\r
  *   <tr>\r
  *    <td>Full Speed Mode</td>\r
  *   </tr>\r
  *  </table>\r
+ *\r
+ *  \section SSec_Description Project Description: \r
+ *\r
+ *  MIDI demonstration application. This gives a simple reference\r
+ *  application for implementing the USB-MIDI class in USB devices.\r
+ *  It is built upon the USB Audio class.\r
+ *  \r
+ *  Joystick movements are translated into note on/off messages and\r
+ *  are sent to the host PC as MIDI streams which can be read by any\r
+ *  MIDI program supporting MIDI IN devices.\r
+ *  \r
+ *  If the HWB is not pressed, channel 1 (default piano) is used. If\r
+ *  the HWB is set, then channel 10 (default percussion) is selected.\r
+ *  \r
+ *  This device implements MIDI-THRU mode, with the IN MIDI data being\r
+ *  generated by the device itself. OUT MIDI data is discarded.\r
+ *\r
+ *  \section SSec_Options Project Options\r
+ *\r
+ *  The following defines can be found in this demo, which can control the demo behaviour when defined, or changed in value.\r
+ *\r
+ *  <table>\r
+ *   <tr>\r
+ *    <td>\r
+ *     None\r
+ *    </td>\r
+ *   </tr>\r
+ *  </table>\r
  */
\ No newline at end of file
index 3525340..a30e7f7 100644 (file)
@@ -62,8 +62,9 @@
                /** Maximum length of a SCSI command which can be issued by the device or host in a Mass Storage bulk wrapper. */\r
                #define MAX_SCSI_COMMAND_LENGTH    16\r
                \r
-               /** Total number of Logical Units (drives) in the device. By default, the total device capacity is shared equally between\r
-                *  each drive - this can be set to any positive non-zero amount. */\r
+               /** Total number of Logical Units (drives) in the device. The total device capacity is shared equally between\r
+                *  each drive - this can be set to any positive non-zero amount.\r
+                */\r
                #define TOTAL_LUNS                 2\r
                \r
                /** Blocks in each LUN, calculated from the total capacity divided by the total number of Logical Units in the device. */\r
index 428faa8..4e8adad 100644 (file)
@@ -6,25 +6,9 @@
  \r
 /** \mainpage Mass Storage Device Demo\r
  *\r
- *  Dual LUN Mass Storage demonstration application. This gives a simple\r
- *  reference application for implementing a multiple LUN USB Mass Storage\r
- *  device using the basic USB UFI drivers in all modern OSes (i.e. no\r
- *  special drivers required).\r
- *  \r
- *  On startup the system will automatically enumerate and function as an\r
- *  external mass storage device with two LUNs (seperate disks) which may\r
- *  be formatted and used in the same manner as commercial USB Mass Storage\r
- *  devices.\r
- *     \r
- *  You will need to format the mass storage drives upon first run of this\r
- *  demonstration - as the device acts only as a data block transport between\r
- *  the host and the storage media, it does not matter what file system is used,\r
- *  as the data interpretation is performed by the host and not the USB device.\r
- *  \r
- *  This demo is not restricted to only two LUNs; by changing the TOTAL_LUNS\r
- *  value in MassStorageDualLUN.h, any number of LUNs can be used (from 1 to\r
- *  255), with each LUN being allocated an equal portion of the available\r
- *  Dataflash memory.\r
+ *  \section SSec_Info USB Information:\r
+ *\r
+ *  The following table gives a rundown of the USB utilization of this demo.\r
  *\r
  *  <table>\r
  *   <tr>\r
  *    <td>Full Speed Mode</td>\r
  *   </tr>\r
  *  </table>\r
+ *\r
+ *  \section SSec_Description Project Description: \r
+ *\r
+ *  Dual LUN Mass Storage demonstration application. This gives a simple\r
+ *  reference application for implementing a multiple LUN USB Mass Storage\r
+ *  device using the basic USB UFI drivers in all modern OSes (i.e. no\r
+ *  special drivers required).\r
+ *  \r
+ *  On startup the system will automatically enumerate and function as an\r
+ *  external mass storage device with two LUNs (seperate disks) which may\r
+ *  be formatted and used in the same manner as commercial USB Mass Storage\r
+ *  devices.\r
+ *     \r
+ *  You will need to format the mass storage drives upon first run of this\r
+ *  demonstration - as the device acts only as a data block transport between\r
+ *  the host and the storage media, it does not matter what file system is used,\r
+ *  as the data interpretation is performed by the host and not the USB device.\r
+ *  \r
+ *  This demo is not restricted to only two LUNs; by changing the TOTAL_LUNS\r
+ *  value in MassStorageDualLUN.h, any number of LUNs can be used (from 1 to\r
+ *  255), with each LUN being allocated an equal portion of the available\r
+ *  Dataflash memory.\r
+ *\r
+ *  \section SSec_Options Project Options\r
+ *\r
+ *  The following defines can be found in this demo, which can control the demo behaviour when defined, or changed in value.\r
+ *\r
+ *  <table>\r
+ *   <tr>\r
+ *    <td><b>Define Name:</b></td>\r
+ *    <td><b>Location:</b></td>\r
+ *    <td><b>Description:</b></td>\r
+ *   </tr>\r
+ *   <tr>\r
+ *    <td>TOTAL_LUNS</td>\r
+ *    <td>MassStorage.h</td>\r
+ *    <td>Total number of Logical Units (drives) in the device. The total device capacity is shared equally between each drive\r
+ *        - this can be set to any positive non-zero amount.</td>\r
+ *   </tr>\r
+ *  </table>\r
  */
\ No newline at end of file
index 2defd7f..88b42e9 100644 (file)
@@ -5,15 +5,10 @@
  */\r
  \r
 /** \mainpage Mass Storage Host Demo\r
- *  \r
- *  Mass Storage host demonstration application. This gives a simple reference\r
- *  application for implementing a USB Mass Storage host, for USB storage devices\r
- *  using the standard Mass Storage USB profile.\r
- *  \r
- *  The first 512 bytes (boot sector) of an attached disk's memory will be dumped\r
- *  out of the serial port in HEX and ASCII form when it is attached to the AT90USB1287\r
- *  AVR. The device will then wait for HWB to be pressed, whereupon the entire ASCII contents\r
- *  of the disk will be dumped to the serial port.\r
+ *\r
+ *  \section SSec_Info USB Information:\r
+ *\r
+ *  The following table gives a rundown of the USB utilization of this demo.\r
  *\r
  *  <table>\r
  *   <tr>\r
  *    <td>Full Speed Mode</td>\r
  *   </tr>\r
  *  </table>\r
+ *\r
+ *  \section SSec_Description Project Description: \r
+ *\r
+ *  Mass Storage host demonstration application. This gives a simple reference\r
+ *  application for implementing a USB Mass Storage host, for USB storage devices\r
+ *  using the standard Mass Storage USB profile.\r
+ *  \r
+ *  The first 512 bytes (boot sector) of an attached disk's memory will be dumped\r
+ *  out of the serial port in HEX and ASCII form when it is attached to the AT90USB1287\r
+ *  AVR. The device will then wait for HWB to be pressed, whereupon the entire ASCII contents\r
+ *  of the disk will be dumped to the serial port.\r
+ *\r
+ *  \section SSec_Options Project Options\r
+ *\r
+ *  The following defines can be found in this demo, which can control the demo behaviour when defined, or changed in value.\r
+ *\r
+ *  <table>\r
+ *   <tr>\r
+ *    <td>\r
+ *     None\r
+ *    </td>\r
+ *   </tr>\r
+ *  </table>\r
  */
\ No newline at end of file
index f8ec0a0..b61850a 100644 (file)
@@ -45,8 +45,13 @@ BUTTLOADTAG(LUFAVersion, "LUFA V" LUFA_VERSION_STRING);
 /* Scheduler Task List */\r
 TASK_LIST\r
 {\r
+       #if !defined(INTERRUPT_CONTROL_ENDPOINT)\r
        { Task: USB_USBTask          , TaskStatus: TASK_STOP },\r
+       #endif\r
+       \r
+       #if !defined(INTERRUPT_DATA_ENDPOINT)\r
        { Task: USB_Mouse_Report     , TaskStatus: TASK_STOP },\r
+       #endif\r
 };\r
 \r
 /* Global Variables */\r
@@ -118,14 +123,34 @@ EVENT_HANDLER(USB_Connect)
        UsingReportProtocol = true;\r
 }\r
 \r
+/** Event handler for the USB_Reset event. This fires when the USB interface is reset by the USB host, before the\r
+ *  enumeration process begins, and enables the control endpoint interrupt so that control requests can be handled\r
+ *  asynchronously when they arrive rather than when the control endpoint is polled manually.\r
+ */\r
+EVENT_HANDLER(USB_Reset)\r
+{\r
+       #if defined(INTERRUPT_CONTROL_ENDPOINT)\r
+       /* Select the control endpoint */\r
+       Endpoint_SelectEndpoint(ENDPOINT_CONTROLEP);\r
+\r
+       /* Enable the endpoint SETUP interrupt ISR for the control endpoint */\r
+       USB_INT_Enable(ENDPOINT_INT_SETUP);\r
+       #endif\r
+}\r
+\r
 /** Event handler for the USB_Disconnect event. This indicates that the device is no longer connected to a host via\r
  *  the status LEDs and stops the USB management and Mouse reporting tasks.\r
  */\r
 EVENT_HANDLER(USB_Disconnect)\r
 {\r
-       /* Stop running mouse reporting and USB management tasks */\r
+       /* Stop running keyboard reporting and USB management tasks */\r
+       #if !defined(INTERRUPT_DATA_ENDPOINT)\r
        Scheduler_SetTaskMode(USB_Mouse_Report, TASK_STOP);\r
+       #endif\r
+\r
+       #if !defined(INTERRUPT_CONTROL_ENDPOINT)\r
        Scheduler_SetTaskMode(USB_USBTask, TASK_STOP);\r
+       #endif\r
 \r
        /* Indicate USB not ready */\r
        UpdateStatus(Status_USBNotReady);\r
@@ -141,11 +166,18 @@ EVENT_HANDLER(USB_ConfigurationChanged)
                                       ENDPOINT_DIR_IN, MOUSE_EPSIZE,\r
                                   ENDPOINT_BANK_SINGLE);\r
 \r
+       #if defined(INTERRUPT_DATA_ENDPOINT)\r
+       /* Enable the endpoint IN interrupt ISR for the report endpoint */\r
+       USB_INT_Enable(ENDPOINT_INT_IN);\r
+       #endif\r
+\r
        /* Indicate USB connected and ready */\r
        UpdateStatus(Status_USBReady);\r
 \r
+       #if !defined(INTERRUPT_DATA_ENDPOINT)\r
        /* Start running mouse reporting task */\r
        Scheduler_SetTaskMode(USB_Mouse_Report, TASK_RUN);\r
+       #endif\r
 }\r
 \r
 /** Event handler for the USB_UnhandledControlPacket event. This is used to catch standard and class specific\r
@@ -163,7 +195,7 @@ EVENT_HANDLER(USB_UnhandledControlPacket)
                                USB_MouseReport_Data_t MouseReportData;\r
 \r
                                /* Create the next mouse report for transmission to the host */\r
-                               GetNextReport(&MouseReportData);\r
+                               CreateMouseReport(&MouseReportData);\r
 \r
                                /* Ignore report type and ID number value */\r
                                Endpoint_Discard_Word();\r
@@ -278,7 +310,7 @@ ISR(TIMER0_COMPA_vect, ISR_BLOCK)
  *\r
  *  \return Boolean true if the new report differs from the last report, false otherwise\r
  */\r
-bool GetNextReport(USB_MouseReport_Data_t* ReportData)\r
+bool CreateMouseReport(USB_MouseReport_Data_t* ReportData)\r
 {\r
        static uint8_t PrevJoyStatus = 0;\r
        static bool    PrevHWBStatus = false;\r
@@ -315,6 +347,45 @@ bool GetNextReport(USB_MouseReport_Data_t* ReportData)
        return InputChanged;\r
 }\r
 \r
+/** Sends the next HID report to the host, via the keyboard data endpoint. */\r
+static inline void SendNextReport(void)\r
+{\r
+       USB_MouseReport_Data_t MouseReportData;\r
+       bool                   SendReport = true;\r
+       \r
+       /* Create the next mouse report for transmission to the host */\r
+       CreateMouseReport(&MouseReportData);\r
+       \r
+       /* Check if the idle period is set*/\r
+       if (IdleCount)\r
+       {\r
+               /* Determine if the idle period has elapsed */\r
+               if (!(IdleMSRemaining))\r
+               {\r
+                       /* Reset the idle time remaining counter, must multiply by 4 to get the duration in milliseconds */\r
+                       IdleMSRemaining = (IdleCount << 2);             \r
+               }\r
+               else\r
+               {\r
+                       /* Idle period not elapsed, indicate that a report must not be sent */\r
+                       SendReport = false;\r
+               }\r
+       }\r
+       \r
+       /* Select the Mouse Report Endpoint */\r
+       Endpoint_SelectEndpoint(MOUSE_EPNUM);\r
+\r
+       /* Check if Mouse Endpoint Ready for Read/Write and if we should send a new report */\r
+       if (Endpoint_ReadWriteAllowed() && SendReport)\r
+       {\r
+               /* Write Mouse Report Data */\r
+               Endpoint_Write_Stream_LE(&MouseReportData, sizeof(MouseReportData));\r
+               \r
+               /* Finalize the stream transfer to send the last packet */\r
+               Endpoint_ClearCurrentBank();\r
+       }\r
+}\r
+\r
 /** Function to manage status updates to the user. This is done via LEDs on the given board, if available, but may be changed to\r
  *  log to a serial port, or anything else that is suitable for status updates.\r
  *\r
@@ -342,45 +413,57 @@ void UpdateStatus(uint8_t CurrentStatus)
        LEDs_SetAllLEDs(LEDMask);\r
 }\r
 \r
+#if !defined(INTERRUPT_DATA_ENDPOINT)\r
 /** Task to manage HID report generation and transmission to the host, when in report mode. */\r
 TASK(USB_Mouse_Report)\r
 {\r
-       USB_MouseReport_Data_t MouseReportData;\r
-       bool                   SendReport = true;\r
-       \r
-       /* Create the next mouse report for transmission to the host */\r
-       GetNextReport(&MouseReportData);\r
-       \r
-       /* Check if the idle period is set*/\r
-       if (IdleCount)\r
+       /* Check if the USB system is connected to a host */\r
+       if (USB_IsConnected)\r
        {\r
-               /* Determine if the idle period has elapsed */\r
-               if (!(IdleMSRemaining))\r
-               {\r
-                       /* Reset the idle time remaining counter, must multiply by 4 to get the duration in milliseconds */\r
-                       IdleMSRemaining = (IdleCount << 2);             \r
-               }\r
-               else\r
-               {\r
-                       /* Idle period not elapsed, indicate that a report must not be sent */\r
-                       SendReport = false;\r
-               }\r
+               /* Send the next mouse report to the host */\r
+               SendNextReport();\r
        }\r
+}\r
+#endif\r
+\r
+/** ISR for the general Pipe/Endpoint interrupt vector. This ISR fires when an endpoint's status changes (such as\r
+ *  a packet has been received) on an endpoint with its corresponding ISR enabling bits set. This is used to send\r
+ *  HID packets to the host each time the HID interrupt endpoints polling period elapses, as managed by the USB\r
+ *  controller. It is also used to respond to standard and class specific requests send to the device on the control\r
+ *  endpoint, by handing them off to the LUFA library when they are received.\r
+ */\r
+ISR(ENDPOINT_PIPE_vect, ISR_BLOCK)\r
+{\r
+       #if defined(INTERRUPT_CONTROL_ENDPOINT)\r
+       /* Check if the control endpoint has received a request */\r
+       if (Endpoint_HasEndpointInterrupted(ENDPOINT_CONTROLEP))\r
+       {\r
+               /* Clear the endpoint interrupt */\r
+               Endpoint_ClearEndpointInterrupt(ENDPOINT_CONTROLEP);\r
+\r
+               /* Process the control request */\r
+               USB_USBTask();\r
+\r
+               /* Handshake the endpoint setup interrupt - must be after the call to USB_USBTask() */\r
+               USB_INT_Clear(ENDPOINT_INT_SETUP);\r
+       }\r
+       #endif\r
        \r
-       /* Check if the USB system is connected to a host */\r
-       if (USB_IsConnected)\r
+       #if defined(INTERRUPT_DATA_ENDPOINT)\r
+       /* Check if mouse endpoint has interrupted */\r
+       if (Endpoint_HasEndpointInterrupted(MOUSE_EPNUM))\r
        {\r
                /* Select the Mouse Report Endpoint */\r
                Endpoint_SelectEndpoint(MOUSE_EPNUM);\r
 \r
-               /* Check if Mouse Endpoint Ready for Read/Write and if we should send a new report */\r
-               if (Endpoint_ReadWriteAllowed() && SendReport)\r
-               {\r
-                       /* Write Mouse Report Data */\r
-                       Endpoint_Write_Stream_LE(&MouseReportData, sizeof(MouseReportData));\r
-                       \r
-                       /* Finalize the stream transfer to send the last packet */\r
-                       Endpoint_ClearCurrentBank();\r
-               }\r
+               /* Clear the endpoint IN interrupt flag */\r
+               USB_INT_Clear(ENDPOINT_INT_IN);\r
+\r
+               /* Clear the Mouse Report endpoint interrupt and select the endpoint */\r
+               Endpoint_ClearEndpointInterrupt(MOUSE_EPNUM);\r
+\r
+               /* Send the next mouse report to the host */\r
+               SendNextReport();\r
        }\r
+       #endif\r
 }\r
index 5090812..8723b78 100644 (file)
                /** Indicates that this module will catch the USB_Disconnect event when thrown by the library. */\r
                HANDLES_EVENT(USB_Disconnect);\r
 \r
+               /** Indicates that this module will catch the USB_Reset event when thrown by the library. */\r
+               HANDLES_EVENT(USB_Reset);\r
+\r
                /** Indicates that this module will catch the USB_ConfigurationChanged event when thrown by the library. */\r
                HANDLES_EVENT(USB_ConfigurationChanged);\r
 \r
                HANDLES_EVENT(USB_UnhandledControlPacket);\r
 \r
        /* Function Prototypes: */\r
-               bool GetNextReport(USB_MouseReport_Data_t* ReportData);\r
+               bool CreateMouseReport(USB_MouseReport_Data_t* ReportData);\r
                void UpdateStatus(uint8_t CurrentStatus);\r
 \r
 #endif\r
index 7b7360f..6764275 100644 (file)
@@ -6,17 +6,9 @@
  \r
 /** \mainpage Mouse Device Demo\r
  *\r
- *  Mouse demonstration application. This gives a simple reference\r
- *  application for implementing a USB Mouse using the basic USB HID\r
- *  drivers in all modern OSes (i.e. no special drivers required). It is\r
- *  boot protocol compatible, and thus works under compatible BIOS as if\r
- *  it was a native mouse (e.g. PS/2).\r
- *  \r
- *  On startup the system will automatically enumerate and function\r
- *  as a mouse when the USB connection to a host is present. To use\r
- *  the mouse, move the joystick to move the pointer, and push the\r
- *  joystick inwards to simulate a left-button click. The HWB serves as\r
- *  the right mouse button.\r
+ *  \section SSec_Info USB Information:\r
+ *\r
+ *  The following table gives a rundown of the USB utilization of this demo.\r
  *\r
  *  <table>\r
  *   <tr>\r
  *    <td>Low Speed Mode, Full Speed Mode</td>\r
  *   </tr>\r
  *  </table>\r
+ *\r
+ *  \section SSec_Description Project Description: \r
+ *\r
+ *  Mouse demonstration application. This gives a simple reference\r
+ *  application for implementing a USB Mouse using the basic USB HID\r
+ *  drivers in all modern OSes (i.e. no special drivers required). It is\r
+ *  boot protocol compatible, and thus works under compatible BIOS as if\r
+ *  it was a native mouse (e.g. PS/2).\r
+ *  \r
+ *  On startup the system will automatically enumerate and function\r
+ *  as a mouse when the USB connection to a host is present. To use\r
+ *  the mouse, move the joystick to move the pointer, and push the\r
+ *  joystick inwards to simulate a left-button click. The HWB serves as\r
+ *  the right mouse button.\r
+ *\r
+ *  \section SSec_Options Project Options\r
+ *\r
+ *  The following defines can be found in this demo, which can control the demo behaviour when defined, or changed in value.\r
+ *\r
+ *  <table>\r
+ *   <tr>\r
+ *    <td><b>Define Name:</b></td>\r
+ *    <td><b>Location:</b></td>\r
+ *    <td><b>Description:</b></td>\r
+ *   </tr>\r
+ *   <tr>\r
+ *    <td>INTERRUPT_CONTROL_ENDPOINT</td>\r
+ *    <td>Makefile CDEFS</td>\r
+ *    <td>When defined, this causes the demo to enable interrupts for the control endpoint,\r
+ *        which services control requests from the host. If not defined, the control endpoint\r
+ *        is serviced via polling using the task scheduler.</td>\r
+ *   </tr>\r
+ *   <tr>\r
+ *    <td>INTERRUPT_DATA_ENDPOINT</td>\r
+ *    <td>Makefile CDEFS</td>\r
+ *    <td>When defined, this causes the demo to enable interrupts for the data endpoint,\r
+ *        which services outgoing mouse button and movement reports to the host. If not defined,\r
+ *        the data endpoint is serviced via polling using the task scheduler.</td>\r
+ *   </tr>\r
+ *  </table>\r
  */
\ No newline at end of file
index a731e20..27ca1d8 100644 (file)
@@ -177,7 +177,6 @@ CDEFS  = -DF_CPU=$(F_CPU)UL -DF_CLOCK=$(F_CLOCK)UL -DBOARD=BOARD_$(BOARD)
 CDEFS += -DUSE_NONSTANDARD_DESCRIPTOR_NAMES -DNO_STREAM_CALLBACKS -DUSB_DEVICE_ONLY\r
 CDEFS += -DUSE_STATIC_OPTIONS="(USB_DEVICE_OPT_FULLSPEED | USB_OPT_REG_ENABLED | USB_OPT_AUTO_PLL)"\r
 \r
-\r
 # Place -D or -U options here for ASM sources\r
 ADEFS = -DF_CPU=$(F_CPU)\r
 \r
index 11c434c..a6d1ba8 100644 (file)
@@ -5,22 +5,10 @@
  */\r
  \r
 /** \mainpage Mouse Host Demo\r
- *  \r
- *  Mouse host demonstration application. This gives a simple reference\r
- *  application for implementing a USB Mouse host, for USB mice using\r
- *  the standard mouse HID profile.\r
- *  \r
- *  Mouse movement and button presses are displayed on the board LEDs,\r
- *  as well as printed out the serial terminal as formatted dY, dY and\r
- *  button status information.\r
- *  \r
- *  This uses a naive method where the mouse is set to Boot Protocol mode, so\r
- *  that the report structure is fixed and known. A better implementation\r
- *  uses the HID report parser for correct report data processing across\r
- *  all compatable mice with advanced characteristics, as shown in the\r
- *  MouseHostWithParser demo application.\r
- *  \r
- *  Currently only single interface mice are supported.        \r
+ *\r
+ *  \section SSec_Info USB Information:\r
+ *\r
+ *  The following table gives a rundown of the USB utilization of this demo.\r
  *\r
  *  <table>\r
  *   <tr>\r
  *    <td>Low Speed Mode, Full Speed Mode</td>\r
  *   </tr>\r
  *  </table>\r
+ *\r
+ *  \section SSec_Description Project Description: \r
+ *\r
+ *  Mouse host demonstration application. This gives a simple reference\r
+ *  application for implementing a USB Mouse host, for USB mice using\r
+ *  the standard mouse HID profile.\r
+ *  \r
+ *  Mouse movement and button presses are displayed on the board LEDs,\r
+ *  as well as printed out the serial terminal as formatted dY, dY and\r
+ *  button status information.\r
+ *  \r
+ *  This uses a naive method where the mouse is set to Boot Protocol mode, so\r
+ *  that the report structure is fixed and known. A better implementation\r
+ *  uses the HID report parser for correct report data processing across\r
+ *  all compatable mice with advanced characteristics, as shown in the\r
+ *  MouseHostWithParser demo application.\r
+ *  \r
+ *  Currently only single interface mice are supported.        \r
+ *\r
+ *  \section SSec_Options Project Options\r
+ *\r
+ *  The following defines can be found in this demo, which can control the demo behaviour when defined, or changed in value.\r
+ *\r
+ *  <table>\r
+ *   <tr>\r
+ *    <td>\r
+ *     None\r
+ *    </td>\r
+ *   </tr>\r
+ *  </table>\r
  */
\ No newline at end of file
index 72ee1db..7498655 100644 (file)
@@ -4,24 +4,9 @@
  *  documentation pages. It is not a project source file.\r
  */\r
  \r
-/** \mainpage Mouse Host Demo\r
- *  \r
- *  Mouse host demonstration application, using pipe interrupts. This\r
- *  gives a simple reference application for implementing a USB Mouse\r
- *  host utilizing the LUFA pipe interrupt system, for USB mice using\r
- *  the standard mouse HID profile.\r
- *  \r
- *  Mouse movement and button presses are displayed on the board LEDs,\r
- *  as well as printed out the serial terminal as formatted dY, dY and\r
- *  button status information.\r
- *  \r
- *  This uses a naive method where the mouse is set to Boot Protocol mode, so\r
- *  that the report structure is fixed and known. A better implementation\r
- *  uses the HID report parser for correct report data processing across\r
- *  all compatable mice with advanced characteristics, as shown in the\r
- *  MouseHostWithParser demo application.\r
- *  \r
- *  Currently only single interface mice are supported.        \r
+/** \mainpage Mouse Host Demo (via interrupts)\r
+ *\r
+ *  \section SSec_Info USB Information:\r
  *\r
  *  <table>\r
  *   <tr>\r
  *    <td>Low Speed Mode, Full Speed Mode</td>\r
  *   </tr>\r
  *  </table>\r
+ *\r
+ *  \section SSec_Description Project Description: \r
+ *\r
+ *  The following table gives a rundown of the USB utilization of this demo.\r
+ *\r
+ *  Mouse host demonstration application, using pipe interrupts. This\r
+ *  gives a simple reference application for implementing a USB Mouse\r
+ *  host utilizing the LUFA pipe interrupt system, for USB mice using\r
+ *  the standard mouse HID profile.\r
+ *  \r
+ *  Mouse movement and button presses are displayed on the board LEDs,\r
+ *  as well as printed out the serial terminal as formatted dY, dY and\r
+ *  button status information.\r
+ *  \r
+ *  This uses a naive method where the mouse is set to Boot Protocol mode, so\r
+ *  that the report structure is fixed and known. A better implementation\r
+ *  uses the HID report parser for correct report data processing across\r
+ *  all compatable mice with advanced characteristics, as shown in the\r
+ *  MouseHostWithParser demo application.\r
+ *  \r
+ *  Currently only single interface mice are supported.        \r
+ *\r
+ *  \section SSec_Options Project Options\r
+ *\r
+ *  The following defines can be found in this demo, which can control the demo behaviour when defined, or changed in value.\r
+ *\r
+ *  <table>\r
+ *   <tr>\r
+ *    <td>\r
+ *     None\r
+ *    </td>\r
+ *   </tr>\r
+ *  </table>\r
  */
\ No newline at end of file
index 97ee8bf..3c83341 100644 (file)
@@ -5,19 +5,10 @@
  */\r
  \r
 /** \mainpage Mouse Host With HID Descriptor Parser Demo\r
- *  \r
- *  Mouse host demonstration application. This gives a simple reference\r
- *  application for implementing a USB Mouse host, for USB mice using\r
- *  the standard mouse HID profile. It uses a HID parser for the HID\r
- *  reports, allowing for correct operation across all USB mice. This\r
- *  demo supports mice with a single HID report.\r
- *  \r
- *  Mouse movement and button presses are displayed on the board LEDs.\r
- *  On connection to a USB mouse, the report items will be processed and\r
- *  printed as a formatted list through the USART before the mouse is\r
- *  fully enumerated.\r
- *  \r
- *  Currently only single interface mice are supported.\r
+ *\r
+ *  \section SSec_Info USB Information:\r
+ *\r
+ *  The following table gives a rundown of the USB utilization of this demo.\r
  *\r
  *  <table>\r
  *   <tr>\r
  *    <td>Low Speed Mode, Full Speed Mode</td>\r
  *   </tr>\r
  *  </table>\r
+ *\r
+ *  \section SSec_Description Project Description: \r
+ *\r
+ *  Mouse host demonstration application. This gives a simple reference\r
+ *  application for implementing a USB Mouse host, for USB mice using\r
+ *  the standard mouse HID profile. It uses a HID parser for the HID\r
+ *  reports, allowing for correct operation across all USB mice. This\r
+ *  demo supports mice with a single HID report.\r
+ *  \r
+ *  Mouse movement and button presses are displayed on the board LEDs.\r
+ *  On connection to a USB mouse, the report items will be processed and\r
+ *  printed as a formatted list through the USART before the mouse is\r
+ *  fully enumerated.\r
+ *  \r
+ *  Currently only single interface mice are supported.\r
+ *\r
+ *  \section SSec_Options Project Options\r
+ *\r
+ *  The following defines can be found in this demo, which can control the demo behaviour when defined, or changed in value.\r
+ *\r
+ *  <table>\r
+ *   <tr>\r
+ *    <td>\r
+ *     None\r
+ *    </td>\r
+ *   </tr>\r
+ *  </table>\r
  */
\ No newline at end of file
index bd4ff69..306cf85 100644 (file)
@@ -5,7 +5,11 @@
  */\r
  \r
 /** \mainpage RNDIS Class Ethernet Demo (with Webserver/Telnet)\r
- *  \r
+ *\r
+ *  \section SSec_Info USB Information:\r
+ *\r
+ *  The following table gives a rundown of the USB utilization of this demo.\r
+ *\r
  *  Remote Network Driver Interface demonstration application.\r
  *  This gives a simple reference application for implementing\r
  *  a CDC RNDIS device acting as a simple network interface for\r
@@ -37,6 +41,8 @@
  *  recommended that it be replaced with an external open source TCP/IP\r
  *  stack that is feature complete, such as the uIP stack.\r
  *\r
+ *  \section SSec_Description Project Description: \r
+ *\r
  *  <table>\r
  *   <tr>\r
  *    <td><b>USB Mode:</b></td>\r
  *    <td>Full Speed Mode</td>\r
  *   </tr>\r
  *  </table>\r
+ *\r
+ *  \section SSec_Options Project Options\r
+ *\r
+ *  The following defines can be found in this demo, which can control the demo behaviour when defined, or changed in value.\r
+ *\r
+ *  <table>\r
+ *   <tr>\r
+ *    <td><b>Define Name:</b></td>\r
+ *    <td><b>Location:</b></td>\r
+ *    <td><b>Description:</b></td>\r
+ *   </tr>\r
+ *   <tr>\r
+ *    <td>NO_DECODE_ETHERNET</td>\r
+ *    <td>Makefile CDEFS</td>\r
+ *    <td>When defined, received Ethernet headers will not be decoded and printed to the device serial port.</td>\r
+ *   </tr>\r
+ *   <tr>\r
+ *    <td>NO_DECODE_ARP</td>\r
+ *    <td>Makefile CDEFS</td>\r
+ *    <td>When defined, received ARP headers will not be decoded and printed to the device serial port.</td>\r
+ *   </tr>\r
+ *   <tr>\r
+ *    <td>NO_DECODE_IP</td>\r
+ *    <td>Makefile CDEFS</td>\r
+ *    <td>When defined, received IP headers will not be decoded and printed to the device serial port.</td>\r
+ *   </tr>\r
+ *   <tr>\r
+ *    <td>NO_DECODE_ICMP</td>\r
+ *    <td>Makefile CDEFS</td>\r
+ *    <td>When defined, received ICMP headers will not be decoded and printed to the device serial port.</td>\r
+ *   </tr>\r
+ *   <tr>\r
+ *    <td>NO_DECODE_TCP</td>\r
+ *    <td>Makefile CDEFS</td>\r
+ *    <td>When defined, received TCP headers will not be decoded and printed to the device serial port.</td>\r
+ *   </tr>\r
+ *   <tr>\r
+ *    <td>NO_DECODE_UDP</td>\r
+ *    <td>Makefile CDEFS</td>\r
+ *    <td>When defined, received UDP headers will not be decoded and printed to the device serial port.</td>\r
+ *   </tr>\r
+ *   <tr>\r
+ *    <td>NO_DECODE_DHCP</td>\r
+ *    <td>Makefile CDEFS</td>\r
+ *    <td>When defined, received DHCP headers will not be decoded and printed to the device serial port.</td>\r
+ *   </tr>\r
+ *  </table>\r
  */
\ No newline at end of file
index 6e2657b..4cdfe63 100644 (file)
@@ -5,14 +5,10 @@
  */\r
  \r
 /** \mainpage Still Image Host Demo\r
- *  \r
- *  Still Image host demonstration application. This gives a simple reference\r
- *  application for implementing a Still Image host, for USB devices such as\r
- *  digital cameras.\r
- *  \r
- *  This demo will enumerate an attached USB Still Image device, print out its\r
- *  information structure, open a session with the device and finally close the\r
- *  session.\r
+ *\r
+ *  \section SSec_Info USB Information:\r
+ *\r
+ *  The following table gives a rundown of the USB utilization of this demo.\r
  *\r
  *  <table>\r
  *   <tr>\r
  *    <td>Full Speed Mode</td>\r
  *   </tr>\r
  *  </table>\r
+ *\r
+ *  \section SSec_Description Project Description: \r
+ *\r
+ *  Still Image host demonstration application. This gives a simple reference\r
+ *  application for implementing a Still Image host, for USB devices such as\r
+ *  digital cameras.\r
+ *  \r
+ *  This demo will enumerate an attached USB Still Image device, print out its\r
+ *  information structure, open a session with the device and finally close the\r
+ *  session.\r
+ *\r
+ *  \section SSec_Options Project Options\r
+ *\r
+ *  The following defines can be found in this demo, which can control the demo behaviour when defined, or changed in value.\r
+ *\r
+ *  <table>\r
+ *   <tr>\r
+ *    <td>\r
+ *     None\r
+ *    </td>\r
+ *   </tr>\r
+ *  </table>\r
  */
\ No newline at end of file
index e5b268a..aef55b7 100644 (file)
@@ -6,25 +6,9 @@
  \r
 /** \mainpage Test Application for the LUFA library\r
  *\r
- *  Test application. Demonstrates several aspects of the LUFA\r
- *  Library. On startup the current temperature will be printed\r
- *  through the USART every 10 seconds, and the current joystick\r
- *  position will be indicated via the LEDs on the selected board.\r
- *  Pressing the HWB will initiate the USB subsystem, enumerating\r
- *  the device (which has <b>no actual functionality beyond\r
- *  enumeration as a device or as a host in this demo</b>, and serves\r
- *  only to demonstrate the USB portion of the library). It will\r
- *  also suspend the joystick and temperature monitoring tasks.\r
- * \r
- *  Pressing the HWB a second time will turn off the USB system\r
- *  and resume the temperature printing task (but not the joystick\r
- *  monitoring task).\r
- *\r
- *  When activated, the USB events will be printed through the\r
- *  serial USART.\r
+ *  \section SSec_Info USB Information:\r
  *\r
- *  When the USB subsystem is activated, the board LEDs will show\r
- *  the current USB status.\r
+ *  The following table gives a rundown of the USB utilization of this demo.\r
  *\r
  *  <table>\r
  *   <tr>\r
  *    <td>Low Speed Mode, Full Speed Mode</td>\r
  *   </tr>\r
  *  </table>\r
+ *\r
+ *  \section SSec_Description Project Description: \r
+ *\r
+ *  Test application. Demonstrates several aspects of the LUFA\r
+ *  Library. On startup the current temperature will be printed\r
+ *  through the USART every 10 seconds, and the current joystick\r
+ *  position will be indicated via the LEDs on the selected board.\r
+ *  Pressing the HWB will initiate the USB subsystem, enumerating\r
+ *  the device (which has <b>no actual functionality beyond\r
+ *  enumeration as a device or as a host in this demo</b>, and serves\r
+ *  only to demonstrate the USB portion of the library). It will\r
+ *  also suspend the joystick and temperature monitoring tasks.\r
+ * \r
+ *  Pressing the HWB a second time will turn off the USB system\r
+ *  and resume the temperature printing task (but not the joystick\r
+ *  monitoring task).\r
+ *\r
+ *  When activated, the USB events will be printed through the\r
+ *  serial USART.\r
+ *\r
+ *  When the USB subsystem is activated, the board LEDs will show\r
+ *  the current USB status.\r
+ *\r
+ *  \section SSec_Options Project Options\r
+ *\r
+ *  The following defines can be found in this demo, which can control the demo behaviour when defined, or changed in value.\r
+ *\r
+ *  <table>\r
+ *   <tr>\r
+ *    <td>\r
+ *     None\r
+ *    </td>\r
+ *   </tr>\r
+ *  </table>\r
  */
\ No newline at end of file
index 992f00f..e334672 100644 (file)
@@ -6,19 +6,9 @@
  \r
 /** \mainpage USB to Serial Converter Demo (via CDC-ACM class)\r
  *\r
- *  Communications Device Class demonstration application.\r
- *  This gives a simple reference application for implementing\r
- *  a USB to Serial converter using the CDC class. Sent and\r
- *  received data on the serial port is communicated to the USB\r
- *  host.\r
- *  \r
- *  After running this demo for the first time on a new computer,\r
- *  you will need to supply the .INF file located in this demo\r
- *  project's directory as the device's driver when running under\r
- *  Windows. This will enable Windows to use its inbuilt CDC drivers,\r
- *  negating the need for custom drivers for the device. Other\r
- *  Operating Systems should automatically use their own inbuilt\r
- *  CDC-ACM drivers.\r
+ *  \section SSec_Info USB Information:\r
+ *\r
+ *  The following table gives a rundown of the USB utilization of this demo.\r
  *\r
  *  <table>\r
  *   <tr>\r
  *    <td>Full Speed Mode</td>\r
  *   </tr>\r
  *  </table>\r
+ *\r
+ *  \section SSec_Description Project Description: \r
+ *\r
+ *  Communications Device Class demonstration application.\r
+ *  This gives a simple reference application for implementing\r
+ *  a USB to Serial converter using the CDC class. Sent and\r
+ *  received data on the serial port is communicated to the USB\r
+ *  host.\r
+ *  \r
+ *  After running this demo for the first time on a new computer,\r
+ *  you will need to supply the .INF file located in this demo\r
+ *  project's directory as the device's driver when running under\r
+ *  Windows. This will enable Windows to use its inbuilt CDC drivers,\r
+ *  negating the need for custom drivers for the device. Other\r
+ *  Operating Systems should automatically use their own inbuilt\r
+ *  CDC-ACM drivers.\r
+ *\r
+ *  \section SSec_Options Project Options\r
+ *\r
+ *  The following defines can be found in this demo, which can control the demo behaviour when defined, or changed in value.\r
+ *\r
+ *  <table>\r
+ *   <tr>\r
+ *    <td><b>Define Name:</b></td>\r
+ *    <td><b>Location:</b></td>\r
+ *    <td><b>Description:</b></td>\r
+ *   </tr>\r
+ *   <tr>\r
+ *    <td>BUFF_STATICSIZE</td>\r
+ *    <td>RingBuff.h</td>\r
+ *    <td>Defines the maximum number of bytes which can be buffered in each Ring Buffer.</td>\r
+ *   </tr>\r
+ *  </table>\r
  */
\ No newline at end of file
index 2fd957a..8f44146 100644 (file)
@@ -58,12 +58,6 @@ all:
 
        make -C Mouse clean
        make -C Mouse all
-
-       make -C MouseFullInt clean
-       make -C MouseFullInt all
-
-       make -C MouseViaInt clean
-       make -C MouseViaInt all
        
        make -C MouseHost clean
        make -C MouseHost all
@@ -102,8 +96,6 @@ all:
        make -C MassStorageHost $@
        make -C MIDI $@
        make -C Mouse $@
-       make -C MouseFullInt $@
-       make -C MouseViaInt $@
        make -C MouseHost $@
        make -C MouseHostWithParser $@
        make -C MouseHostViaInt $@
index 3e21d73..77cdbe3 100644 (file)
@@ -1 +1 @@
-<Project name="LUFA"><Folder name="Demos"><Folder name="TestApp"><File path="Demos\TestApp\makefile"></File><File path="Demos\TestApp\TestApp.c"></File><File path="Demos\TestApp\TestApp.h"></File><File path="Demos\TestApp\TestEvents.c"></File><File path="Demos\TestApp\TestEvents.h"></File><File path="Demos\TestApp\Descriptors.c"></File><File path="Demos\TestApp\Descriptors.h"></File><File path="Demos\TestApp\TestApp.txt"></File><File path="Demos\TestApp\Doxygen.conf"></File></Folder><Folder name="Mouse"><File path="Demos\Mouse\makefile"></File><File path="Demos\Mouse\Descriptors.c"></File><File path="Demos\Mouse\Descriptors.h"></File><File path="Demos\Mouse\Mouse.h"></File><File path="Demos\Mouse\Mouse.c"></File><File path="Demos\Mouse\Mouse.txt"></File><File path="Demos\Mouse\Doxygen.conf"></File></Folder><Folder name="Keyboard"><File path="Demos\Keyboard\Descriptors.c"></File><File path="Demos\Keyboard\Keyboard.c"></File><File path="Demos\Keyboard\Descriptors.h"></File><File path="Demos\Keyboard\Keyboard.h"></File><File path="Demos\Keyboard\makefile"></File><File path="Demos\Keyboard\Keyboard.txt"></File><File path="Demos\Keyboard\Doxygen.conf"></File></Folder><Folder name="MouseHost"><File path="Demos\MouseHost\MouseHost.h"></File><File path="Demos\MouseHost\makefile"></File><File path="Demos\MouseHost\MouseHost.c"></File><File path="Demos\MouseHost\ConfigDescriptor.c"></File><File path="Demos\MouseHost\ConfigDescriptor.h"></File><File path="Demos\MouseHost\Doxygen.conf"></File><File path="Demos\MouseHost\MouseHost.txt"></File></Folder><Folder name="KeyboardHost"><File path="Demos\KeyboardHost\makefile"></File><File path="Demos\KeyboardHost\KeyboardHost.c"></File><File path="Demos\KeyboardHost\KeyboardHost.h"></File><File path="Demos\KeyboardHost\ConfigDescriptor.c"></File><File path="Demos\KeyboardHost\ConfigDescriptor.h"></File><File path="Demos\KeyboardHost\Doxygen.conf"></File><File path="Demos\KeyboardHost\KeyboardHost.txt"></File></Folder><Folder name="Joystick"><File path="Demos\Joystick\makefile"></File><File path="Demos\Joystick\Descriptors.c"></File><File path="Demos\Joystick\Descriptors.h"></File><File path="Demos\Joystick\Joystick.c"></File><File path="Demos\Joystick\Joystick.h"></File><File path="Demos\Joystick\Joystick.txt"></File><File path="Demos\Joystick\Doxygen.conf"></File></Folder><Folder name="CDC"><File path="Demos\CDC\makefile"></File><File path="Demos\CDC\CDC.c"></File><File path="Demos\CDC\CDC.h"></File><File path="Demos\CDC\Descriptors.c"></File><File path="Demos\CDC\Descriptors.h"></File><File path="Demos\CDC\CDC.txt"></File><File path="Demos\CDC\LUFA CDC.inf"></File><File path="Demos\CDC\Doxygen.conf"></File></Folder><Folder name="USBtoSerial"><File path="Demos\USBtoSerial\Descriptors.h"></File><File path="Demos\USBtoSerial\RingBuff.c"></File><File path="Demos\USBtoSerial\RingBuff.h"></File><File path="Demos\USBtoSerial\Descriptors.c"></File><File path="Demos\USBtoSerial\makefile"></File><File path="Demos\USBtoSerial\USBtoSerial.h"></File><File path="Demos\USBtoSerial\USBtoSerial.c"></File><File path="Demos\USBtoSerial\USBtoSerial.txt"></File><File path="Demos\USBtoSerial\LUFA USBtoSerial.inf"></File><File path="Demos\USBtoSerial\Doxygen.conf"></File></Folder><Folder name="MassStorage"><File path="Demos\MassStorage\MassStorage.h"></File><File path="Demos\MassStorage\Descriptors.c"></File><File path="Demos\MassStorage\Descriptors.h"></File><File path="Demos\MassStorage\makefile"></File><File path="Demos\MassStorage\MassStorage.c"></File><File path="Demos\MassStorage\SCSI.h"></File><File path="Demos\MassStorage\SCSI.c"></File><File path="Demos\MassStorage\DataflashManager.h"></File><File path="Demos\MassStorage\SCSI_Codes.h"></File><File path="Demos\MassStorage\MassStorage.txt"></File><File path="Demos\MassStorage\DataflashManager.c"></File><File path="Demos\MassStorage\Doxygen.conf"></File></Folder><Folder name="KeyboardHostViaInt"><File path="Demos\KeyboardHostViaInt\makefile"></File><File path="Demos\KeyboardHostViaInt\KeyboardHostViaInt.c"></File><File path="Demos\KeyboardHostViaInt\KeyboardHostViaInt.h"></File><File path="Demos\KeyboardHostViaInt\ConfigDescriptor.c"></File><File path="Demos\KeyboardHostViaInt\ConfigDescriptor.h"></File><File path="Demos\KeyboardHostViaInt\Doxygen.conf"></File><File path="Demos\KeyboardHostViaInt\KeyboardHostViaInt.txt"></File></Folder><Folder name="MouseHostViaInt"><File path="Demos\MouseHostViaInt\MouseHostViaInt.h"></File><File path="Demos\MouseHostViaInt\makefile"></File><File path="Demos\MouseHostViaInt\MouseHostViaInt.c"></File><File path="Demos\MouseHostViaInt\ConfigDescriptor.c"></File><File path="Demos\MouseHostViaInt\ConfigDescriptor.h"></File><File path="Demos\MouseHostViaInt\Doxygen.conf"></File><File path="Demos\MouseHostViaInt\MouseHostViaInt.txt"></File></Folder><Folder name="AudioOutput"><File path="Demos\AudioOutput\makefile"></File><File path="Demos\AudioOutput\AudioOutput.c"></File><File path="Demos\AudioOutput\AudioOutput.h"></File><File path="Demos\AudioOutput\Descriptors.c"></File><File path="Demos\AudioOutput\Descriptors.h"></File><File path="Demos\AudioOutput\Doxygen.conf"></File><File path="Demos\AudioOutput\AudioOutput.txt"></File></Folder><Folder name="MassStorageHost"><File path="Demos\MassStorageHost\MassStorageHost.h"></File><File path="Demos\MassStorageHost\makefile"></File><File path="Demos\MassStorageHost\MassStorageHost.c"></File><File path="Demos\MassStorageHost\MassStoreCommands.c"></File><File path="Demos\MassStorageHost\MassStoreCommands.h"></File><File path="Demos\MassStorageHost\ConfigDescriptor.c"></File><File path="Demos\MassStorageHost\ConfigDescriptor.h"></File><File path="Demos\MassStorageHost\Doxygen.conf"></File><File path="Demos\MassStorageHost\SCSI_Codes.h"></File><File path="Demos\MassStorageHost\MassStorageHost.txt"></File></Folder><Folder name="AudioInput"><File path="Demos\AudioInput\makefile"></File><File path="Demos\AudioInput\AudioInput.h"></File><File path="Demos\AudioInput\Descriptors.h"></File><File path="Demos\AudioInput\Descriptors.c"></File><File path="Demos\AudioInput\AudioInput.c"></File><File path="Demos\AudioInput\Doxygen.conf"></File><File path="Demos\AudioInput\AudioInput.txt"></File></Folder><Folder name="MouseViaInt"><File path="Demos\MouseViaInt\Descriptors.c"></File><File path="Demos\MouseViaInt\Descriptors.h"></File><File path="Demos\MouseViaInt\makefile"></File><File path="Demos\MouseViaInt\MouseViaInt.c"></File><File path="Demos\MouseViaInt\MouseViaInt.h"></File><File path="Demos\MouseViaInt\MouseViaInt.txt"></File><File path="Demos\MouseViaInt\Doxygen.conf"></File></Folder><Folder name="MouseFullInt"><File path="Demos\MouseFullInt\Descriptors.c"></File><File path="Demos\MouseFullInt\Descriptors.h"></File><File path="Demos\MouseFullInt\makefile"></File><File path="Demos\MouseFullInt\MouseFullInt.c"></File><File path="Demos\MouseFullInt\MouseFullInt.h"></File><File path="Demos\MouseFullInt\MouseFullInt.txt"></File><File path="Demos\MouseFullInt\Doxygen.conf"></File></Folder><Folder name="KeyboardHostWithParser"><File path="Demos\KeyboardHostWithParser\makefile"></File><File path="Demos\KeyboardHostWithParser\KeyboardHostWithParser.c"></File><File path="Demos\KeyboardHostWithParser\KeyboardHostWithParser.h"></File><File path="Demos\KeyboardHostWithParser\ConfigDescriptor.c"></File><File path="Demos\KeyboardHostWithParser\ConfigDescriptor.h"></File><File path="Demos\KeyboardHostWithParser\HIDReport.c"></File><File path="Demos\KeyboardHostWithParser\HIDReport.h"></File><File path="Demos\KeyboardHostWithParser\Doxygen.conf"></File><File path="Demos\KeyboardHostWithParser\KeyboardHostWithParser.txt"></File></Folder><Folder name="MouseHostWithParser"><File path="Demos\MouseHostWithParser\makefile"></File><File path="Demos\MouseHostWithParser\MouseHostWithParser.c"></File><File path="Demos\MouseHostWithParser\MouseHostWithParser.h"></File><File path="Demos\MouseHostWithParser\ConfigDescriptor.c"></File><File path="Demos\MouseHostWithParser\ConfigDescriptor.h"></File><File path="Demos\MouseHostWithParser\HIDReport.c"></File><File path="Demos\MouseHostWithParser\HIDReport.h"></File><File path="Demos\MouseHostWithParser\Doxygen.conf"></File><File path="Demos\MouseHostWithParser\MouseHostWithParser.txt"></File></Folder><Folder name="MIDI"><File path="Demos\MIDI\Descriptors.c"></File><File path="Demos\MIDI\Descriptors.h"></File><File path="Demos\MIDI\makefile"></File><File path="Demos\MIDI\MIDI.c"></File><File path="Demos\MIDI\MIDI.h"></File><File path="Demos\MIDI\Doxygen.conf"></File><File path="Demos\MIDI\MIDI.txt"></File></Folder><Folder name="CDCHost"><File path="Demos\CDCHost\CDCHost.c"></File><File path="Demos\CDCHost\CDCHost.h"></File><File path="Demos\CDCHost\makefile"></File><File path="Demos\CDCHost\ConfigDescriptor.c"></File><File path="Demos\CDCHost\ConfigDescriptor.h"></File><File path="Demos\CDCHost\Doxygen.conf"></File><File path="Demos\CDCHost\CDCHost.txt"></File></Folder><Folder name="StillImageHost"><File path="Demos\StillImageHost\makefile"></File><File path="Demos\StillImageHost\PIMACodes.h"></File><File path="Demos\StillImageHost\StillImageCommands.c"></File><File path="Demos\StillImageHost\StillImageCommands.h"></File><File path="Demos\StillImageHost\StillImageHost.c"></File><File path="Demos\StillImageHost\StillImageHost.h"></File><File path="Demos\StillImageHost\ConfigDescriptor.c"></File><File path="Demos\StillImageHost\ConfigDescriptor.h"></File><File path="Demos\StillImageHost\Doxygen.conf"></File></Folder><Folder name="RNDISEthernet"><File path="Demos\RNDISEthernet\RNDIS.c"></File><File path="Demos\RNDISEthernet\Descriptors.c"></File><File path="Demos\RNDISEthernet\Webserver.h"></File><File path="Demos\RNDISEthernet\ARP.c"></File><File path="Demos\RNDISEthernet\ARP.h"></File><File path="Demos\RNDISEthernet\Descriptors.h"></File><File path="Demos\RNDISEthernet\DHCP.c"></File><File path="Demos\RNDISEthernet\DHCP.h"></File><File path="Demos\RNDISEthernet\Ethernet.c"></File><File path="Demos\RNDISEthernet\Ethernet.h"></File><File path="Demos\RNDISEthernet\EthernetProtocols.h"></File><File path="Demos\RNDISEthernet\ICMP.c"></File><File path="Demos\RNDISEthernet\ICMP.h"></File><File path="Demos\RNDISEthernet\IP.c"></File><File path="Demos\RNDISEthernet\IP.h"></File><File path="Demos\RNDISEthernet\makefile"></File><File path="Demos\RNDISEthernet\ProtocolDecoders.c"></File><File path="Demos\RNDISEthernet\ProtocolDecoders.h"></File><File path="Demos\RNDISEthernet\RNDIS.h"></File><File path="Demos\RNDISEthernet\RNDISEthernet.aps"></File><File path="Demos\RNDISEthernet\RNDISEthernet.c"></File><File path="Demos\RNDISEthernet\RNDISEthernet.h"></File><File path="Demos\RNDISEthernet\TCP.c"></File><File path="Demos\RNDISEthernet\TCP.h"></File><File path="Demos\RNDISEthernet\UDP.c"></File><File path="Demos\RNDISEthernet\UDP.h"></File><File path="Demos\RNDISEthernet\Webserver.c"></File><File path="Demos\RNDISEthernet\LUFA RNDIS.inf"></File><File path="Demos\RNDISEthernet\Doxygen.conf"></File><File path="Demos\RNDISEthernet\RNDISEthernet.txt"></File><File path="Demos\RNDISEthernet\RNDISConstants.h"></File></Folder><Folder name="KeyboardMouse"><File path="Demos\KeyboardMouse\Descriptors.c"></File><File path="Demos\KeyboardMouse\Descriptors.h"></File><File path="Demos\KeyboardMouse\KeyboardMouse.c"></File><File path="Demos\KeyboardMouse\KeyboardMouse.h"></File><File path="Demos\KeyboardMouse\makefile"></File><File path="Demos\KeyboardMouse\KeyboardMouse.txt"></File><File path="Demos\KeyboardMouse\Doxygen.conf"></File></Folder><Folder name="DualCDC"><File path="Demos\DualCDC\Descriptors.c"></File><File path="Demos\DualCDC\Descriptors.h"></File><File path="Demos\DualCDC\makefile"></File><File path="Demos\DualCDC\DualCDC.c"></File><File path="Demos\DualCDC\DualCDC.h"></File><File path="Demos\DualCDC\DualCDC.txt"></File><File path="Demos\DualCDC\LUFA DualCDC.inf"></File><File path="Demos\DualCDC\Doxygen.conf"></File></Folder><File path="Demos\makefile"></File></Folder><Folder name="LUFA"><Folder name="Common"><File path="LUFA\Common\Common.h"></File><File path="LUFA\Common\FunctionAttributes.h"></File><File path="LUFA\Common\ButtLoadTag.h"></File><File path="LUFA\Common\BoardTypes.h"></File></Folder><Folder name="Drivers"><Folder name="USB"><Folder name="LowLevel"><File path="LUFA\Drivers\USB\LowLevel\HostChapter9.h"></File><File path="LUFA\Drivers\USB\LowLevel\LowLevel.c"></File><File path="LUFA\Drivers\USB\LowLevel\LowLevel.h"></File><File path="LUFA\Drivers\USB\LowLevel\Pipe.c"></File><File path="LUFA\Drivers\USB\LowLevel\Pipe.h"></File><File path="LUFA\Drivers\USB\LowLevel\StdRequestType.h"></File><File path="LUFA\Drivers\USB\LowLevel\DevChapter9.c"></File><File path="LUFA\Drivers\USB\LowLevel\DevChapter9.h"></File><File path="LUFA\Drivers\USB\LowLevel\Device.h"></File><File path="LUFA\Drivers\USB\LowLevel\Endpoint.c"></File><File path="LUFA\Drivers\USB\LowLevel\Endpoint.h"></File><File path="LUFA\Drivers\USB\LowLevel\Host.c"></File><File path="LUFA\Drivers\USB\LowLevel\Host.h"></File><File path="LUFA\Drivers\USB\LowLevel\HostChapter9.c"></File><File path="LUFA\Drivers\USB\LowLevel\OTG.h"></File><File path="LUFA\Drivers\USB\LowLevel\USBMode.h"></File><File path="LUFA\Drivers\USB\LowLevel\StreamCallbacks.h"></File></Folder><Folder name="HighLevel"><File path="LUFA\Drivers\USB\HighLevel\USBTask.h"></File><File path="LUFA\Drivers\USB\HighLevel\Events.c"></File><File path="LUFA\Drivers\USB\HighLevel\Events.h"></File><File path="LUFA\Drivers\USB\HighLevel\USBInterrupt.c"></File><File path="LUFA\Drivers\USB\HighLevel\USBInterrupt.h"></File><File path="LUFA\Drivers\USB\HighLevel\USBTask.c"></File><File path="LUFA\Drivers\USB\HighLevel\StdDescriptors.c"></File><File path="LUFA\Drivers\USB\HighLevel\StdDescriptors.h"></File></Folder><Folder name="Class"><File path="LUFA\Drivers\USB\Class\HIDParser.c"></File><File path="LUFA\Drivers\USB\Class\HIDParser.h"></File><File path="LUFA\Drivers\USB\Class\HIDReportData.h"></File><File path="LUFA\Drivers\USB\Class\ConfigDescriptor.c"></File><File path="LUFA\Drivers\USB\Class\ConfigDescriptor.h"></File></Folder><File path="LUFA\Drivers\USB\USB.h"></File></Folder><Folder name="Misc"><File path="LUFA\Drivers\Misc\TerminalCodes.h"></File></Folder><Folder name="AT90USBXXX"><Folder name="AT90USBXXX67"><File path="LUFA\Drivers\AT90USBXXX\AT90USBXXX67\ADC.h"></File></Folder><File path="LUFA\Drivers\AT90USBXXX\Serial_Stream.h"></File><File path="LUFA\Drivers\AT90USBXXX\ADC.h"></File><File path="LUFA\Drivers\AT90USBXXX\Serial.c"></File><File path="LUFA\Drivers\AT90USBXXX\Serial.h"></File><File path="LUFA\Drivers\AT90USBXXX\Serial_Stream.c"></File><File path="LUFA\Drivers\AT90USBXXX\SPI.h"></File></Folder><Folder name="Board"><Folder name="USBKEY"><File path="LUFA\Drivers\Board\USBKEY\Dataflash.h"></File><File path="LUFA\Drivers\Board\USBKEY\Joystick.h"></File><File path="LUFA\Drivers\Board\USBKEY\HWB.h"></File><File path="LUFA\Drivers\Board\USBKEY\AT45DB642D.h"></File><File path="LUFA\Drivers\Board\USBKEY\LEDs.h"></File></Folder><Folder name="STK526"><File path="LUFA\Drivers\Board\STK526\Dataflash.h"></File><File path="LUFA\Drivers\Board\STK526\Joystick.h"></File><File path="LUFA\Drivers\Board\STK526\HWB.h"></File><File path="LUFA\Drivers\Board\STK526\AT45DB642D.h"></File><File path="LUFA\Drivers\Board\STK526\LEDs.h"></File></Folder><Folder name="STK525"><File path="LUFA\Drivers\Board\STK525\Dataflash.h"></File><File path="LUFA\Drivers\Board\STK525\Joystick.h"></File><File path="LUFA\Drivers\Board\STK525\HWB.h"></File><File path="LUFA\Drivers\Board\STK525\AT45DB321C.h"></File><File path="LUFA\Drivers\Board\STK525\LEDs.h"></File></Folder><Folder name="RZUSBSTICK"><File path="LUFA\Drivers\Board\RZUSBSTICK\LEDs.h"></File></Folder><Folder name="ATAVRUSBRF01"><File path="LUFA\Drivers\Board\ATAVRUSBRF01\LEDs.h"></File><File path="LUFA\Drivers\Board\ATAVRUSBRF01\HWB.h"></File></Folder><File path="LUFA\Drivers\Board\Temperature.h"></File><File path="LUFA\Drivers\Board\Dataflash.h"></File><File path="LUFA\Drivers\Board\HWB.h"></File><File path="LUFA\Drivers\Board\Joystick.h"></File><File path="LUFA\Drivers\Board\Temperature.c"></File><File path="LUFA\Drivers\Board\LEDs.h"></File></Folder></Folder><Folder name="Scheduler"><File path="LUFA\Scheduler\Scheduler.h"></File><File path="LUFA\Scheduler\Scheduler.c"></File></Folder><Folder name="MemoryAllocator"><File path="LUFA\MemoryAllocator\DynAlloc.h"></File><File path="LUFA\MemoryAllocator\DynAlloc.c"></File></Folder><Folder name="DriverStubs"><File path="LUFA\DriverStubs\Dataflash.h"></File><File path="LUFA\DriverStubs\HWB.h"></File><File path="LUFA\DriverStubs\Joystick.h"></File><File path="LUFA\DriverStubs\LEDs.h"></File></Folder><File path="LUFA\makefile"></File><File path="LUFA\Version.h"></File><File path="LUFA\BuildingLinkableLibraries.txt"></File><File path="LUFA\GettingStarted.txt"></File><File path="LUFA\MainPage.txt"></File><File path="LUFA\SchedulerOverview.txt"></File><File path="LUFA\VIDAndPIDValues.txt"></File><File path="LUFA\ChangeLog.txt"></File><File path="LUFA\CompileTimeTokens.txt"></File><File path="LUFA\MigrationInformation.txt"></File><File path="LUFA\DirectorySummaries.txt"></File><File path="LUFA\Doxygen.conf"></File><File path="LUFA\WritingBoardDrivers.txt"></File></Folder><Folder name="Projects"><Folder name="MagStripe"><File path="Projects\Magstripe\Descriptors.c"></File><File path="Projects\Magstripe\Descriptors.h"></File><File path="Projects\Magstripe\Magstripe.c"></File><File path="Projects\Magstripe\Magstripe.h"></File><File path="Projects\Magstripe\MagstripeHW.h"></File><File path="Projects\Magstripe\makefile"></File><File path="Projects\Magstripe\Magstripe.txt"></File><File path="Projects\Magstripe\Doxygen.conf"></File><File path="Projects\Magstripe\CircularBitBuffer.c"></File><File path="Projects\Magstripe\CircularBitBuffer.h"></File></Folder><Folder name="AVRISP_Programmer"><File path="Projects\AVRISP_Programmer\AVRISP_Firmware_Design.txt"></File><File path="Projects\AVRISP_Programmer\AVRISP_Programmer.c"></File><File path="Projects\AVRISP_Programmer\AVRISP_Programmer.h"></File><File path="Projects\AVRISP_Programmer\AVRISP_Programmer.txt"></File><File path="Projects\AVRISP_Programmer\Descriptors.c"></File><File path="Projects\AVRISP_Programmer\makefile"></File><File path="Projects\AVRISP_Programmer\Sample_Programming_Session.txt"></File><File path="Projects\AVRISP_Programmer\RingBuff.c"></File><File path="Projects\AVRISP_Programmer\RingBuff.h"></File><File path="Projects\AVRISP_Programmer\Descriptors.h"></File></Folder><File path="Projects\makefile"></File></Folder><Folder name="Bootloaders"><Folder name="DFU"><File path="Bootloaders\DFU\BootloaderDFU.c"></File><File path="Bootloaders\DFU\BootloaderDFU.h"></File><File path="Bootloaders\DFU\Descriptors.c"></File><File path="Bootloaders\DFU\Descriptors.h"></File><File path="Bootloaders\DFU\makefile"></File><File path="Bootloaders\DFU\BootloaderDFU.txt"></File><File path="Bootloaders\DFU\Doxygen.conf"></File></Folder><Folder name="CDC"><File path="Bootloaders\CDC\BootloaderCDC.c"></File><File path="Bootloaders\CDC\BootloaderCDC.h"></File><File path="Bootloaders\CDC\Descriptors.c"></File><File path="Bootloaders\CDC\Descriptors.h"></File><File path="Bootloaders\CDC\makefile"></File><File path="Bootloaders\CDC\LUFA CDC Bootloader.inf"></File><File path="Bootloaders\CDC\Doxygen.conf"></File><File path="Bootloaders\CDC\BootloaderCDC.txt"></File></Folder><Folder name="TeensyHID"><File path="Bootloaders\TeensyHID\Descriptors.c"></File><File path="Bootloaders\TeensyHID\Descriptors.h"></File><File path="Bootloaders\TeensyHID\makefile"></File><File path="Bootloaders\TeensyHID\TeensyHID.c"></File><File path="Bootloaders\TeensyHID\TeensyHID.h"></File><File path="Bootloaders\TeensyHID\TeensyHID.txt"></File></Folder><File path="Bootloaders\makefile"></File></Folder><File path="makefile"></File></Project>
\ No newline at end of file
+<Project name="LUFA"><Folder name="Demos"><Folder name="TestApp"><File path="Demos\TestApp\makefile"></File><File path="Demos\TestApp\TestApp.c"></File><File path="Demos\TestApp\TestApp.h"></File><File path="Demos\TestApp\TestEvents.c"></File><File path="Demos\TestApp\TestEvents.h"></File><File path="Demos\TestApp\Descriptors.c"></File><File path="Demos\TestApp\Descriptors.h"></File><File path="Demos\TestApp\TestApp.txt"></File><File path="Demos\TestApp\Doxygen.conf"></File></Folder><Folder name="Mouse"><File path="Demos\Mouse\makefile"></File><File path="Demos\Mouse\Descriptors.c"></File><File path="Demos\Mouse\Descriptors.h"></File><File path="Demos\Mouse\Mouse.h"></File><File path="Demos\Mouse\Mouse.c"></File><File path="Demos\Mouse\Mouse.txt"></File><File path="Demos\Mouse\Doxygen.conf"></File></Folder><Folder name="Keyboard"><File path="Demos\Keyboard\Descriptors.c"></File><File path="Demos\Keyboard\Keyboard.c"></File><File path="Demos\Keyboard\Descriptors.h"></File><File path="Demos\Keyboard\Keyboard.h"></File><File path="Demos\Keyboard\makefile"></File><File path="Demos\Keyboard\Keyboard.txt"></File><File path="Demos\Keyboard\Doxygen.conf"></File></Folder><Folder name="MouseHost"><File path="Demos\MouseHost\MouseHost.h"></File><File path="Demos\MouseHost\makefile"></File><File path="Demos\MouseHost\MouseHost.c"></File><File path="Demos\MouseHost\ConfigDescriptor.c"></File><File path="Demos\MouseHost\ConfigDescriptor.h"></File><File path="Demos\MouseHost\Doxygen.conf"></File><File path="Demos\MouseHost\MouseHost.txt"></File></Folder><Folder name="KeyboardHost"><File path="Demos\KeyboardHost\makefile"></File><File path="Demos\KeyboardHost\KeyboardHost.c"></File><File path="Demos\KeyboardHost\KeyboardHost.h"></File><File path="Demos\KeyboardHost\ConfigDescriptor.c"></File><File path="Demos\KeyboardHost\ConfigDescriptor.h"></File><File path="Demos\KeyboardHost\Doxygen.conf"></File><File path="Demos\KeyboardHost\KeyboardHost.txt"></File></Folder><Folder name="Joystick"><File path="Demos\Joystick\makefile"></File><File path="Demos\Joystick\Descriptors.c"></File><File path="Demos\Joystick\Descriptors.h"></File><File path="Demos\Joystick\Joystick.c"></File><File path="Demos\Joystick\Joystick.h"></File><File path="Demos\Joystick\Joystick.txt"></File><File path="Demos\Joystick\Doxygen.conf"></File></Folder><Folder name="CDC"><File path="Demos\CDC\makefile"></File><File path="Demos\CDC\CDC.c"></File><File path="Demos\CDC\CDC.h"></File><File path="Demos\CDC\Descriptors.c"></File><File path="Demos\CDC\Descriptors.h"></File><File path="Demos\CDC\CDC.txt"></File><File path="Demos\CDC\LUFA CDC.inf"></File><File path="Demos\CDC\Doxygen.conf"></File></Folder><Folder name="USBtoSerial"><File path="Demos\USBtoSerial\Descriptors.h"></File><File path="Demos\USBtoSerial\RingBuff.c"></File><File path="Demos\USBtoSerial\RingBuff.h"></File><File path="Demos\USBtoSerial\Descriptors.c"></File><File path="Demos\USBtoSerial\makefile"></File><File path="Demos\USBtoSerial\USBtoSerial.h"></File><File path="Demos\USBtoSerial\USBtoSerial.c"></File><File path="Demos\USBtoSerial\USBtoSerial.txt"></File><File path="Demos\USBtoSerial\LUFA USBtoSerial.inf"></File><File path="Demos\USBtoSerial\Doxygen.conf"></File></Folder><Folder name="MassStorage"><File path="Demos\MassStorage\MassStorage.h"></File><File path="Demos\MassStorage\Descriptors.c"></File><File path="Demos\MassStorage\Descriptors.h"></File><File path="Demos\MassStorage\makefile"></File><File path="Demos\MassStorage\MassStorage.c"></File><File path="Demos\MassStorage\SCSI.h"></File><File path="Demos\MassStorage\SCSI.c"></File><File path="Demos\MassStorage\DataflashManager.h"></File><File path="Demos\MassStorage\SCSI_Codes.h"></File><File path="Demos\MassStorage\MassStorage.txt"></File><File path="Demos\MassStorage\DataflashManager.c"></File><File path="Demos\MassStorage\Doxygen.conf"></File></Folder><Folder name="KeyboardHostViaInt"><File path="Demos\KeyboardHostViaInt\makefile"></File><File path="Demos\KeyboardHostViaInt\KeyboardHostViaInt.c"></File><File path="Demos\KeyboardHostViaInt\KeyboardHostViaInt.h"></File><File path="Demos\KeyboardHostViaInt\ConfigDescriptor.c"></File><File path="Demos\KeyboardHostViaInt\ConfigDescriptor.h"></File><File path="Demos\KeyboardHostViaInt\Doxygen.conf"></File><File path="Demos\KeyboardHostViaInt\KeyboardHostViaInt.txt"></File></Folder><Folder name="MouseHostViaInt"><File path="Demos\MouseHostViaInt\MouseHostViaInt.h"></File><File path="Demos\MouseHostViaInt\makefile"></File><File path="Demos\MouseHostViaInt\MouseHostViaInt.c"></File><File path="Demos\MouseHostViaInt\ConfigDescriptor.c"></File><File path="Demos\MouseHostViaInt\ConfigDescriptor.h"></File><File path="Demos\MouseHostViaInt\Doxygen.conf"></File><File path="Demos\MouseHostViaInt\MouseHostViaInt.txt"></File></Folder><Folder name="AudioOutput"><File path="Demos\AudioOutput\makefile"></File><File path="Demos\AudioOutput\AudioOutput.c"></File><File path="Demos\AudioOutput\AudioOutput.h"></File><File path="Demos\AudioOutput\Descriptors.c"></File><File path="Demos\AudioOutput\Descriptors.h"></File><File path="Demos\AudioOutput\Doxygen.conf"></File><File path="Demos\AudioOutput\AudioOutput.txt"></File></Folder><Folder name="MassStorageHost"><File path="Demos\MassStorageHost\MassStorageHost.h"></File><File path="Demos\MassStorageHost\makefile"></File><File path="Demos\MassStorageHost\MassStorageHost.c"></File><File path="Demos\MassStorageHost\MassStoreCommands.c"></File><File path="Demos\MassStorageHost\MassStoreCommands.h"></File><File path="Demos\MassStorageHost\ConfigDescriptor.c"></File><File path="Demos\MassStorageHost\ConfigDescriptor.h"></File><File path="Demos\MassStorageHost\Doxygen.conf"></File><File path="Demos\MassStorageHost\SCSI_Codes.h"></File><File path="Demos\MassStorageHost\MassStorageHost.txt"></File></Folder><Folder name="AudioInput"><File path="Demos\AudioInput\makefile"></File><File path="Demos\AudioInput\AudioInput.h"></File><File path="Demos\AudioInput\Descriptors.h"></File><File path="Demos\AudioInput\Descriptors.c"></File><File path="Demos\AudioInput\AudioInput.c"></File><File path="Demos\AudioInput\Doxygen.conf"></File><File path="Demos\AudioInput\AudioInput.txt"></File></Folder><Folder name="KeyboardHostWithParser"><File path="Demos\KeyboardHostWithParser\makefile"></File><File path="Demos\KeyboardHostWithParser\KeyboardHostWithParser.c"></File><File path="Demos\KeyboardHostWithParser\KeyboardHostWithParser.h"></File><File path="Demos\KeyboardHostWithParser\ConfigDescriptor.c"></File><File path="Demos\KeyboardHostWithParser\ConfigDescriptor.h"></File><File path="Demos\KeyboardHostWithParser\HIDReport.c"></File><File path="Demos\KeyboardHostWithParser\HIDReport.h"></File><File path="Demos\KeyboardHostWithParser\Doxygen.conf"></File><File path="Demos\KeyboardHostWithParser\KeyboardHostWithParser.txt"></File></Folder><Folder name="MouseHostWithParser"><File path="Demos\MouseHostWithParser\makefile"></File><File path="Demos\MouseHostWithParser\MouseHostWithParser.c"></File><File path="Demos\MouseHostWithParser\MouseHostWithParser.h"></File><File path="Demos\MouseHostWithParser\ConfigDescriptor.c"></File><File path="Demos\MouseHostWithParser\ConfigDescriptor.h"></File><File path="Demos\MouseHostWithParser\HIDReport.c"></File><File path="Demos\MouseHostWithParser\HIDReport.h"></File><File path="Demos\MouseHostWithParser\Doxygen.conf"></File><File path="Demos\MouseHostWithParser\MouseHostWithParser.txt"></File></Folder><Folder name="MIDI"><File path="Demos\MIDI\Descriptors.c"></File><File path="Demos\MIDI\Descriptors.h"></File><File path="Demos\MIDI\makefile"></File><File path="Demos\MIDI\MIDI.c"></File><File path="Demos\MIDI\MIDI.h"></File><File path="Demos\MIDI\Doxygen.conf"></File><File path="Demos\MIDI\MIDI.txt"></File></Folder><Folder name="CDCHost"><File path="Demos\CDCHost\CDCHost.c"></File><File path="Demos\CDCHost\CDCHost.h"></File><File path="Demos\CDCHost\makefile"></File><File path="Demos\CDCHost\ConfigDescriptor.c"></File><File path="Demos\CDCHost\ConfigDescriptor.h"></File><File path="Demos\CDCHost\Doxygen.conf"></File><File path="Demos\CDCHost\CDCHost.txt"></File></Folder><Folder name="StillImageHost"><File path="Demos\StillImageHost\makefile"></File><File path="Demos\StillImageHost\PIMACodes.h"></File><File path="Demos\StillImageHost\StillImageCommands.c"></File><File path="Demos\StillImageHost\StillImageCommands.h"></File><File path="Demos\StillImageHost\StillImageHost.c"></File><File path="Demos\StillImageHost\StillImageHost.h"></File><File path="Demos\StillImageHost\ConfigDescriptor.c"></File><File path="Demos\StillImageHost\ConfigDescriptor.h"></File><File path="Demos\StillImageHost\Doxygen.conf"></File><File path="Demos\StillImageHost\StillImageHost.txt"></File></Folder><Folder name="RNDISEthernet"><File path="Demos\RNDISEthernet\RNDIS.c"></File><File path="Demos\RNDISEthernet\Descriptors.c"></File><File path="Demos\RNDISEthernet\Webserver.h"></File><File path="Demos\RNDISEthernet\ARP.c"></File><File path="Demos\RNDISEthernet\ARP.h"></File><File path="Demos\RNDISEthernet\Descriptors.h"></File><File path="Demos\RNDISEthernet\DHCP.c"></File><File path="Demos\RNDISEthernet\DHCP.h"></File><File path="Demos\RNDISEthernet\Ethernet.c"></File><File path="Demos\RNDISEthernet\Ethernet.h"></File><File path="Demos\RNDISEthernet\EthernetProtocols.h"></File><File path="Demos\RNDISEthernet\ICMP.c"></File><File path="Demos\RNDISEthernet\ICMP.h"></File><File path="Demos\RNDISEthernet\IP.c"></File><File path="Demos\RNDISEthernet\IP.h"></File><File path="Demos\RNDISEthernet\makefile"></File><File path="Demos\RNDISEthernet\ProtocolDecoders.c"></File><File path="Demos\RNDISEthernet\ProtocolDecoders.h"></File><File path="Demos\RNDISEthernet\RNDIS.h"></File><File path="Demos\RNDISEthernet\RNDISEthernet.aps"></File><File path="Demos\RNDISEthernet\RNDISEthernet.c"></File><File path="Demos\RNDISEthernet\RNDISEthernet.h"></File><File path="Demos\RNDISEthernet\TCP.c"></File><File path="Demos\RNDISEthernet\TCP.h"></File><File path="Demos\RNDISEthernet\UDP.c"></File><File path="Demos\RNDISEthernet\UDP.h"></File><File path="Demos\RNDISEthernet\Webserver.c"></File><File path="Demos\RNDISEthernet\LUFA RNDIS.inf"></File><File path="Demos\RNDISEthernet\Doxygen.conf"></File><File path="Demos\RNDISEthernet\RNDISEthernet.txt"></File><File path="Demos\RNDISEthernet\RNDISConstants.h"></File></Folder><Folder name="KeyboardMouse"><File path="Demos\KeyboardMouse\Descriptors.c"></File><File path="Demos\KeyboardMouse\Descriptors.h"></File><File path="Demos\KeyboardMouse\KeyboardMouse.c"></File><File path="Demos\KeyboardMouse\KeyboardMouse.h"></File><File path="Demos\KeyboardMouse\makefile"></File><File path="Demos\KeyboardMouse\KeyboardMouse.txt"></File><File path="Demos\KeyboardMouse\Doxygen.conf"></File></Folder><Folder name="DualCDC"><File path="Demos\DualCDC\Descriptors.c"></File><File path="Demos\DualCDC\Descriptors.h"></File><File path="Demos\DualCDC\makefile"></File><File path="Demos\DualCDC\DualCDC.c"></File><File path="Demos\DualCDC\DualCDC.h"></File><File path="Demos\DualCDC\DualCDC.txt"></File><File path="Demos\DualCDC\LUFA DualCDC.inf"></File><File path="Demos\DualCDC\Doxygen.conf"></File></Folder><File path="Demos\makefile"></File></Folder><Folder name="LUFA"><Folder name="Common"><File path="LUFA\Common\Common.h"></File><File path="LUFA\Common\FunctionAttributes.h"></File><File path="LUFA\Common\ButtLoadTag.h"></File><File path="LUFA\Common\BoardTypes.h"></File></Folder><Folder name="Drivers"><Folder name="USB"><Folder name="LowLevel"><File path="LUFA\Drivers\USB\LowLevel\HostChapter9.h"></File><File path="LUFA\Drivers\USB\LowLevel\LowLevel.c"></File><File path="LUFA\Drivers\USB\LowLevel\LowLevel.h"></File><File path="LUFA\Drivers\USB\LowLevel\Pipe.c"></File><File path="LUFA\Drivers\USB\LowLevel\Pipe.h"></File><File path="LUFA\Drivers\USB\LowLevel\StdRequestType.h"></File><File path="LUFA\Drivers\USB\LowLevel\DevChapter9.c"></File><File path="LUFA\Drivers\USB\LowLevel\DevChapter9.h"></File><File path="LUFA\Drivers\USB\LowLevel\Device.h"></File><File path="LUFA\Drivers\USB\LowLevel\Endpoint.c"></File><File path="LUFA\Drivers\USB\LowLevel\Endpoint.h"></File><File path="LUFA\Drivers\USB\LowLevel\Host.c"></File><File path="LUFA\Drivers\USB\LowLevel\Host.h"></File><File path="LUFA\Drivers\USB\LowLevel\HostChapter9.c"></File><File path="LUFA\Drivers\USB\LowLevel\OTG.h"></File><File path="LUFA\Drivers\USB\LowLevel\USBMode.h"></File><File path="LUFA\Drivers\USB\LowLevel\StreamCallbacks.h"></File></Folder><Folder name="HighLevel"><File path="LUFA\Drivers\USB\HighLevel\USBTask.h"></File><File path="LUFA\Drivers\USB\HighLevel\Events.c"></File><File path="LUFA\Drivers\USB\HighLevel\Events.h"></File><File path="LUFA\Drivers\USB\HighLevel\USBInterrupt.c"></File><File path="LUFA\Drivers\USB\HighLevel\USBInterrupt.h"></File><File path="LUFA\Drivers\USB\HighLevel\USBTask.c"></File><File path="LUFA\Drivers\USB\HighLevel\StdDescriptors.c"></File><File path="LUFA\Drivers\USB\HighLevel\StdDescriptors.h"></File></Folder><Folder name="Class"><File path="LUFA\Drivers\USB\Class\HIDParser.c"></File><File path="LUFA\Drivers\USB\Class\HIDParser.h"></File><File path="LUFA\Drivers\USB\Class\HIDReportData.h"></File><File path="LUFA\Drivers\USB\Class\ConfigDescriptor.c"></File><File path="LUFA\Drivers\USB\Class\ConfigDescriptor.h"></File></Folder><File path="LUFA\Drivers\USB\USB.h"></File></Folder><Folder name="Misc"><File path="LUFA\Drivers\Misc\TerminalCodes.h"></File></Folder><Folder name="AT90USBXXX"><Folder name="AT90USBXXX67"><File path="LUFA\Drivers\AT90USBXXX\AT90USBXXX67\ADC.h"></File></Folder><File path="LUFA\Drivers\AT90USBXXX\Serial_Stream.h"></File><File path="LUFA\Drivers\AT90USBXXX\ADC.h"></File><File path="LUFA\Drivers\AT90USBXXX\Serial.c"></File><File path="LUFA\Drivers\AT90USBXXX\Serial.h"></File><File path="LUFA\Drivers\AT90USBXXX\Serial_Stream.c"></File><File path="LUFA\Drivers\AT90USBXXX\SPI.h"></File></Folder><Folder name="Board"><Folder name="USBKEY"><File path="LUFA\Drivers\Board\USBKEY\Dataflash.h"></File><File path="LUFA\Drivers\Board\USBKEY\Joystick.h"></File><File path="LUFA\Drivers\Board\USBKEY\HWB.h"></File><File path="LUFA\Drivers\Board\USBKEY\AT45DB642D.h"></File><File path="LUFA\Drivers\Board\USBKEY\LEDs.h"></File></Folder><Folder name="STK526"><File path="LUFA\Drivers\Board\STK526\Dataflash.h"></File><File path="LUFA\Drivers\Board\STK526\Joystick.h"></File><File path="LUFA\Drivers\Board\STK526\HWB.h"></File><File path="LUFA\Drivers\Board\STK526\AT45DB642D.h"></File><File path="LUFA\Drivers\Board\STK526\LEDs.h"></File></Folder><Folder name="STK525"><File path="LUFA\Drivers\Board\STK525\Dataflash.h"></File><File path="LUFA\Drivers\Board\STK525\Joystick.h"></File><File path="LUFA\Drivers\Board\STK525\HWB.h"></File><File path="LUFA\Drivers\Board\STK525\AT45DB321C.h"></File><File path="LUFA\Drivers\Board\STK525\LEDs.h"></File></Folder><Folder name="RZUSBSTICK"><File path="LUFA\Drivers\Board\RZUSBSTICK\LEDs.h"></File></Folder><Folder name="ATAVRUSBRF01"><File path="LUFA\Drivers\Board\ATAVRUSBRF01\LEDs.h"></File><File path="LUFA\Drivers\Board\ATAVRUSBRF01\HWB.h"></File></Folder><File path="LUFA\Drivers\Board\Temperature.h"></File><File path="LUFA\Drivers\Board\Dataflash.h"></File><File path="LUFA\Drivers\Board\HWB.h"></File><File path="LUFA\Drivers\Board\Joystick.h"></File><File path="LUFA\Drivers\Board\Temperature.c"></File><File path="LUFA\Drivers\Board\LEDs.h"></File></Folder></Folder><Folder name="Scheduler"><File path="LUFA\Scheduler\Scheduler.h"></File><File path="LUFA\Scheduler\Scheduler.c"></File></Folder><Folder name="MemoryAllocator"><File path="LUFA\MemoryAllocator\DynAlloc.h"></File><File path="LUFA\MemoryAllocator\DynAlloc.c"></File></Folder><Folder name="DriverStubs"><File path="LUFA\DriverStubs\Dataflash.h"></File><File path="LUFA\DriverStubs\HWB.h"></File><File path="LUFA\DriverStubs\Joystick.h"></File><File path="LUFA\DriverStubs\LEDs.h"></File></Folder><File path="LUFA\makefile"></File><File path="LUFA\Version.h"></File><File path="LUFA\BuildingLinkableLibraries.txt"></File><File path="LUFA\GettingStarted.txt"></File><File path="LUFA\MainPage.txt"></File><File path="LUFA\SchedulerOverview.txt"></File><File path="LUFA\VIDAndPIDValues.txt"></File><File path="LUFA\ChangeLog.txt"></File><File path="LUFA\CompileTimeTokens.txt"></File><File path="LUFA\MigrationInformation.txt"></File><File path="LUFA\DirectorySummaries.txt"></File><File path="LUFA\Doxygen.conf"></File><File path="LUFA\WritingBoardDrivers.txt"></File></Folder><Folder name="Projects"><Folder name="MagStripe"><File path="Projects\Magstripe\Descriptors.c"></File><File path="Projects\Magstripe\Descriptors.h"></File><File path="Projects\Magstripe\Magstripe.c"></File><File path="Projects\Magstripe\Magstripe.h"></File><File path="Projects\Magstripe\MagstripeHW.h"></File><File path="Projects\Magstripe\makefile"></File><File path="Projects\Magstripe\Magstripe.txt"></File><File path="Projects\Magstripe\Doxygen.conf"></File><File path="Projects\Magstripe\CircularBitBuffer.c"></File><File path="Projects\Magstripe\CircularBitBuffer.h"></File></Folder><File path="Projects\makefile"></File></Folder><Folder name="Bootloaders"><Folder name="DFU"><File path="Bootloaders\DFU\BootloaderDFU.c"></File><File path="Bootloaders\DFU\BootloaderDFU.h"></File><File path="Bootloaders\DFU\Descriptors.c"></File><File path="Bootloaders\DFU\Descriptors.h"></File><File path="Bootloaders\DFU\makefile"></File><File path="Bootloaders\DFU\BootloaderDFU.txt"></File><File path="Bootloaders\DFU\Doxygen.conf"></File></Folder><Folder name="CDC"><File path="Bootloaders\CDC\BootloaderCDC.c"></File><File path="Bootloaders\CDC\BootloaderCDC.h"></File><File path="Bootloaders\CDC\Descriptors.c"></File><File path="Bootloaders\CDC\Descriptors.h"></File><File path="Bootloaders\CDC\makefile"></File><File path="Bootloaders\CDC\LUFA CDC Bootloader.inf"></File><File path="Bootloaders\CDC\Doxygen.conf"></File><File path="Bootloaders\CDC\BootloaderCDC.txt"></File></Folder><Folder name="TeensyHID"><File path="Bootloaders\TeensyHID\Descriptors.c"></File><File path="Bootloaders\TeensyHID\Descriptors.h"></File><File path="Bootloaders\TeensyHID\makefile"></File><File path="Bootloaders\TeensyHID\TeensyHID.c"></File><File path="Bootloaders\TeensyHID\TeensyHID.h"></File><File path="Bootloaders\TeensyHID\TeensyHID.txt"></File></Folder><File path="Bootloaders\makefile"></File></Folder><File path="makefile"></File></Project>
\ No newline at end of file
index c1de86f..ad7f7bb 100644 (file)
@@ -8,7 +8,6 @@
   *\r
   *  \section Sec_ChangeLogXXXXXX Version XXXXXX\r
   *\r
-  *  - Added new incomplete BluetoothHost demo\r
   *  - Changed AVRISP Programmer descriptors to use a newly allocated 0x204F PID value\r
   *  - Fixed MagStripe project configuration descriptor containing an unused (blank) endpoint descriptor\r
   *  - Incorporated makefile changes by Denver Gingerich to retain compatibility with stock (non-WinAVR) AVR-GCC installations\r
   *    to Kenneth Clubb)\r
   *  - Added DataflashManager_WriteBlocks_RAM() and DataflashManager_ReadBlocks_RAM() functions to the MassStorage demo, to allow for easy\r
   *    interfacing with a FAT library for dataflash file level access\r
-  *  - Incomplete non-functional BluetoothHost demo removed until it has reached a stable state to prevent confusion\r
   *  - Corrected CDC class bootloader to fix a few bugs, changed address counter to store x2 addresses for convenience\r
   *  - Fixed typos in the SPI driver SPI_SPEED_FCPU_DIV_64 and SPI_SPEED_FCPU_DIV_128 masks (thanks to Markus Zocholl)\r
+  *  - Keyboard and Mouse demos (normal, data interrupt and fully interrupt driven) combined into unified keyboard and mouse demos\r
+  *  - Removed AVRISP_Programmer project due to code quality concerns\r
   *\r
   *  \section Sec_ChangeLog090209 Version 090209\r
   *\r
diff --git a/Projects/AVRISP_Programmer/AVRISP_Firmware_Design.txt b/Projects/AVRISP_Programmer/AVRISP_Firmware_Design.txt
deleted file mode 100644 (file)
index 643454d..0000000
+++ /dev/null
@@ -1,176 +0,0 @@
-Instructions for converting the LUFA USBtoSerial Demo to an AVR ISP Programmer.\r
-By Opendous Inc., Copyright under the Creative Commons Attribution License:\r
-http://creativecommons.org/licenses/by/3.0/\r
-\r
-1) Start with the LUFA/Demos/USBtoSerial firmware.\r
-    - rename USBtoSerial.c, USBtoSerial.h, and USBtoSerial.aps to\r
-      AVRISP_Programmer.*\r
-    - edit AVRISP_Programmer.aps and rename all instances of "USBtoSerial" to\r
-      "AVRISP_Programmer"\r
-    - copy AVRISP_Programmer.txt from an older version of AVRISP_Programmer\r
-\r
-2) Edit makefile by changing TARGET from "USBtoSerial" to "AVRISP_Programmer"\r
-\r
-3) Edit AVRISP_Programmer.h:\r
-    - change ifdef _USB_TO_SERIAL_H to _AVRISP_PROGRAMMER_H_\r
-    - rename ReconfigureUSART(void) to ReconfigureSPI(void)\r
-    - add  void processHostSPIRequest(void);  &  void delay_ms(uint8_t dly);\r
-    - replace the define for Serial.h with one for SPI.h:\r
-      #include <libs/LUFA/Drivers/AT90USBXXX/SPI.h>\r
-\r
-4) Make alterations to Descriptors.c\r
-    - change manufacturer string to "www.AVRopendous.org", length=19\r
-    - change product string to "LUFA-Based AVR ISP Programmer", length=29\r
-\r
-5) Edit Ringbuff.h to enable the Peek Command:  #define BUFF_USEPEEK\r
-\r
-6) Edit AVRISP_Programmer.c:\r
-    - change #include "USBtoSerial.h"  to  #include "AVRISP_Programmer.h"\r
-    - change BUTTLOADTAG(ProjName to "LUFA AVR910 ISP Programmer"\r
-    - in main(), rename ReconfigureUSART() to Reconfigure();\r
-    - in EVENT_HANDLER(USB_UnhandledControlPacket), rename ReconfigureUSART\r
-    - delete the ISRs: ISR(USART1_RX_vect)  &  ISR(USART1_TX_vect)\r
-    - delete ReconfigureUSART(void)\r
-    - add  void ReconfigureSPI(void),  void processHostSPIRequest(void),\r
-      and  void delay_ms(uint8_t dly)  from a previous version\r
-    - add Timer1 and SPI initialization code to main():\r
-           /* Hardware Initialization */\r
-           //LEDs_Init();\r
-           DDRB = 0;\r
-           PORTB = 0;\r
-           DDRC |= ((1 << PC2) | (1 << PC4) | (1 << PC5) | (1 << PC6) | (1 << PC7)); //AT90USBxx2\r
-           // PC2 is also used for RESET, so set it HIGH initially - note 'P' command sets it to LOW (Active)\r
-           PORTC |= ((1 << PC2) | (1 << PC4) | (1 << PC5) | (1 << PC6) | (1 << PC7)); //AT90USBxx2\r
-           DDRD = 0;\r
-           PORTD = (1 << PB7); // only PB7(HWB) should be High as this is the bootloader pin\r
-           // Prepare PortB for SPI - set PB0(^SS), PB1(SCK), PB2(MOSI) as output as well as all other pins except PB3(MISO)\r
-           DDRB = (1 << PB0) | (1 << PB1) | (1 << PB2) | (0 << PB3) | (1 << PB4) | (1 << PB5) | (1 << PB6) | (1 << PB7);\r
-           PORTB |= (1 << PB0);\r
-\r
-           // initialize Timer1 for use in delay function\r
-           TCCR1A = 0;\r
-           //TCCR1B = (1 << CS10); // no prescaling, use CLK\r
-           TCCR1B = ((1 << CS12) | (1 << CS10)); // prescale by CLK/1024\r
-           // 8MHz/1024 = 7813 ticks per second --> ~8 ticks per millisecond (ms)\r
-           timerval = TCNT1; // start timer1\r
-\r
-    - In TASK(CDC_Task) in the\r
-        if (USB_IsConnected) {\r
-            if (Endpoint_ReadWriteAllowed()) {\r
-                while (Endpoint_BytesInEndpoint()) {\r
-                    ...\r
-      structure, after  Buffer_StoreElement(&Rx_Buffer, Endpoint_Read_Byte()):\r
-\r
-        /* Each time there is an element, check which comand should be\r
-               run and if enough data is available to run that command.\r
-               There are 1-byte, 2-byte, 3-byte, 4-byte commands, and 5-byte commands\r
-               Remember that the "which command" byte counts as 1 */\r
-        if (Rx_Buffer.Elements == 0) {\r
-               // do nothing, wait for data\r
-        } else {\r
-               tempByte = Buffer_PeekElement(&Rx_Buffer); // peek at first element\r
-\r
-                       /* make sure the issued command and associated data are all ready */\r
-               if (Rx_Buffer.Elements == 1) { // zero data byte command\r
-                       if ((tempByte == 'P') | (tempByte == 'a') | (tempByte == 'm') |\r
-                       (tempByte == 'R') | (tempByte == 'd') | (tempByte == 'e') |\r
-                       (tempByte == 'L') | (tempByte == 's') | (tempByte == 't') | \r
-                       (tempByte == 'S') | (tempByte == 'V') | (tempByte == 'v') |\r
-                       (tempByte == 'p') | (tempByte == 'F')) {\r
-               processHostSPIRequest(); // command has enough data, process it\r
-                       }\r
-               } else if (Rx_Buffer.Elements == 2) { // one data byte command\r
-                       if ((tempByte == 'T') | (tempByte == 'c') | (tempByte == 'C') |\r
-                               (tempByte == 'D') | (tempByte == 'l') | (tempByte == 'f') |\r
-                               (tempByte == 'x') | (tempByte == 'y')) {\r
-                               processHostSPIRequest(); // command has enough data, process it\r
-                       }\r
-               } else if (Rx_Buffer.Elements == 3) { // two data byte command\r
-                       if ((tempByte == 'A') | (tempByte == 'Z')) {\r
-                               processHostSPIRequest(); // command has enough data, process it\r
-                       }\r
-               } else if (Rx_Buffer.Elements == 4) { // three data byte command\r
-                       if ((tempByte == ':')) {\r
-               processHostSPIRequest(); // command has enough data, process it\r
-                       }\r
-               } else if (Rx_Buffer.Elements == 5) { // four data byte command\r
-                       if ((tempByte == '.')) {\r
-                               processHostSPIRequest(); // command has enough data, process it\r
-                       }\r
-               } else {\r
-                       // do nothing\r
-               }\r
-        }\r
-\r
-    - need to add code to flush the buffer.  Change:\r
-        /* Check if Rx buffer contains data */\r
-               if (Rx_Buffer.Elements)\r
-               {\r
-                       /* Initiate the transmission of the buffer contents if USART idle*/\r
-                       if (!(Transmitting))\r
-                       {\r
-                               Transmitting = true;\r
-                               Serial_TxByte(Buffer_GetElement(&Rx_Buffer));\r
-                       }\r
-               }\r
-      To:\r
-        /* Check if Rx buffer contains data */\r
-               if (Rx_Buffer.Elements)\r
-               {\r
-                       /* Initiate the transmission of the buffer contents if USART idle*/\r
-                       if (!(Transmitting))\r
-                       {\r
-                               Transmitting = true;\r
-                               /* The following flushes the receive buffer to prepare for new\r
-                   data and commands. Need to flush the buffer as the command\r
-                   byte which is peeked above needs to be dealt with, otherwise\r
-                   the command bytes will overflow the buffer eventually */\r
-                               //Buffer_GetElement(&Rx_Buffer); // also works\r
-                               Buffer_Initialize(&Rx_Buffer);\r
-                       }\r
-               }\r
-\r
-    - need to add the following defines and globals:\r
-        #define RESETPORT       PORTB\r
-        #define RESETPIN        PB0\r
-        #define RESETPORT2      PORTC\r
-        #define RESETPIN2       PC2\r
-        #define CR_HEX          '\r'\r
-\r
-        #define DELAY_VERYSHORT    0x01\r
-        #define DELAY_SHORT        0x02\r
-        #define DELAY_MEDIUM       0x03\r
-        #define DELAY_LONG         0x05\r
-        #define DELAY_MULTIPLE     0x04\r
-\r
-        /*  AVR Device Codes - Can have a maximum of 14 but can be any you want.\r
-            Note that these are completely irrelevent.  If AVRdude supports a\r
-            device, then that device is programmable.  Use -F switch to ignore\r
-            device codes. */\r
-        #define AVRDEVCODE01   0x55 /* ATtiny12 */\r
-        #define AVRDEVCODE02   0x56 /* ATtiny15 */\r
-        #define AVRDEVCODE03   0x5E /* ATtiny261 */\r
-        #define AVRDEVCODE04   0x76 /* ATmega8 */\r
-        #define AVRDEVCODE05   0x74 /* ATmega16 */\r
-        #define AVRDEVCODE06   0x72 /* ATmega32 */\r
-        #define AVRDEVCODE07   0x45 /* ATmega64 */\r
-        #define AVRDEVCODE08   0x74 /* ATmega644 */\r
-        #define AVRDEVCODE09   0x43 /* ATmega128 */\r
-        #define AVRDEVCODE10   0x63 /* ATmega162 */\r
-        #define AVRDEVCODE11   0x78 /* ATmega169 */\r
-        #define AVRDEVCODE12   0x6C /* AT90S4434 */\r
-        #define AVRDEVCODE13   0x38 /* AT90S8515A */\r
-        #define AVRDEVCODE14   0x65 /* AT90S8555 */\r
-\r
-        /* some global variables used throughout */\r
-        uint8_t tempIOreg = 0;\r
-        uint8_t tempIOreg2 = 0;\r
-        uint8_t tempIOreg3 = 0;\r
-        uint8_t tempIOreg4 = 0;\r
-        uint8_t dataWidth = 0;\r
-        uint8_t firstRun = 1;\r
-        uint8_t deviceCode = 0;\r
-        uint8_t tempByte = 0;\r
-        uint16_t currAddress = 0;\r
-        uint16_t timerval = 0;\r
-\r
diff --git a/Projects/AVRISP_Programmer/AVRISP_Programmer.aps b/Projects/AVRISP_Programmer/AVRISP_Programmer.aps
deleted file mode 100644 (file)
index 7480023..0000000
+++ /dev/null
@@ -1 +0,0 @@
-<AVRStudio><MANAGEMENT><ProjectName>AVRISP_Programmer</ProjectName><Created>30-Sep-2008 14:18:39</Created><LastEdit>30-Sep-2008 14:18:52</LastEdit><ICON>241</ICON><ProjectType>0</ProjectType><Created>30-Sep-2008 14:18:39</Created><Version>4</Version><Build>4, 14, 0, 589</Build><ProjectTypeName>AVR GCC</ProjectTypeName></MANAGEMENT><CODE_CREATION><ObjectFile></ObjectFile><EntryFile></EntryFile><SaveFolder>C:\Users\Dean\Documents\Electronics\Projects\WORK\MyUSBWORK\Demos\AVRISP_Programmer\</SaveFolder></CODE_CREATION><DEBUG_TARGET><CURRENT_TARGET></CURRENT_TARGET><CURRENT_PART></CURRENT_PART><BREAKPOINTS></BREAKPOINTS><IO_EXPAND><HIDE>false</HIDE></IO_EXPAND><REGISTERNAMES><Register>R00</Register><Register>R01</Register><Register>R02</Register><Register>R03</Register><Register>R04</Register><Register>R05</Register><Register>R06</Register><Register>R07</Register><Register>R08</Register><Register>R09</Register><Register>R10</Register><Register>R11</Register><Register>R12</Register><Register>R13</Register><Register>R14</Register><Register>R15</Register><Register>R16</Register><Register>R17</Register><Register>R18</Register><Register>R19</Register><Register>R20</Register><Register>R21</Register><Register>R22</Register><Register>R23</Register><Register>R24</Register><Register>R25</Register><Register>R26</Register><Register>R27</Register><Register>R28</Register><Register>R29</Register><Register>R30</Register><Register>R31</Register></REGISTERNAMES><COM>Auto</COM><COMType>0</COMType><WATCHNUM>0</WATCHNUM><WATCHNAMES><Pane0></Pane0><Pane1></Pane1><Pane2></Pane2><Pane3></Pane3></WATCHNAMES><BreakOnTrcaeFull>0</BreakOnTrcaeFull></DEBUG_TARGET><Debugger><Triggers></Triggers></Debugger><AVRGCCPLUGIN><FILES><SOURCEFILE>Descriptors.c</SOURCEFILE><SOURCEFILE>RingBuff.c</SOURCEFILE><SOURCEFILE>AVRISP_Programmer.c</SOURCEFILE><HEADERFILE>Descriptors.h</HEADERFILE><HEADERFILE>RingBuff.h</HEADERFILE><HEADERFILE>AVRISP_Programmer.h</HEADERFILE><OTHERFILE>makefile</OTHERFILE></FILES><CONFIGS><CONFIG><NAME>default</NAME><USESEXTERNALMAKEFILE>YES</USESEXTERNALMAKEFILE><EXTERNALMAKEFILE>makefile</EXTERNALMAKEFILE><PART>atmega128</PART><HEX>1</HEX><LIST>1</LIST><MAP>1</MAP><OUTPUTFILENAME>AVRISP_Programmer.elf</OUTPUTFILENAME><OUTPUTDIR>default\</OUTPUTDIR><ISDIRTY>1</ISDIRTY><OPTIONS/><INCDIRS/><LIBDIRS/><LIBS/><LINKOBJECTS/><OPTIONSFORALL>-Wall -gdwarf-2 -std=gnu99 -Os -funsigned-char -funsigned-bitfields -fpack-struct -fshort-enums</OPTIONSFORALL><LINKEROPTIONS></LINKEROPTIONS><SEGMENTS/></CONFIG></CONFIGS><LASTCONFIG>default</LASTCONFIG><USES_WINAVR>1</USES_WINAVR><GCC_LOC>C:\WinAVR-20080512\bin\avr-gcc.exe</GCC_LOC><MAKE_LOC>C:\WinAVR-20080512\utils\bin\make.exe</MAKE_LOC></AVRGCCPLUGIN><IOView><usergroups/><sort sorted="0" column="0" ordername="0" orderaddress="0" ordergroup="0"/></IOView><Files></Files><Events><Bookmarks></Bookmarks></Events><Trace><Filters></Filters></Trace></AVRStudio>\r
diff --git a/Projects/AVRISP_Programmer/AVRISP_Programmer.c b/Projects/AVRISP_Programmer/AVRISP_Programmer.c
deleted file mode 100644 (file)
index 5859367..0000000
+++ /dev/null
@@ -1,763 +0,0 @@
-/*\r
-             LUFA Library\r
-     Copyright (C) Dean Camera, 2009.\r
-              \r
-  dean [at] fourwalledcubicle [dot] com\r
-      www.fourwalledcubicle.com\r
-*/\r
-\r
-/*\r
-  Copyright 2009  Dean Camera (dean [at] fourwalledcubicle [dot] com)\r
-  AVR ISP Programmer code Copyright 2009  Opendous Inc. (www.opendous.org)\r
-  For more info and usage instructions for this firmware, visit:\r
-  http://code.google.com/p/avropendous/wiki/AVR_ISP_Programmer\r
-\r
-  Note that this firmware is designed to work with AVRdude:\r
-  http://savannah.nongnu.org/projects/avrdude\r
-  But should work with other software that supports the AVR910 ISP\r
-  programmer or STK200 hardware.\r
-\r
-  Permission to use, copy, modify, and distribute this software\r
-  and its documentation for any purpose and without fee is hereby\r
-  granted, provided that the above copyright notice appear in all\r
-  copies and that both that the copyright notice and this\r
-  permission notice and warranty disclaimer appear in supporting\r
-  documentation, and that the name of the author not be used in\r
-  advertising or publicity pertaining to distribution of the\r
-  software without specific, written prior permission.\r
-\r
-  The author disclaim all warranties with regard to this\r
-  software, including all implied warranties of merchantability\r
-  and fitness.  In no event shall the author be liable for any\r
-  special, indirect or consequential damages or any damages\r
-  whatsoever resulting from loss of use, data or profits, whether\r
-  in an action of contract, negligence or other tortious action,\r
-  arising out of or in connection with the use or performance of\r
-  this software.\r
-*/\r
-\r
-/*\r
-    Usage:\r
-     avrdude -vv -F -P COM7 -c avr910 -p t261\r
-       Note -F flag which overrides signature check and enables programming\r
-       of any "In-System Programmable via SPI Port" AVR MCU.  Part number,\r
-       t261, should be set to your target device.\r
-     avrdude -vv -F -P COM7 -c avr910 -p t261 -U flash:w:PROG.hex\r
-       PROG.hex is the hex file to program your t261 AVR with\r
-     avrdude -vv -F -P COM7 -b 115200 -c avr910 -p t261 -U flash:w:test.hex\r
-       The -b 115200 sets the SPI clock to 62.5kHz from the default 125kHz and may\r
-       work when the default programming speed fails.\r
-     AVROSP.exe -dATtiny261 -cCOM7 -rf\r
-       AVRosp is the Open Source AVR ISP Programming Software available from Atmel.com\r
-\r
-    Note: on Linux systems, COM7 should be replaced with someting like /dev/ttyACM0\r
-          You can determine this value by running dmesg after plugging in the device\r
-    Note: you must RESET the programmer after each use (AVRdude session).\r
-\r
-    Note: If you experience errors with older devices, try changing the DELAY defines\r
-\r
-    MISO, MOSI, and SCK are connected directly from the AVRopendous board\r
-    to the pin of the same functionality on the target.  RESET pin on the target\r
-    can be connected either to SS (PB0), or PC2.  Do not have any other pins\r
-    connected - especially HWB pin, to avoid unintentional behaviour.\r
-\r
-    AVR910 functionality was overlayed on USBtoSerial  functionality.\r
-    Keep this in mind when looking over the code.\r
-    Default target speed is 125kHz and corresponds to 19200 baud, which\r
-    is the default setting for AVRdude.\r
-\r
-    Changing "Baud-Rate" will change the SPI speed.  Defualt SPI clock speed\r
-    is 8Mhz / 4 = 2MHz.  8Mhz is the device clock speed.  This is the setting at\r
-    9600 baud.  The following is a table of baud-rate vs. SPI Speed that will result\r
-         9600 = 2Mhz\r
-         14400 = 1MHz\r
-         19200 = 125kHz (AVRdude Default)\r
-         38400 = 250kHz\r
-         57600 = 500kHz\r
-         115200 = 62.5kHz\r
-\r
-       Before running, you will need to install the INF file that\r
-       is located in the project directory. This will enable\r
-       Windows to use its inbuilt CDC drivers, negating the need\r
-       for special Windows drivers for the device. To install,\r
-       right-click the .INF file and choose the Install option.\r
-*/\r
-\r
-/*     TODO: - fix the requirement that a RESET must be performed after each session, which\r
-            is only an issue under Windows.  Everything works fine under Linux\r
-*/\r
-\r
-#include "AVRISP_Programmer.h"\r
-\r
-/* Project Tags, for reading out using the ButtLoad project */\r
-BUTTLOADTAG(ProjName,    "LUFA AVR910 ISP Programmer");\r
-BUTTLOADTAG(BuildTime,   __TIME__);\r
-BUTTLOADTAG(BuildDate,   __DATE__);\r
-BUTTLOADTAG(LUFAVersion, "LUFA V" LUFA_VERSION_STRING);\r
-\r
-\r
-#define RESETPORT       PORTB\r
-#define RESETPIN        PB0\r
-#define RESETPORT2      PORTC\r
-#define RESETPIN2       PC2\r
-#define CR_HEX          '\r'\r
-\r
-#define DELAY_VERYSHORT    0x01\r
-#define DELAY_SHORT        0x02\r
-#define DELAY_MEDIUM       0x03\r
-#define DELAY_LONG         0x05\r
-#define DELAY_MULTIPLE     0x02\r
-\r
-\r
-/*  AVR Device Codes - Can have a maximum of 14 but can be any you want.\r
-    Note that these are completely irrelevent.  If AVRdude supports a device,\r
-    then that device is programmable.  Use -F switch to ignore device codes. */\r
-#define AVRDEVCODE01   0x55 /* ATtiny12 */\r
-#define AVRDEVCODE02   0x56 /* ATtiny15 */\r
-#define AVRDEVCODE03   0x5E /* ATtiny261 */\r
-#define AVRDEVCODE04   0x76 /* ATmega8 */\r
-#define AVRDEVCODE05   0x74 /* ATmega16 */\r
-#define AVRDEVCODE06   0x72 /* ATmega32 */\r
-#define AVRDEVCODE07   0x45 /* ATmega64 */\r
-#define AVRDEVCODE08   0x74 /* ATmega644 */\r
-#define AVRDEVCODE09   0x43 /* ATmega128 */\r
-#define AVRDEVCODE10   0x63 /* ATmega162 */\r
-#define AVRDEVCODE11   0x78 /* ATmega169 */\r
-#define AVRDEVCODE12   0x6C /* AT90S4434 */\r
-#define AVRDEVCODE13   0x38 /* AT90S8515A */\r
-#define AVRDEVCODE14   0x65 /* AT90S8555 */\r
-\r
-\r
-/* Scheduler Task List */\r
-TASK_LIST\r
-{\r
-       { Task: USB_USBTask          , TaskStatus: TASK_STOP },\r
-       { Task: CDC_Task             , TaskStatus: TASK_STOP },\r
-};\r
-\r
-/* Globals: */\r
-/** Contains the current baud rate and other settings of the virtual serial port.\r
- *\r
-    These values are set by the host via a class-specific request, and the physical USART should be reconfigured to match the\r
-    new settings each time they are changed by the host.\r
- */\r
-CDC_Line_Coding_t LineCoding = { BaudRateBPS: 9600,\r
-                                 CharFormat:  OneStopBit,\r
-                                 ParityType:  Parity_None,\r
-                                 DataBits:    8            };\r
-\r
-/** Ring (circular) buffer to hold the RX data - data from the host to the attached device on the serial port. */\r
-RingBuff_t Rx_Buffer;\r
-\r
-/** Ring (circular) buffer to hold the TX data - data from the attached device on the serial port to the host. */\r
-RingBuff_t Tx_Buffer;\r
-\r
-/** Flag to indicate if the USART is currently transmitting data from the Rx_Buffer circular buffer. */\r
-volatile bool Transmitting = false;\r
-\r
-/* some global variables used throughout */\r
-uint16_t currAddress = 0;\r
-\r
-/** Main program entry point. This routine configures the hardware required by the application, then\r
-    starts the scheduler to run the application tasks.\r
- */\r
-int main(void)\r
-{\r
-       /* Disable watchdog if enabled by bootloader/fuses */\r
-       MCUSR &= ~(1 << WDRF);\r
-       wdt_disable();\r
-\r
-       /* Disable clock division */\r
-       clock_prescale_set(clock_div_1);\r
-\r
-       /* Hardware Initialization */\r
-       LEDs_Init();\r
-       ReconfigureSPI();\r
-\r
-       DDRC |= ((1 << PC2) | (1 << PC4) | (1 << PC5) | (1 << PC6) | (1 << PC7)); //AT90USBxx2\r
-       // PC2 is also used for RESET, so set it HIGH initially - note 'P' command sets it to LOW (Active)\r
-       PORTC |= ((1 << PC2) | (1 << PC4) | (1 << PC5) | (1 << PC6) | (1 << PC7)); //AT90USBxx2\r
-       DDRD = 0;\r
-       PORTD = (1 << PB7); // only PB7(HWB) should be High as this is the bootloader pin\r
-       // Prepare PortB for SPI - set PB0(^SS), PB1(SCK), PB2(MOSI) as output as well as all other pins except PB3(MISO)\r
-       DDRB = (1 << PB0) | (1 << PB1) | (1 << PB2) | (0 << PB3) | (1 << PB4) | (1 << PB5) | (1 << PB6) | (1 << PB7);\r
-       PORTB |= (1 << PB0);\r
-    // make sure DataFlash devices to not interfere - deselect them by setting PE0 and PE1 HIGH:\r
-    PORTE = 0xFF;\r
-    DDRE  = 0xFF;\r
-\r
-       /* Ringbuffer Initialization */\r
-       Buffer_Initialize(&Rx_Buffer);\r
-       Buffer_Initialize(&Tx_Buffer);\r
-       \r
-       /* Indicate USB not ready */\r
-       UpdateStatus(Status_USBNotReady);\r
-       \r
-       /* Initialize Scheduler so that it can be used */\r
-       Scheduler_Init();\r
-\r
-       /* Initialize USB Subsystem */\r
-       USB_Init();\r
-\r
-       /* Scheduling - routine never returns, so put this last in the main function */\r
-       Scheduler_Start();\r
-}\r
-\r
-/** Event handler for the USB_Connect event. This indicates that the device is enumerating via the status LEDs and\r
-    starts the library USB task to begin the enumeration and USB management process.\r
- */\r
-EVENT_HANDLER(USB_Connect)\r
-{\r
-       /* Start USB management task */\r
-       Scheduler_SetTaskMode(USB_USBTask, TASK_RUN);\r
-\r
-       /* Indicate USB enumerating */\r
-       UpdateStatus(Status_USBEnumerating);\r
-}\r
-\r
-/** Event handler for the USB_Disconnect event. This indicates that the device is no longer connected to a host via\r
-    the status LEDs and stops the USB management and CDC management tasks.\r
- */\r
-EVENT_HANDLER(USB_Disconnect)\r
-{\r
-       /* Stop running CDC and USB management tasks */\r
-       Scheduler_SetTaskMode(CDC_Task, TASK_STOP);\r
-       Scheduler_SetTaskMode(USB_USBTask, TASK_STOP);\r
-\r
-       /* Indicate USB not ready */\r
-       UpdateStatus(Status_USBNotReady);\r
-}\r
-\r
-/** Event handler for the USB_ConfigurationChanged event. This is fired when the host set the current configuration\r
-    of the USB device after enumeration - the device endpoints are configured and the CDC management task started.\r
- */\r
-EVENT_HANDLER(USB_ConfigurationChanged)\r
-{\r
-       /* Setup CDC Notification, Rx and Tx Endpoints */\r
-       Endpoint_ConfigureEndpoint(CDC_NOTIFICATION_EPNUM, EP_TYPE_INTERRUPT,\r
-                                      ENDPOINT_DIR_IN, CDC_NOTIFICATION_EPSIZE,\r
-                                  ENDPOINT_BANK_SINGLE);\r
-\r
-       Endpoint_ConfigureEndpoint(CDC_TX_EPNUM, EP_TYPE_BULK,\r
-                                      ENDPOINT_DIR_IN, CDC_TXRX_EPSIZE,\r
-                                  ENDPOINT_BANK_SINGLE);\r
-\r
-       Endpoint_ConfigureEndpoint(CDC_RX_EPNUM, EP_TYPE_BULK,\r
-                                      ENDPOINT_DIR_OUT, CDC_TXRX_EPSIZE,\r
-                                  ENDPOINT_BANK_SINGLE);\r
-\r
-       /* Indicate USB connected and ready */\r
-       UpdateStatus(Status_USBReady);\r
-\r
-       /* Start CDC task */\r
-       Scheduler_SetTaskMode(CDC_Task, TASK_RUN);\r
-}\r
-\r
-/** Event handler for the USB_UnhandledControlPacket event. This is used to catch standard and class specific\r
-    control requests that are not handled internally by the USB library (including the CDC control commands,\r
-    which are all issued via the control endpoint), so that they can be handled appropriately for the application.\r
- */\r
-EVENT_HANDLER(USB_UnhandledControlPacket)\r
-{\r
-       uint8_t* LineCodingData = (uint8_t*)&LineCoding;\r
-\r
-       /* Process CDC specific control requests */\r
-       switch (bRequest)\r
-       {\r
-               case REQ_GetLineEncoding:\r
-                       if (bmRequestType == (REQDIR_DEVICETOHOST | REQTYPE_CLASS | REQREC_INTERFACE))\r
-                       {       \r
-                               /* Acknowledge the SETUP packet, ready for data transfer */\r
-                               Endpoint_ClearSetupReceived();\r
-\r
-                               /* Write the line coding data to the control endpoint */\r
-                               Endpoint_Write_Control_Stream_LE(LineCodingData, sizeof(LineCoding));\r
-                               \r
-                               /* Finalize the stream transfer to send the last packet or clear the host abort */\r
-                               Endpoint_ClearSetupOUT();\r
-                       }\r
-                       \r
-                       break;\r
-               case REQ_SetLineEncoding:\r
-                       if (bmRequestType == (REQDIR_HOSTTODEVICE | REQTYPE_CLASS | REQREC_INTERFACE))\r
-                       {\r
-                               /* Acknowledge the SETUP packet, ready for data transfer */\r
-                               Endpoint_ClearSetupReceived();\r
-\r
-                               /* Read the line coding data in from the host into the global struct */\r
-                               Endpoint_Read_Control_Stream_LE(LineCodingData, sizeof(LineCoding));\r
-\r
-                               /* Finalize the stream transfer to clear the last packet from the host */\r
-                               Endpoint_ClearSetupIN();\r
-                               \r
-                               /* Reconfigure the USART with the new settings */\r
-                               ReconfigureSPI();\r
-                       }\r
-       \r
-                       break;\r
-               case REQ_SetControlLineState:\r
-                       if (bmRequestType == (REQDIR_HOSTTODEVICE | REQTYPE_CLASS | REQREC_INTERFACE))\r
-                       {\r
-                               /* Acknowledge the SETUP packet, ready for data transfer */\r
-                               Endpoint_ClearSetupReceived();\r
-                               \r
-                               /* Acknowledge status stage */\r
-                               while (!(Endpoint_IsSetupINReady()));\r
-                               Endpoint_ClearSetupIN();\r
-                       }\r
-       \r
-                       break;\r
-       }\r
-}\r
-\r
-/** Task to manage CDC data transmission and reception to and from the host, from and to the physical USART. */\r
-TASK(CDC_Task)\r
-{\r
-       if (USB_IsConnected)\r
-       {\r
-               /* Select the Serial Rx Endpoint */\r
-               Endpoint_SelectEndpoint(CDC_RX_EPNUM);\r
-               \r
-               if (Endpoint_ReadWriteAllowed())\r
-               {\r
-                       /* Read the received data endpoint into the transmission buffer */\r
-                       while (Endpoint_BytesInEndpoint())\r
-                       {\r
-                               /* Wait until the buffer has space for a new character */\r
-                               while (!((BUFF_STATICSIZE - Rx_Buffer.Elements)));\r
-                       \r
-                               /* Store each character from the endpoint */\r
-                               Buffer_StoreElement(&Rx_Buffer, Endpoint_Read_Byte());\r
-\r
-                /* Run the given command once enough data is available. */\r
-                if (Rx_Buffer.Elements)\r
-                               {\r
-                                       const uint8_t ZeroDataByteCommands[]  = {'P', 'a', 'm', 'R', 'd', 'e', 'L', 's', 't', 'S', 'V', 'v', 'p', 'F'};\r
-                                       const uint8_t OneDataByteCommands[]   = {'T', 'c', 'C', 'D', 'l', 'f', 'x', 'y'};\r
-                                       const uint8_t TwoDataByteCommands[]   = {'A', 'Z'};\r
-                                       const uint8_t ThreeDataByteCommands[] = {':'};\r
-                                       const uint8_t FourDataByteCommands[]  = {'.'};\r
-                                       \r
-                                       const struct\r
-                                       {\r
-                                               const uint8_t  TotalCommands;\r
-                                               const uint8_t* CommandBytes;\r
-                                       } AVR910Commands[] = {{sizeof(ZeroDataByteCommands),  ZeroDataByteCommands},\r
-                                                             {sizeof(OneDataByteCommands),   OneDataByteCommands},\r
-                                                             {sizeof(TwoDataByteCommands),   TwoDataByteCommands},\r
-                                                             {sizeof(ThreeDataByteCommands), ThreeDataByteCommands},\r
-                                                             {sizeof(FourDataByteCommands),  FourDataByteCommands}};\r
-                                       \r
-                                       /* Determine the data length of the issued command */\r
-                                       uint8_t CommandDataLength = (Rx_Buffer.Elements - 1);\r
-                                       \r
-                                       /* Loop through each of the possible command bytes allowable from the given command data length */\r
-                                       for (uint8_t CurrentCommand = 0; CurrentCommand < AVR910Commands[CommandDataLength].TotalCommands; CurrentCommand++)\r
-                                       {\r
-                                               /* If issues command matches an allowable command, process it */\r
-                                               if (Buffer_PeekElement(&Rx_Buffer) == AVR910Commands[CommandDataLength].CommandBytes[CurrentCommand])\r
-                                                 processHostSPIRequest();\r
-                                       }\r
-                }\r
-                       }\r
-                       \r
-                       /* Clear the endpoint buffer */\r
-                       Endpoint_ClearCurrentBank();\r
-               }\r
-\r
-               /* Select the Serial Tx Endpoint */\r
-               Endpoint_SelectEndpoint(CDC_TX_EPNUM);\r
-\r
-               /* Check if the Tx buffer contains anything to be sent to the host */\r
-               if (Tx_Buffer.Elements)\r
-               {\r
-                       /* Wait until Serial Tx Endpoint Ready for Read/Write */\r
-                       while (!(Endpoint_ReadWriteAllowed()));\r
-                       \r
-                       /* Check before sending the data if the endpoint is completely full */\r
-                       bool IsFull = (Endpoint_BytesInEndpoint() == CDC_TXRX_EPSIZE);\r
-                       \r
-                       /* Write the transmission buffer contents to the received data endpoint */\r
-                       while (Tx_Buffer.Elements && (Endpoint_BytesInEndpoint() < CDC_TXRX_EPSIZE))\r
-                         Endpoint_Write_Byte(Buffer_GetElement(&Tx_Buffer));\r
-                       \r
-                       /* Send the data */\r
-                       Endpoint_ClearCurrentBank();\r
-\r
-                       /* If a full endpoint was sent, we need to send an empty packet afterwards to terminate the transfer */\r
-                       if (IsFull)\r
-                       {\r
-                               /* Wait until Serial Tx Endpoint Ready for Read/Write */\r
-                               while (!(Endpoint_ReadWriteAllowed()));\r
-\r
-                               /* Send an empty packet to terminate the transfer */\r
-                               Endpoint_ClearCurrentBank();\r
-                       }\r
-               }\r
-       }\r
-}\r
-\r
-/** Function to manage status updates to the user. This is done via LEDs on the given board, if available, but may be changed to\r
- *  log to a serial port, or anything else that is suitable for status updates.\r
- *\r
- *  \param CurrentStatus  Current status of the system, from the USBtoSerial_StatusCodes_t enum\r
- */\r
-void UpdateStatus(uint8_t CurrentStatus)\r
-{\r
-       uint8_t LEDMask = LEDS_NO_LEDS;\r
-       \r
-       /* Set the LED mask to the appropriate LED mask based on the given status code */\r
-       switch (CurrentStatus)\r
-       {\r
-               case Status_USBNotReady:\r
-                       LEDMask = (LEDS_LED1);\r
-                       break;\r
-               case Status_USBEnumerating:\r
-                       LEDMask = (LEDS_LED1 | LEDS_LED2);\r
-                       break;\r
-               case Status_USBReady:\r
-                       LEDMask = (LEDS_LED2 | LEDS_LED4);\r
-                       break;\r
-       }\r
-       \r
-       /* Set the board LEDs to the new LED mask */\r
-       LEDs_SetAllLEDs(LEDMask);\r
-}\r
-\r
-/** Reconfigures SPI to match the current serial port settings issued by the host. */\r
-void ReconfigureSPI(void)\r
-{\r
-       uint8_t SPCRmask = (1 << SPE) | (1 << MSTR); // always enable SPI as Master\r
-       uint8_t SPSRmask = 0;\r
-\r
-       /* Determine stop bits - 1.5 stop bits is set as 1 stop bit due to hardware limitations */\r
-       /* For SPI, determine whether format is LSB or MSB */\r
-       if (LineCoding.CharFormat == TwoStopBits) {     \r
-               SPCRmask |= (1 << DORD);\r
-       } else if (LineCoding.CharFormat == OneStopBit) {\r
-               SPCRmask |= (0 << DORD);\r
-       }\r
-\r
-       /* Determine data size - 5, 6, 7, or 8 bits are supported */\r
-       /* Changing line coding changes SPI Mode\r
-               CPOL=0, CPHA=0 Sample (Rising) Setup (Falling) SPI-Mode0 == 8 bits line coding\r
-               CPOL=0, CPHA=1 Setup (Rising) Sample (Falling) SPI-Mode1 == 7 bits line coding\r
-               CPOL=1, CPHA=0 Sample (Falling) Setup (Rising) SPI-Mode2 == 6 bits line coding\r
-               CPOL=1, CPHA=1 Setup (Falling) Sample (Rising) SPI-Mode3 == 5 bits line coding\r
-       */\r
-       if (LineCoding.DataBits == 5) {\r
-               SPCRmask |= ((1 << CPOL) | (1 << CPHA));\r
-       } else if (LineCoding.DataBits == 6) {\r
-               SPCRmask |= ((1 << CPOL) | (0 << CPHA));\r
-       } else if (LineCoding.DataBits == 7) {\r
-               SPCRmask |= ((0 << CPOL) | (1 << CPHA));\r
-       } else if (LineCoding.DataBits == 8) {\r
-               SPCRmask |= ((0 << CPOL) | (0 << CPHA));\r
-       }\r
-\r
-\r
-       /* Set the USART baud rate register to the desired baud rate value */\r
-       /* also alter the SPI speed via value of baud rate */\r
-       if        (LineCoding.BaudRateBPS == 9600) {    // 2Mhz SPI (Fosc / 4)\r
-               SPCRmask |= ((0 << SPR1) | (0 << SPR0));\r
-               SPSRmask |= (0 << SPI2X);\r
-       } else if (LineCoding.BaudRateBPS == 14400) {   // 1Mhz SPI (Fosc / 8)\r
-               SPCRmask |= ((0 << SPR1) | (1 << SPR0));\r
-               SPSRmask |= (1 << SPI2X);\r
-       } else if (LineCoding.BaudRateBPS == 57600) {   // 500kHz SPI (Fosc / 16)\r
-               SPCRmask |= ((0 << SPR1) | (1 << SPR0));\r
-               SPSRmask |= (0 << SPI2X);\r
-       } else if (LineCoding.BaudRateBPS == 38400) {   // 250kHz SPI (Fosc / 32)\r
-               SPCRmask |= ((1 << SPR1) | (0 << SPR0));\r
-               SPSRmask |= (1 << SPI2X);\r
-       } else if (LineCoding.BaudRateBPS == 19200) {   // 125kHz SPI (Fosc / 64)\r
-               SPCRmask |= ((1 << SPR1) | (0 << SPR0));\r
-               SPSRmask |= (0 << SPI2X);\r
-       } else if (LineCoding.BaudRateBPS == 115200) {  // 62.5kHz SPI (Fosc / 128)\r
-               SPCRmask |= ((1 << SPR1) | (1 << SPR0));\r
-               SPSRmask |= (0 << SPI2X);\r
-       }\r
-\r
-       SPCR = SPCRmask;\r
-       SPSR = SPSRmask;\r
-}\r
-\r
-\r
-/* process data according to AVR910 protocol */\r
-void processHostSPIRequest(void) {\r
-\r
-       uint8_t readByte1 = 0;\r
-       uint8_t readByte2 = 0;\r
-       uint8_t readByte3 = 0;\r
-       uint8_t readByte4 = 0;\r
-       uint8_t firstByte = 0;\r
-\r
-       /*      Taken from a90isp_ver23.asm:\r
-               +-------------+------------+------+\r
-               ;*  Commands                           | Host writes | Host reads |      |\r
-               ;*  --------                           +-----+-------+------+-----+      |\r
-               ;*                                     | ID  | data  | data |     | Note |\r
-               ;* +-----------------------------------+-----+-------+------+-----+------+\r
-               ;* | Enter programming mode            | 'P' |       |      | 13d |   1  |\r
-               ;* | Report autoincrement address      | 'a' |       |      | 'Y' |      |\r
-               ;* | Set address                       | 'A' | ah al |      | 13d |   2  |\r
-               ;* | Write program memory, low byte    | 'c' |    dd |      | 13d |   3  |\r
-               ;* | Write program memory, high byte   | 'C' |    dd |      | 13d |   3  |\r
-               ;* | Issue Page Write                  | 'm' |       |      | 13d |      |\r
-               ;* | Read program memory               | 'R' |       |dd(dd)|     |   4  |\r
-               ;* | Write data memory                 | 'D' |    dd |      | 13d |      |\r
-               ;* | Read data memory                  | 'd' |       |   dd |     |      |\r
-               ;* | Chip erase                        | 'e' |       |      | 13d |      |\r
-               ;* | Write lock bits                   | 'l' |    dd |      | 13d |      |\r
-               ;* | Write fuse bits                   | 'f' |    dd |      | 13d |  11  |\r
-               ;* | Read fuse and lock bits           | 'F' |       |   dd |     |  11  |\r
-               ;* | Leave programming mode            | 'L' |       |      | 13d |   5  |\r
-               ;* | Select device type                | 'T' |    dd |      | 13d |   6  |\r
-               ;* | Read signature bytes              | 's' |       | 3*dd |     |      |\r
-               ;* | Return supported device codes     | 't' |       | n*dd | 00d |   7  |\r
-               ;* | Return software identifier        | 'S' |       | s[7] |     |   8  |\r
-               ;* | Return sofware version            | 'V' |       |dd dd |     |   9  |\r
-               ;* | Return hardware version           | 'v' |       |dd dd |     |   9  |\r
-               ;* | Return programmer type            | 'p' |       |   dd |     |  10  |\r
-               ;* | Set LED                           | 'x' |    dd |      | 13d |  12  |\r
-               ;* | Clear LED                         | 'y' |    dd |      | 13d |  12  |\r
-               ;* | Universial command                | ':' |  3*dd |   dd | 13d |      |\r
-               ;* | New universal command                 | '.' |  4*dd |   dd | 13d |      |\r
-               ;* | Special test command                  | 'Z' |  2*dd |   dd |     |      |\r
-       */\r
-\r
-       firstByte = Buffer_GetElement(&Rx_Buffer);\r
-       Buffer_Initialize(&Tx_Buffer); // make sure the buffer is clear before proceeding\r
-\r
-       if        (firstByte == 'P') { // enter Programming mode\r
-               // enable SPI -- already done\r
-               // enter programming mode on target:\r
-               //PORTB = 0; // set clock to zero\r
-               RESETPORT = (1 << RESETPIN); // set RESET pin on target to 1\r
-               RESETPORT2 = (1 << RESETPIN2);\r
-               _delay_ms(DELAY_SHORT);\r
-               //RESETPORT = (RESETPORT & ~(1 << RESETPIN)); // set RESET pin on target to 0 - Active\r
-               RESETPORT = 0x00;\r
-               RESETPORT2 = 0;\r
-               _delay_ms(DELAY_SHORT);\r
-               SPI_SendByte(0xAC);\r
-               SPI_SendByte(0x53);\r
-               SPI_SendByte(0x00);\r
-               SPI_SendByte(0x00);\r
-               _delay_ms(DELAY_VERYSHORT);\r
-               Buffer_StoreElement(&Tx_Buffer, CR_HEX); // return carriage return (CR_HEX) if successful\r
-\r
-       } else if (firstByte == 'T') { // Select device type\r
-               Buffer_GetElement(&Rx_Buffer); // set device type\r
-               Buffer_StoreElement(&Tx_Buffer, CR_HEX); // return carriage return (CR_HEX) if successful\r
-\r
-       } else if (firstByte == 'a') { // Report autoincrement address\r
-               Buffer_StoreElement(&Tx_Buffer, 'Y'); // return 'Y' - Auto-increment enabled\r
-\r
-       } else if (firstByte == 'A') { //Load Address\r
-               // get two bytes over serial and set currAddress to them\r
-               readByte1 = Buffer_GetElement(&Rx_Buffer); // high byte\r
-               readByte2 = Buffer_GetElement(&Rx_Buffer); // low byte\r
-               currAddress = (readByte1 << 8) | (readByte2);\r
-               Buffer_StoreElement(&Tx_Buffer, CR_HEX); // return carriage return (CR_HEX) if successful\r
-\r
-       } else if (firstByte == 'c') { // Write program memory, low byte\r
-               // send 4 bytes over SPI; 0x40, then Address High Byte, then Low, then data\r
-               readByte1 = Buffer_GetElement(&Rx_Buffer);\r
-               SPI_SendByte(0x40);\r
-               SPI_SendByte((currAddress >> 8)); // high byte\r
-               SPI_SendByte((currAddress)); // low byte\r
-               SPI_SendByte(readByte1); // data\r
-               _delay_ms(DELAY_MEDIUM); // certain MCUs require a delay of about 24585 cycles\r
-               Buffer_StoreElement(&Tx_Buffer, CR_HEX); // return carriage return (CR_HEX) if successful\r
-\r
-       } else if (firstByte == 'C') { // Write program memory, high byte\r
-               // send 4 bytes over SPI; 0x48, then Address High Byte, then Low, then data\r
-               readByte1 = Buffer_GetElement(&Rx_Buffer);\r
-               SPI_SendByte(0x48);\r
-               SPI_SendByte((currAddress >> 8)); // high byte\r
-               SPI_SendByte((currAddress)); // low byte\r
-               SPI_SendByte(readByte1); // data\r
-               currAddress++; // increment currAddress\r
-               Buffer_StoreElement(&Tx_Buffer, CR_HEX); // return carriage return (CR_HEX) if successful\r
-\r
-       } else if (firstByte == 'm') { // Write Program Memory Page\r
-               // send 4 bytes over SPI; 0x4c, then Address High Byte, then Low, then 0x00\r
-               SPI_SendByte(0x4C);\r
-               SPI_SendByte((currAddress >> 8)); // high byte\r
-               SPI_SendByte((currAddress)); // low byte\r
-               SPI_SendByte(0x00);\r
-               _delay_ms(DELAY_LONG);\r
-               Buffer_StoreElement(&Tx_Buffer, CR_HEX); // return carriage return (CR_HEX) if successful\r
-\r
-       } else if (firstByte == 'R') { // Read Program Memory\r
-               // send 4 bytes over SPI; 0x28, then Address High Byte, then Low, then send back read data from 4th byte over serial\r
-               SPI_SendByte(0x28);\r
-               SPI_SendByte((currAddress >> 8)); // high byte\r
-               SPI_SendByte((currAddress)); // low byte\r
-               readByte1 = SPI_TransferByte(0x00); // read in data\r
-               Buffer_StoreElement(&Tx_Buffer, readByte1);\r
-               // send 4 bytes over SPI; 0x20, then Address High Byte, then Low, then send back read data from 4th byte over serial\r
-               SPI_SendByte(0x20);\r
-               SPI_SendByte((currAddress >> 8)); // high byte\r
-               SPI_SendByte((currAddress)); // low byte\r
-               readByte2 = SPI_TransferByte(0x00); // read in data\r
-               Buffer_StoreElement(&Tx_Buffer, readByte2);\r
-               currAddress++; // increment currAddress\r
-\r
-       } else if (firstByte == 'D') { // Write Data Memory\r
-               // send 4 bytes over SPI; 0xc0, then Address High Byte, then Low, then data\r
-               readByte1 = Buffer_GetElement(&Rx_Buffer);\r
-               SPI_SendByte(0xC0);\r
-               SPI_SendByte((currAddress >> 8)); // high byte\r
-               SPI_SendByte((currAddress)); // low byte\r
-               SPI_SendByte(readByte1); // data\r
-               _delay_ms(DELAY_MEDIUM);\r
-               currAddress++; // increment currAddress\r
-               Buffer_StoreElement(&Tx_Buffer, CR_HEX); // return carriage return (CR_HEX) if successful\r
-\r
-       } else if (firstByte == 'd') { // Read Data Memory\r
-               // send 4 bytes over SPI; 0xa0, then Address High Byte, then Low, then send back read data from 4th byte over serial\r
-               SPI_SendByte(0xA0);\r
-               SPI_SendByte((currAddress >> 8)); // high byte\r
-               SPI_SendByte((currAddress)); // low byte\r
-               readByte1 = SPI_TransferByte(0x00); // read in data\r
-               Buffer_StoreElement(&Tx_Buffer, readByte1);\r
-               currAddress++; // increment currAddress\r
-\r
-       } else if (firstByte == 'e') { // erase the target device\r
-               // send 4 bytes over SPI; 0xac, 0x80, 0x04, 0x00\r
-               SPI_SendByte(0xAC);\r
-               SPI_SendByte(0x80);\r
-               SPI_SendByte(0x04);\r
-               SPI_SendByte(0x00);\r
-               _delay_ms(DELAY_LONG);\r
-               Buffer_StoreElement(&Tx_Buffer, CR_HEX); // return carriage return (CR_HEX) if successful\r
-\r
-       } else if (firstByte == 'l') { // write lock bits\r
-               // send 4 bytes over SPI; 0xac, [andi s_data 0x06], 0xe0, 0x00\r
-               readByte1 = Buffer_GetElement(&Rx_Buffer); // read in lock bits data\r
-               SPI_SendByte(0xAC);\r
-               SPI_SendByte(((0x06 & readByte1) | 0xE0)); // TODO - is this correct???\r
-               SPI_SendByte(0x00);\r
-               SPI_SendByte(0x00);\r
-               _delay_ms(DELAY_MEDIUM);\r
-               Buffer_StoreElement(&Tx_Buffer, CR_HEX); // return carriage return (CR_HEX) if successful\r
-\r
-       } else if (firstByte == 'f') { // write fuse bits\r
-               // ignore this command, but need to remove data from the receive buffer\r
-               readByte1 = Buffer_GetElement(&Rx_Buffer);\r
-               Buffer_StoreElement(&Tx_Buffer, CR_HEX); // return carriage return (CR_HEX) if successful\r
-\r
-       } else if (firstByte == 'L') { // leave programming mode\r
-               RESETPORT |= (1 << RESETPIN); // set RESET pin on target to 1\r
-               RESETPORT2 |= (1 << RESETPIN2); // set RESET pin on target to 1\r
-               Buffer_StoreElement(&Tx_Buffer, CR_HEX); // return carriage return (CR_HEX) if successful\r
-\r
-       } else if (firstByte == 's') { // Read signature bytes\r
-               // send 4 bytes over SPI; 0x30, 0x00, 0x02, read and send last byte over serial\r
-               SPI_SendByte(0x30);\r
-               SPI_SendByte(0x00);\r
-               SPI_SendByte(0x02);\r
-               readByte1 = SPI_TransferByte(0x00); // read in data\r
-               Buffer_StoreElement(&Tx_Buffer, readByte1);\r
-               SPI_SendByte(0x30);\r
-               SPI_SendByte(0x00);\r
-               SPI_SendByte(0x01);\r
-               readByte1 = SPI_TransferByte(0x00); // read in data\r
-               Buffer_StoreElement(&Tx_Buffer, readByte1);\r
-               SPI_SendByte(0x30);\r
-               SPI_SendByte(0x00);\r
-               SPI_SendByte(0x00);\r
-               readByte1 = SPI_TransferByte(0x00); // read in data\r
-               Buffer_StoreElement(&Tx_Buffer, readByte1);\r
-\r
-       } else if (firstByte == 't') { // Return supported device codes\r
-               Buffer_StoreElement(&Tx_Buffer, AVRDEVCODE01);\r
-               Buffer_StoreElement(&Tx_Buffer, AVRDEVCODE02);\r
-               Buffer_StoreElement(&Tx_Buffer, AVRDEVCODE03);\r
-               Buffer_StoreElement(&Tx_Buffer, AVRDEVCODE04);\r
-               Buffer_StoreElement(&Tx_Buffer, AVRDEVCODE05);\r
-               Buffer_StoreElement(&Tx_Buffer, AVRDEVCODE06);\r
-               Buffer_StoreElement(&Tx_Buffer, AVRDEVCODE07);\r
-               Buffer_StoreElement(&Tx_Buffer, AVRDEVCODE08);\r
-               Buffer_StoreElement(&Tx_Buffer, AVRDEVCODE09);\r
-               Buffer_StoreElement(&Tx_Buffer, AVRDEVCODE10);\r
-               Buffer_StoreElement(&Tx_Buffer, AVRDEVCODE11);\r
-               Buffer_StoreElement(&Tx_Buffer, AVRDEVCODE12);\r
-               Buffer_StoreElement(&Tx_Buffer, AVRDEVCODE13);\r
-               Buffer_StoreElement(&Tx_Buffer, AVRDEVCODE14);\r
-               Buffer_StoreElement(&Tx_Buffer, 0x00);\r
-\r
-       } else if (firstByte == 'S') { // Return software identifier\r
-               // return string[7] with "AVR ISP"\r
-               Buffer_StoreElement(&Tx_Buffer, 'A');\r
-               Buffer_StoreElement(&Tx_Buffer, 'V');\r
-               Buffer_StoreElement(&Tx_Buffer, 'R');\r
-               Buffer_StoreElement(&Tx_Buffer, 0x20);\r
-               Buffer_StoreElement(&Tx_Buffer, 'I');\r
-               Buffer_StoreElement(&Tx_Buffer, 'S');\r
-               Buffer_StoreElement(&Tx_Buffer, 'P');\r
-\r
-       } else if (firstByte == 'V') { // Return sofware version\r
-               //return two bytes, software Major then Minor\r
-               Buffer_StoreElement(&Tx_Buffer, '2');\r
-               Buffer_StoreElement(&Tx_Buffer, '3');\r
-\r
-       } else if (firstByte == 'v') { // Return hardware version\r
-               //return two bytes, hardware Major then Minor   \r
-               Buffer_StoreElement(&Tx_Buffer, ('1'));\r
-               Buffer_StoreElement(&Tx_Buffer, ('0'));\r
-\r
-       } else if (firstByte == 'p') { // Return programmer type\r
-               // return 'S' for Serial Programmer\r
-               Buffer_StoreElement(&Tx_Buffer, 'S');\r
-\r
-       } else if (firstByte == 'x') { // set LED\r
-               // ignore this command, but need to remove data from the receive buffer\r
-               readByte1 = Buffer_GetElement(&Rx_Buffer);\r
-               Buffer_StoreElement(&Tx_Buffer, CR_HEX); // return carriage return (CR_HEX) if successful\r
-\r
-       } else if (firstByte == 'y') { // clear LED\r
-               // ignore this command, but need to remove data from the receive buffer\r
-               readByte1 = Buffer_GetElement(&Rx_Buffer);\r
-               Buffer_StoreElement(&Tx_Buffer, CR_HEX); // return carriage return (CR_HEX) if successful\r
-\r
-       } else if (firstByte == ':') { // Universal Command\r
-               // get 3 bytes over serial\r
-               readByte1 = Buffer_GetElement(&Rx_Buffer);\r
-               readByte2 = Buffer_GetElement(&Rx_Buffer);\r
-               readByte3 = Buffer_GetElement(&Rx_Buffer);\r
-               SPI_SendByte(readByte1);\r
-               SPI_SendByte(readByte2);\r
-               SPI_SendByte(readByte3);\r
-               readByte1 = SPI_TransferByte(0x00);\r
-               Buffer_StoreElement(&Tx_Buffer, readByte1);\r
-               _delay_ms(DELAY_MEDIUM);\r
-               Buffer_StoreElement(&Tx_Buffer, CR_HEX); // return carriage return (CR_HEX) if successful\r
-\r
-       } else if (firstByte == '.') { // New Universal Command\r
-               // get 4 bytes over serial\r
-               readByte1 = Buffer_GetElement(&Rx_Buffer);\r
-               readByte2 = Buffer_GetElement(&Rx_Buffer);\r
-               readByte3 = Buffer_GetElement(&Rx_Buffer);\r
-               readByte4 = Buffer_GetElement(&Rx_Buffer);\r
-               SPI_SendByte(readByte1);\r
-               SPI_SendByte(readByte2);\r
-               SPI_SendByte(readByte3);\r
-               readByte1 = SPI_TransferByte(readByte4);\r
-               Buffer_StoreElement(&Tx_Buffer, readByte1);\r
-               _delay_ms(DELAY_MEDIUM);\r
-               Buffer_StoreElement(&Tx_Buffer, CR_HEX); // return carriage return (CR_HEX) if successful\r
-\r
-       } else if (firstByte == 'Z') { // Special test command\r
-               // do nothing, but need to remove data from the receive buffer\r
-               readByte1 = Buffer_GetElement(&Rx_Buffer);\r
-               readByte2 = Buffer_GetElement(&Rx_Buffer);\r
-\r
-       } else {\r
-               // do nothing, but need to return with a carriage return\r
-               Buffer_StoreElement(&Tx_Buffer, CR_HEX); // return carriage return (CR_HEX) if successful\r
-       }\r
-}\r
-\r
diff --git a/Projects/AVRISP_Programmer/AVRISP_Programmer.h b/Projects/AVRISP_Programmer/AVRISP_Programmer.h
deleted file mode 100644 (file)
index c6ac13f..0000000
+++ /dev/null
@@ -1,195 +0,0 @@
-/*\r
-             LUFA Library\r
-     Copyright (C) Dean Camera, 2009.\r
-              \r
-  dean [at] fourwalledcubicle [dot] com\r
-      www.fourwalledcubicle.com\r
-*/\r
-\r
-/*\r
-  Copyright 2009  Dean Camera (dean [at] fourwalledcubicle [dot] com)\r
-\r
-  Permission to use, copy, modify, and distribute this software\r
-  and its documentation for any purpose and without fee is hereby\r
-  granted, provided that the above copyright notice appear in all\r
-  copies and that both that the copyright notice and this\r
-  permission notice and warranty disclaimer appear in supporting\r
-  documentation, and that the name of the author not be used in\r
-  advertising or publicity pertaining to distribution of the\r
-  software without specific, written prior permission.\r
-\r
-  The author disclaim all warranties with regard to this\r
-  software, including all implied warranties of merchantability\r
-  and fitness.  In no event shall the author be liable for any\r
-  special, indirect or consequential damages or any damages\r
-  whatsoever resulting from loss of use, data or profits, whether\r
-  in an action of contract, negligence or other tortious action,\r
-  arising out of or in connection with the use or performance of\r
-  this software.\r
-*/\r
-\r
-/** \file\r
- *\r
- *  Header file for USBtoSerial.c.\r
- */\r
-\r
-#ifndef _AVRISP_PROGRAMMER_H_\r
-#define _AVRISP_PROGRAMMER_H_\r
-\r
-       /* Includes: */\r
-               #include <avr/io.h>\r
-               #include <avr/wdt.h>\r
-               #include <avr/interrupt.h>\r
-               #include <avr/power.h>\r
-               #include <util/delay.h>\r
-\r
-               #include "Descriptors.h"\r
-               #include "RingBuff.h"\r
-\r
-               #include <LUFA/Version.h>                         // Library Version Information\r
-               #include <LUFA/Common/ButtLoadTag.h>              // PROGMEM tags readable by the ButtLoad project\r
-               #include <LUFA/Drivers/USB/USB.h>                 // USB Functionality\r
-               #include <LUFA/Drivers/AT90USBXXX/SPI.h>          // SPI driver\r
-               #include <LUFA/Drivers/Board/LEDs.h>              // LEDs driver\r
-               #include <LUFA/Scheduler/Scheduler.h>             // Simple scheduler for task management\r
-\r
-       /* Macros: */\r
-               /** CDC Class specific request to get the current virtual serial port configuration settings. */\r
-               #define REQ_GetLineEncoding          0x21\r
-\r
-               /** CDC Class specific request to set the current virtual serial port configuration settings. */\r
-               #define REQ_SetLineEncoding          0x20\r
-\r
-               /** CDC Class specific request to set the current virtual serial port handshake line states. */\r
-               #define REQ_SetControlLineState      0x22\r
-               \r
-               /** Notification type constant for a change in the virtual serial port handshake line states, for\r
-                *  use with a USB_Notification_Header_t notification structure when sent to the host via the CDC \r
-                *  notification endpoint.\r
-                */\r
-               #define NOTIF_SerialState            0x20\r
-\r
-               /** Mask for the DTR handshake line for use with the REQ_SetControlLineState class specific request\r
-                *  from the host, to indicate that the DTR line state should be high.\r
-                */\r
-               #define CONTROL_LINE_OUT_DTR         (1 << 0)\r
-\r
-               /** Mask for the RTS handshake line for use with the REQ_SetControlLineState class specific request\r
-                *  from the host, to indicate that theRTS line state should be high.\r
-                */\r
-               #define CONTROL_LINE_OUT_RTS         (1 << 1)\r
-               \r
-               /** Mask for the DCD handshake line for use with the a NOTIF_SerialState class specific notification\r
-                *  from the device to the host, to indicate that the DCD line state is currently high.\r
-                */\r
-               #define CONTROL_LINE_IN_DCD          (1 << 0)\r
-\r
-               /** Mask for the DSR handshake line for use with the a NOTIF_SerialState class specific notification\r
-                *  from the device to the host, to indicate that the DSR line state is currently high.\r
-                */\r
-               #define CONTROL_LINE_IN_DSR          (1 << 1)\r
-\r
-               /** Mask for the BREAK handshake line for use with the a NOTIF_SerialState class specific notification\r
-                *  from the device to the host, to indicate that the BREAK line state is currently high.\r
-                */\r
-               #define CONTROL_LINE_IN_BREAK        (1 << 2)\r
-\r
-               /** Mask for the RING handshake line for use with the a NOTIF_SerialState class specific notification\r
-                *  from the device to the host, to indicate that the RING line state is currently high.\r
-                */\r
-               #define CONTROL_LINE_IN_RING         (1 << 3)\r
-\r
-               /** Mask for use with the a NOTIF_SerialState class specific notification from the device to the host,\r
-                *  to indicate that a framing error has ocurred on the virtual serial port.\r
-                */\r
-               #define CONTROL_LINE_IN_FRAMEERROR   (1 << 4)\r
-\r
-               /** Mask for use with the a NOTIF_SerialState class specific notification from the device to the host,\r
-                *  to indicate that a parity error has ocurred on the virtual serial port.\r
-                */\r
-               #define CONTROL_LINE_IN_PARITYERROR  (1 << 5)\r
-\r
-               /** Mask for use with the a NOTIF_SerialState class specific notification from the device to the host,\r
-                *  to indicate that a data overrun error has ocurred on the virtual serial port.\r
-                */\r
-               #define CONTROL_LINE_IN_OVERRUNERROR (1 << 6)\r
-               \r
-       /* Event Handlers: */\r
-               /** Indicates that this module will catch the USB_Connect event when thrown by the library. */\r
-               HANDLES_EVENT(USB_Connect);\r
-\r
-               /** Indicates that this module will catch the USB_Disconnect event when thrown by the library. */\r
-               HANDLES_EVENT(USB_Disconnect);\r
-\r
-               /** Indicates that this module will catch the USB_ConfigurationChanged event when thrown by the library. */\r
-               HANDLES_EVENT(USB_ConfigurationChanged);\r
-\r
-               /** Indicates that this module will catch the USB_UnhandledControlPacket event when thrown by the library. */\r
-               HANDLES_EVENT(USB_UnhandledControlPacket);\r
-               \r
-       /* Type Defines: */\r
-               /** Type define for the virtual serial port line encoding settings, for storing the current USART configuration\r
-                *  as set by the host via a class specific request.\r
-                */\r
-               typedef struct\r
-               {\r
-                       uint32_t BaudRateBPS; /**< Baud rate of the virtual serial port, in bits per second */\r
-                       uint8_t  CharFormat; /**< Character format of the virtual serial port, a value from the\r
-                                             *   CDCDevice_CDC_LineCodingFormats_t enum\r
-                                             */\r
-                       uint8_t  ParityType; /**< Parity setting of the virtual serial port, a value from the\r
-                                             *   CDCDevice_LineCodingParity_t enum\r
-                                             */\r
-                       uint8_t  DataBits; /**< Bits of data per charater of the virtual serial port */\r
-               } CDC_Line_Coding_t;\r
-               \r
-               /** Type define for a CDC notification, sent to the host via the CDC notification endpoint to indicate a\r
-                *  change in the device state asynchronously.\r
-                */\r
-               typedef struct\r
-               {\r
-                       uint8_t  NotificationType; /**< Notification type, a mask of REQDIR_*, REQTYPE_* and REQREC_* constants\r
-                                                   *   from the library StdRequestType.h header\r
-                                                   */\r
-                       uint8_t  Notification; /**< Notification value, a NOTIF_* constant */\r
-                       uint16_t wValue; /**< Notification wValue, notification-specific */\r
-                       uint16_t wIndex; /**< Notification wIndex, notification-specific */\r
-                       uint16_t wLength; /**< Notification wLength, notification-specific */\r
-               } USB_Notification_Header_t;\r
-               \r
-       /* Enums: */\r
-               /** Enum for the possible line encoding formats of a virtual serial port. */\r
-               enum CDCDevice_CDC_LineCodingFormats_t\r
-               {\r
-                       OneStopBit          = 0, /**< Each frame contains one stop bit */\r
-                       OneAndAHalfStopBits = 1, /**< Each frame contains one and a half stop bits */\r
-                       TwoStopBits         = 2, /**< Each frame contains two stop bits */\r
-               };\r
-               \r
-               /** Enum for the possible line encoding parity settings of a virtual serial port. */\r
-               enum CDCDevice_LineCodingParity_t\r
-               {\r
-                       Parity_None         = 0, /**< No parity bit mode on each frame */\r
-                       Parity_Odd          = 1, /**< Odd parity bit mode on each frame */\r
-                       Parity_Even         = 2, /**< Even parity bit mode on each frame */\r
-                       Parity_Mark         = 3, /**< Mark parity bit mode on each frame */\r
-                       Parity_Space        = 4, /**< Space parity bit mode on each frame */\r
-               };\r
-\r
-               /** Enum for the possible status codes for passing to the UpdateStatus() function. */\r
-               enum USBtoSerial_StatusCodes_t\r
-               {\r
-                       Status_USBNotReady    = 0, /**< USB is not ready (disconnected from a USB host) */\r
-                       Status_USBEnumerating = 1, /**< USB interface is enumerating */\r
-                       Status_USBReady       = 2, /**< USB interface is connected and ready */\r
-               };\r
-               \r
-       /* Tasks: */\r
-               TASK(CDC_Task);\r
-\r
-       /* Function Prototypes: */\r
-               void ReconfigureSPI(void);\r
-               void UpdateStatus(uint8_t CurrentStatus);\r
-               void processHostSPIRequest(void);\r
-\r
-#endif\r
diff --git a/Projects/AVRISP_Programmer/AVRISP_Programmer.txt b/Projects/AVRISP_Programmer/AVRISP_Programmer.txt
deleted file mode 100644 (file)
index 1872cfb..0000000
+++ /dev/null
@@ -1,89 +0,0 @@
-/** \file\r
- *\r
- *  This file contains special DoxyGen information for the generation of the main page and other special\r
- *  documentation pages. It is not a project source file.\r
- */\r
\r
-/** \mainpage AVRISP_Programmer\r
- *\r
- *  Communications Device Class demonstration application.\r
- *  This gives a simple reference application for implementing\r
- *  a USB to Serial converter using the CDC class.  Data communicated\r
- *  over the USB Virtual Serial Port according to Atmel's AVR910\r
- *  protocol is used to program AVR MCUs that are\r
- *  "In-System Programmable via SPI Port".\r
- *\r
- *  After running this firmware for the first time on a new computer,\r
- *  you will need to supply the .INF file located in this demo\r
- *  project's directory as the device's driver when running under\r
- *  Windows. This will enable Windows to use its inbuilt CDC drivers,\r
- *  negating the need for custom drivers for the device. Other\r
- *  Operating Systems should automatically use their own inbuilt\r
- *  CDC-ACM drivers.\r
- *\r
- *  Usage:\r
- *   avrdude -vv -F -P COM7 -c avr910 -p t261\r
- *     Note -F flag which overrides signature check and enables programming\r
- *     of any "In-System Programmable via SPI Port" AVR MCU.  Part number,\r
- *     t261, should be set to your target device.\r
- *   avrdude -vv -F -P COM7 -c avr910 -p t261 -U flash:w:PROG.hex\r
- *     PROG.hex is the hex file to program your t261 AVR with\r
- *   avrdude -vv -F -P COM7 -b 115200 -c avr910 -p t261 -U flash:w:test.hex\r
- *     The -b 115200 sets the SPI clock to 62.5kHz from the default 125kHz and may\r
- *     work when the default programming speed fails.\r
- * AVROSP.exe -dATtiny261 -cCOM7 -rf\r
- *     AVRosp is the Open Source AVR ISP Programming Software available from Atmel.com\r
- *\r
- *  Note: on Linux systems, COM7 should be replaced with someting like /dev/ttyACM0\r
- *        You can determine this value by running dmesg after plugging in the device\r
- *  Note: you must RESET the programmer after each use (AVRdude session).\r
- *\r
- *  Note: If you experience errors with older devices, try changing DELAY_LONG\r
- *  to a larger value, such as 0xFF in AVRISP_Programmer.c\r
- *\r
- *  MISO, MOSI, and SCK are connected directly from the AVRopendous board\r
- *  to the pin of the same functionality on the target.  RESET pin on the target\r
- *  can be connected either to SS (PB0), or PC2.  Do not have any other pins\r
- *  connected - especially HWB pin, to avoid unintentional behaviour.\r
- *\r
- *  AVR910 functionality was overlayed on USBtoSerial  functionality.\r
- *  Keep this in mind when looking over the code.\r
- *  Default target speed is 125kHz and corresponds to 19200 baud, which\r
- *  is the default setting for AVRdude.\r
- *\r
- *  Changing "Baud-Rate" will change the SPI speed.  Defualt SPI clock speed\r
- *  is 8Mhz / 4 = 2MHz.  8Mhz is the device clock speed.  This is the setting at\r
- *  9600 baud.  The following is a table of baud-rate vs. SPI Speed that will result\r
- *       9600 = 2Mhz\r
- *       14400 = 1MHz\r
- *       19200 = 125kHz (AVRdude Default)\r
- *       38400 = 250kHz\r
- *       57600 = 500kHz\r
- *       115200 = 62.5kHz\r
- *\r
- *\r
- *\r
- *\r
- *  <table>\r
- *   <tr>\r
- *    <td><b>USB Mode:</b></td>\r
- *    <td>Device</td>\r
- *   </tr>\r
- *   <tr>\r
- *    <td><b>USB Class:</b></td>\r
- *    <td>Communications Device Class (CDC)</td>\r
- *   </tr>\r
- *   <tr> \r
- *    <td><b>USB Subclass:</b></td>\r
- *    <td>Abstract Control Model (ACM)</td>\r
- *   </tr>\r
- *   <tr>\r
- *    <td><b>Relevant Standards:</b></td>\r
- *    <td>USBIF CDC Class Standard</td>\r
- *   </tr>\r
- *   <tr>\r
- *    <td><b>Usable Speeds:</b></td>\r
- *    <td>Full Speed Mode</td>\r
- *   </tr>\r
- *  </table>\r
- */\r
diff --git a/Projects/AVRISP_Programmer/AVRISP_Programmer_Picture.jpg b/Projects/AVRISP_Programmer/AVRISP_Programmer_Picture.jpg
deleted file mode 100644 (file)
index 87ec3d4..0000000
Binary files a/Projects/AVRISP_Programmer/AVRISP_Programmer_Picture.jpg and /dev/null differ
diff --git a/Projects/AVRISP_Programmer/Descriptors.c b/Projects/AVRISP_Programmer/Descriptors.c
deleted file mode 100644 (file)
index 5f3ffca..0000000
+++ /dev/null
@@ -1,263 +0,0 @@
-/*\r
-             LUFA Library\r
-     Copyright (C) Dean Camera, 2009.\r
-              \r
-  dean [at] fourwalledcubicle [dot] com\r
-      www.fourwalledcubicle.com\r
-*/\r
-\r
-/*\r
-  Copyright 2009  Dean Camera (dean [at] fourwalledcubicle [dot] com)\r
-\r
-  Permission to use, copy, modify, and distribute this software\r
-  and its documentation for any purpose and without fee is hereby\r
-  granted, provided that the above copyright notice appear in all\r
-  copies and that both that the copyright notice and this\r
-  permission notice and warranty disclaimer appear in supporting\r
-  documentation, and that the name of the author not be used in\r
-  advertising or publicity pertaining to distribution of the\r
-  software without specific, written prior permission.\r
-\r
-  The author disclaim all warranties with regard to this\r
-  software, including all implied warranties of merchantability\r
-  and fitness.  In no event shall the author be liable for any\r
-  special, indirect or consequential damages or any damages\r
-  whatsoever resulting from loss of use, data or profits, whether\r
-  in an action of contract, negligence or other tortious action,\r
-  arising out of or in connection with the use or performance of\r
-  this software.\r
-*/\r
-\r
-/** \file\r
- *\r
- *  USB Device Descriptors, for library use when in USB device mode. Descriptors are special \r
- *  computer-readable structures which the host requests upon device enumeration, to determine\r
- *  the device's capabilities and functions.  \r
- */\r
-\r
-#include "Descriptors.h"\r
-\r
-/** Device descriptor structure. This descriptor, located in FLASH memory, describes the overall\r
- *  device characteristics, including the supported USB version, control endpoint size and the\r
- *  number of device configurations. The descriptor is read out by the USB host when the enumeration\r
- *  process begins.\r
- */\r
-USB_Descriptor_Device_t PROGMEM DeviceDescriptor =\r
-{\r
-       Header:                 {Size: sizeof(USB_Descriptor_Device_t), Type: DTYPE_Device},\r
-               \r
-       USBSpecification:       VERSION_BCD(01.10),\r
-       Class:                  0x02,\r
-       SubClass:               0x00,\r
-       Protocol:               0x00,\r
-                               \r
-       Endpoint0Size:          8,\r
-               \r
-       VendorID:               0x03EB,\r
-       ProductID:              0x204F,\r
-       ReleaseNumber:          0x0000,\r
-               \r
-       ManufacturerStrIndex:   0x01,\r
-       ProductStrIndex:        0x02,\r
-       SerialNumStrIndex:      NO_DESCRIPTOR,\r
-               \r
-       NumberOfConfigurations: 1\r
-};\r
-\r
-/** Configuration descriptor structure. This descriptor, located in FLASH memory, describes the usage\r
- *  of the device in one of its supported configurations, including information about any device interfaces\r
- *  and endpoints. The descriptor is read out by the USB host during the enumeration process when selecting\r
- *  a configuration so that the host may correctly communicate with the USB device.\r
- */\r
-USB_Descriptor_Configuration_t PROGMEM ConfigurationDescriptor =\r
-{\r
-       Config:\r
-               {\r
-                       Header:                 {Size: sizeof(USB_Descriptor_Configuration_Header_t), Type: DTYPE_Configuration},\r
-\r
-                       TotalConfigurationSize: sizeof(USB_Descriptor_Configuration_t),\r
-                       TotalInterfaces:        2,\r
-                               \r
-                       ConfigurationNumber:    1,\r
-                       ConfigurationStrIndex:  NO_DESCRIPTOR,\r
-                               \r
-                       ConfigAttributes:       (USB_CONFIG_ATTR_BUSPOWERED | USB_CONFIG_ATTR_SELFPOWERED),\r
-                       \r
-                       MaxPowerConsumption:    USB_CONFIG_POWER_MA(100)\r
-               },\r
-               \r
-       CCI_Interface:\r
-               {\r
-                       Header:                 {Size: sizeof(USB_Descriptor_Interface_t), Type: DTYPE_Interface},\r
-\r
-                       InterfaceNumber:        0,\r
-                       AlternateSetting:       0,\r
-                       \r
-                       TotalEndpoints:         1,\r
-                               \r
-                       Class:                  0x02,\r
-                       SubClass:               0x02,\r
-                       Protocol:               0x01,\r
-                               \r
-                       InterfaceStrIndex:      NO_DESCRIPTOR\r
-               },\r
-\r
-       CDC_Functional_IntHeader:\r
-               {\r
-                       Header:                 {Size: sizeof(CDC_FUNCTIONAL_DESCRIPTOR(2)), Type: 0x24},\r
-                       SubType:                0x00,\r
-                       \r
-                       Data:                   {0x01, 0x10}\r
-               },\r
-\r
-       CDC_Functional_CallManagement:\r
-               {\r
-                       Header:                 {Size: sizeof(CDC_FUNCTIONAL_DESCRIPTOR(2)), Type: 0x24},\r
-                       SubType:                0x01,\r
-                       \r
-                       Data:                   {0x03, 0x01}\r
-               },\r
-\r
-       CDC_Functional_AbstractControlManagement:\r
-               {\r
-                       Header:                 {Size: sizeof(CDC_FUNCTIONAL_DESCRIPTOR(1)), Type: 0x24},\r
-                       SubType:                0x02,\r
-                       \r
-                       Data:                   {0x06}\r
-               },\r
-               \r
-       CDC_Functional_Union:\r
-               {\r
-                       Header:                 {Size: sizeof(CDC_FUNCTIONAL_DESCRIPTOR(2)), Type: 0x24},\r
-                       SubType:                0x06,\r
-                       \r
-                       Data:                   {0x00, 0x01}\r
-               },\r
-\r
-       ManagementEndpoint:\r
-               {\r
-                       Header:                 {Size: sizeof(USB_Descriptor_Endpoint_t), Type: DTYPE_Endpoint},\r
-                                                                                \r
-                       EndpointAddress:        (ENDPOINT_DESCRIPTOR_DIR_IN | CDC_NOTIFICATION_EPNUM),\r
-                       Attributes:                     EP_TYPE_INTERRUPT,\r
-                       EndpointSize:           CDC_NOTIFICATION_EPSIZE,\r
-                       PollingIntervalMS:              0xFF\r
-               },\r
-\r
-       DCI_Interface:\r
-               {\r
-                       Header:                 {Size: sizeof(USB_Descriptor_Interface_t), Type: DTYPE_Interface},\r
-\r
-                       InterfaceNumber:        1,\r
-                       AlternateSetting:       0,\r
-                       \r
-                       TotalEndpoints:         2,\r
-                               \r
-                       Class:                  0x0A,\r
-                       SubClass:               0x00,\r
-                       Protocol:               0x00,\r
-                               \r
-                       InterfaceStrIndex:      NO_DESCRIPTOR\r
-               },\r
-\r
-       DataOutEndpoint:\r
-               {\r
-                       Header:                 {Size: sizeof(USB_Descriptor_Endpoint_t), Type: DTYPE_Endpoint},\r
-                                                                                \r
-                       EndpointAddress:        (ENDPOINT_DESCRIPTOR_DIR_OUT | CDC_RX_EPNUM),\r
-                       Attributes:                     EP_TYPE_BULK,\r
-                       EndpointSize:           CDC_TXRX_EPSIZE,\r
-                       PollingIntervalMS:              0x00\r
-               },\r
-               \r
-       DataInEndpoint:\r
-               {\r
-                       Header:                 {Size: sizeof(USB_Descriptor_Endpoint_t), Type: DTYPE_Endpoint},\r
-                                                                                \r
-                       EndpointAddress:        (ENDPOINT_DESCRIPTOR_DIR_IN | CDC_TX_EPNUM),\r
-                       Attributes:                     EP_TYPE_BULK,\r
-                       EndpointSize:           CDC_TXRX_EPSIZE,\r
-                       PollingIntervalMS:              0x00\r
-               }\r
-};\r
-\r
-/** Language descriptor structure. This descriptor, located in FLASH memory, is returned when the host requests\r
- *  the string descriptor with index 0 (the first index). It is actually an array of 16-bit integers, which indicate\r
- *  via the language ID table available at USB.org what languages the device supports for its string descriptors.\r
- */\r
-USB_Descriptor_String_t PROGMEM LanguageString =\r
-{\r
-       Header:                 {Size: USB_STRING_LEN(1), Type: DTYPE_String},\r
-               \r
-       UnicodeString:          {LANGUAGE_ID_ENG}\r
-};\r
-\r
-/** Manufacturer descriptor string. This is a Unicode string containing the manufacturer's details in human readable\r
- *  form, and is read out upon request by the host when the appropriate string ID is requested, listed in the Device\r
- *  Descriptor.\r
- */\r
-USB_Descriptor_String_t PROGMEM ManufacturerString =\r
-{\r
-       Header:                 {Size: USB_STRING_LEN(19), Type: DTYPE_String},\r
-               \r
-       UnicodeString:          L"www.AVRopendous.org"\r
-};\r
-\r
-/** Product descriptor string. This is a Unicode string containing the product's details in human readable form,\r
- *  and is read out upon request by the host when the appropriate string ID is requested, listed in the Device\r
- *  Descriptor.\r
- */\r
-USB_Descriptor_String_t PROGMEM ProductString =\r
-{\r
-       Header:                 {Size: USB_STRING_LEN(29), Type: DTYPE_String},\r
-               \r
-       UnicodeString:          L"LUFA-Based AVR ISP Programmer"\r
-};\r
-\r
-/** This function is called by the library when in device mode, and must be overridden (see StdDescriptors.h\r
- *  documentation) by the application code so that the address and size of a requested descriptor can be given\r
- *  to the USB library. When the device recieves a Get Descriptor request on the control endpoint, this function\r
- *  is called so that the descriptor details can be passed back and the appropriate descriptor sent back to the\r
- *  USB host.\r
- */\r
-uint16_t USB_GetDescriptor(const uint16_t wValue, const uint8_t wIndex, void** const DescriptorAddress)\r
-{\r
-       const uint8_t  DescriptorType   = (wValue >> 8);\r
-       const uint8_t  DescriptorNumber = (wValue & 0xFF);\r
-\r
-       void*    Address = NULL;\r
-       uint16_t Size    = NO_DESCRIPTOR;\r
-\r
-       switch (DescriptorType)\r
-       {\r
-               case DTYPE_Device:\r
-                       Address = DESCRIPTOR_ADDRESS(DeviceDescriptor);\r
-                       Size    = sizeof(USB_Descriptor_Device_t);\r
-                       break;\r
-               case DTYPE_Configuration:\r
-                       Address = DESCRIPTOR_ADDRESS(ConfigurationDescriptor);\r
-                       Size    = sizeof(USB_Descriptor_Configuration_t);\r
-                       break;\r
-               case DTYPE_String:\r
-                       switch (DescriptorNumber)\r
-                       {\r
-                               case 0x00:\r
-                                       Address = DESCRIPTOR_ADDRESS(LanguageString);\r
-                                       Size    = pgm_read_byte(&LanguageString.Header.Size);\r
-                                       break;\r
-                               case 0x01:\r
-                                       Address = DESCRIPTOR_ADDRESS(ManufacturerString);\r
-                                       Size    = pgm_read_byte(&ManufacturerString.Header.Size);\r
-                                       break;\r
-                               case 0x02:\r
-                                       Address = DESCRIPTOR_ADDRESS(ProductString);\r
-                                       Size    = pgm_read_byte(&ProductString.Header.Size);\r
-                                       break;\r
-                       }\r
-                       \r
-                       break;\r
-       }\r
-       \r
-       *DescriptorAddress = Address;\r
-       return Size;\r
-}\r
diff --git a/Projects/AVRISP_Programmer/Descriptors.h b/Projects/AVRISP_Programmer/Descriptors.h
deleted file mode 100644 (file)
index bec5e40..0000000
+++ /dev/null
@@ -1,98 +0,0 @@
-/*\r
-             LUFA Library\r
-     Copyright (C) Dean Camera, 2009.\r
-              \r
-  dean [at] fourwalledcubicle [dot] com\r
-      www.fourwalledcubicle.com\r
-*/\r
-\r
-/*\r
-  Copyright 2009  Dean Camera (dean [at] fourwalledcubicle [dot] com)\r
-\r
-  Permission to use, copy, modify, and distribute this software\r
-  and its documentation for any purpose and without fee is hereby\r
-  granted, provided that the above copyright notice appear in all\r
-  copies and that both that the copyright notice and this\r
-  permission notice and warranty disclaimer appear in supporting\r
-  documentation, and that the name of the author not be used in\r
-  advertising or publicity pertaining to distribution of the\r
-  software without specific, written prior permission.\r
-\r
-  The author disclaim all warranties with regard to this\r
-  software, including all implied warranties of merchantability\r
-  and fitness.  In no event shall the author be liable for any\r
-  special, indirect or consequential damages or any damages\r
-  whatsoever resulting from loss of use, data or profits, whether\r
-  in an action of contract, negligence or other tortious action,\r
-  arising out of or in connection with the use or performance of\r
-  this software.\r
-*/\r
-\r
-/** \file\r
- *\r
- *  Header file for Descriptors.c.\r
- */\r
\r
-#ifndef _DESCRIPTORS_H_\r
-#define _DESCRIPTORS_H_\r
-\r
-       /* Includes: */\r
-               #include <LUFA/Drivers/USB/USB.h>\r
-\r
-               #include <avr/pgmspace.h>\r
-\r
-       /* Macros: */\r
-               /** Macro to define a CDC class-specific functional descriptor. CDC functional descriptors have a\r
-                *  uniform structure but variable sized data payloads, thus cannot be represented accurately by\r
-                *  a single typedef struct. A macro is used instead so that functional descriptors can be created\r
-                *  easily by specifying the size of the payload. This allows sizeof() to work correctly.\r
-                *\r
-                *  \param DataSize  Size in bytes of the CDC functional descriptor's data payload\r
-                */\r
-               #define CDC_FUNCTIONAL_DESCRIPTOR(DataSize)        \\r
-                    struct                                        \\r
-                    {                                             \\r
-                         USB_Descriptor_Header_t Header;          \\r
-                             uint8_t                 SubType;         \\r
-                         uint8_t                 Data[DataSize];  \\r
-                    }\r
-                        \r
-               /** Endpoint number of the CDC device-to-host notification IN endpoint. */\r
-               #define CDC_NOTIFICATION_EPNUM         2\r
-\r
-               /** Endpoint number of the CDC device-to-host data IN endpoint. */\r
-               #define CDC_TX_EPNUM                   3        \r
-\r
-               /** Endpoint number of the CDC host-to-device data OUT endpoint. */\r
-               #define CDC_RX_EPNUM                   4        \r
-\r
-               /** Size in bytes of the CDC device-to-host notification IN endpoint. */\r
-               #define CDC_NOTIFICATION_EPSIZE        8\r
-\r
-               /** Size in bytes of the CDC data IN and OUT endpoints. */\r
-               #define CDC_TXRX_EPSIZE                16       \r
-\r
-       /* Type Defines: */\r
-               /** Type define for the device configuration descriptor structure. This must be defined in the\r
-                *  application code, as the configuration descriptor contains several sub-descriptors which\r
-                *  vary between devices, and which describe the device's usage to the host.\r
-                */\r
-               typedef struct\r
-               {\r
-                       USB_Descriptor_Configuration_Header_t    Config;\r
-                       USB_Descriptor_Interface_t               CCI_Interface;\r
-                       CDC_FUNCTIONAL_DESCRIPTOR(2)             CDC_Functional_IntHeader;\r
-                       CDC_FUNCTIONAL_DESCRIPTOR(2)             CDC_Functional_CallManagement;\r
-                       CDC_FUNCTIONAL_DESCRIPTOR(1)             CDC_Functional_AbstractControlManagement;\r
-                       CDC_FUNCTIONAL_DESCRIPTOR(2)             CDC_Functional_Union;\r
-                       USB_Descriptor_Endpoint_t                ManagementEndpoint;\r
-                       USB_Descriptor_Interface_t               DCI_Interface;\r
-                       USB_Descriptor_Endpoint_t                DataOutEndpoint;\r
-                       USB_Descriptor_Endpoint_t                DataInEndpoint;\r
-               } USB_Descriptor_Configuration_t;\r
-\r
-       /* Function Prototypes: */\r
-               uint16_t USB_GetDescriptor(const uint16_t wValue, const uint8_t wIndex, void** const DescriptorAddress)\r
-                                          ATTR_WARN_UNUSED_RESULT ATTR_NON_NULL_PTR_ARG(3);\r
-\r
-#endif\r
diff --git a/Projects/AVRISP_Programmer/Doxygen.conf b/Projects/AVRISP_Programmer/Doxygen.conf
deleted file mode 100644 (file)
index 1eb8c54..0000000
+++ /dev/null
@@ -1,1485 +0,0 @@
-# Doxyfile 1.5.7.1\r
-\r
-# This file describes the settings to be used by the documentation system\r
-# doxygen (www.doxygen.org) for a project\r
-#\r
-# All text after a hash (#) is considered a comment and will be ignored\r
-# The format is:\r
-#       TAG = value [value, ...]\r
-# For lists items can also be appended using:\r
-#       TAG += value [value, ...]\r
-# Values that contain spaces should be placed between quotes (" ")\r
-\r
-#---------------------------------------------------------------------------\r
-# Project related configuration options\r
-#---------------------------------------------------------------------------\r
-\r
-# This tag specifies the encoding used for all characters in the config file \r
-# that follow. The default is UTF-8 which is also the encoding used for all \r
-# text before the first occurrence of this tag. Doxygen uses libiconv (or the \r
-# iconv built into libc) for the transcoding. See \r
-# http://www.gnu.org/software/libiconv for the list of possible encodings.\r
-\r
-DOXYFILE_ENCODING      = UTF-8\r
-\r
-# The PROJECT_NAME tag is a single word (or a sequence of words surrounded \r
-# by quotes) that should identify the project.\r
-\r
-PROJECT_NAME           = "LUFA Library - USB to Serial Device Demo"\r
-\r
-# The PROJECT_NUMBER tag can be used to enter a project or revision number. \r
-# This could be handy for archiving the generated documentation or \r
-# if some version control system is used.\r
-\r
-PROJECT_NUMBER         = 0.0.0\r
-\r
-# The OUTPUT_DIRECTORY tag is used to specify the (relative or absolute) \r
-# base path where the generated documentation will be put. \r
-# If a relative path is entered, it will be relative to the location \r
-# where doxygen was started. If left blank the current directory will be used.\r
-\r
-OUTPUT_DIRECTORY       = ./Documentation/\r
-\r
-# If the CREATE_SUBDIRS tag is set to YES, then doxygen will create \r
-# 4096 sub-directories (in 2 levels) under the output directory of each output \r
-# format and will distribute the generated files over these directories. \r
-# Enabling this option can be useful when feeding doxygen a huge amount of \r
-# source files, where putting all generated files in the same directory would \r
-# otherwise cause performance problems for the file system.\r
-\r
-CREATE_SUBDIRS         = YES\r
-\r
-# The OUTPUT_LANGUAGE tag is used to specify the language in which all \r
-# documentation generated by doxygen is written. Doxygen will use this \r
-# information to generate all constant output in the proper language. \r
-# The default language is English, other supported languages are: \r
-# Afrikaans, Arabic, Brazilian, Catalan, Chinese, Chinese-Traditional, \r
-# Croatian, Czech, Danish, Dutch, Farsi, Finnish, French, German, Greek, \r
-# Hungarian, Italian, Japanese, Japanese-en (Japanese with English messages), \r
-# Korean, Korean-en, Lithuanian, Norwegian, Macedonian, Persian, Polish, \r
-# Portuguese, Romanian, Russian, Serbian, Serbian-Cyrilic, Slovak, Slovene, \r
-# Spanish, Swedish, and Ukrainian.\r
-\r
-OUTPUT_LANGUAGE        = English\r
-\r
-# If the BRIEF_MEMBER_DESC tag is set to YES (the default) Doxygen will \r
-# include brief member descriptions after the members that are listed in \r
-# the file and class documentation (similar to JavaDoc). \r
-# Set to NO to disable this.\r
-\r
-BRIEF_MEMBER_DESC      = YES\r
-\r
-# If the REPEAT_BRIEF tag is set to YES (the default) Doxygen will prepend \r
-# the brief description of a member or function before the detailed description. \r
-# Note: if both HIDE_UNDOC_MEMBERS and BRIEF_MEMBER_DESC are set to NO, the \r
-# brief descriptions will be completely suppressed.\r
-\r
-REPEAT_BRIEF           = YES\r
-\r
-# This tag implements a quasi-intelligent brief description abbreviator \r
-# that is used to form the text in various listings. Each string \r
-# in this list, if found as the leading text of the brief description, will be \r
-# stripped from the text and the result after processing the whole list, is \r
-# used as the annotated text. Otherwise, the brief description is used as-is. \r
-# If left blank, the following values are used ("$name" is automatically \r
-# replaced with the name of the entity): "The $name class" "The $name widget" \r
-# "The $name file" "is" "provides" "specifies" "contains" \r
-# "represents" "a" "an" "the"\r
-\r
-ABBREVIATE_BRIEF       = "The $name class" \\r
-                         "The $name widget" \\r
-                         "The $name file" \\r
-                         is \\r
-                         provides \\r
-                         specifies \\r
-                         contains \\r
-                         represents \\r
-                         a \\r
-                         an \\r
-                         the\r
-\r
-# If the ALWAYS_DETAILED_SEC and REPEAT_BRIEF tags are both set to YES then \r
-# Doxygen will generate a detailed section even if there is only a brief \r
-# description.\r
-\r
-ALWAYS_DETAILED_SEC    = NO\r
-\r
-# If the INLINE_INHERITED_MEMB tag is set to YES, doxygen will show all \r
-# inherited members of a class in the documentation of that class as if those \r
-# members were ordinary class members. Constructors, destructors and assignment \r
-# operators of the base classes will not be shown.\r
-\r
-INLINE_INHERITED_MEMB  = NO\r
-\r
-# If the FULL_PATH_NAMES tag is set to YES then Doxygen will prepend the full \r
-# path before files name in the file list and in the header files. If set \r
-# to NO the shortest path that makes the file name unique will be used.\r
-\r
-FULL_PATH_NAMES        = YES\r
-\r
-# If the FULL_PATH_NAMES tag is set to YES then the STRIP_FROM_PATH tag \r
-# can be used to strip a user-defined part of the path. Stripping is \r
-# only done if one of the specified strings matches the left-hand part of \r
-# the path. The tag can be used to show relative paths in the file list. \r
-# If left blank the directory from which doxygen is run is used as the \r
-# path to strip.\r
-\r
-STRIP_FROM_PATH        = \r
-\r
-# The STRIP_FROM_INC_PATH tag can be used to strip a user-defined part of \r
-# the path mentioned in the documentation of a class, which tells \r
-# the reader which header file to include in order to use a class. \r
-# If left blank only the name of the header file containing the class \r
-# definition is used. Otherwise one should specify the include paths that \r
-# are normally passed to the compiler using the -I flag.\r
-\r
-STRIP_FROM_INC_PATH    = \r
-\r
-# If the SHORT_NAMES tag is set to YES, doxygen will generate much shorter \r
-# (but less readable) file names. This can be useful is your file systems \r
-# doesn't support long names like on DOS, Mac, or CD-ROM.\r
-\r
-SHORT_NAMES            = YES\r
-\r
-# If the JAVADOC_AUTOBRIEF tag is set to YES then Doxygen \r
-# will interpret the first line (until the first dot) of a JavaDoc-style \r
-# comment as the brief description. If set to NO, the JavaDoc \r
-# comments will behave just like regular Qt-style comments \r
-# (thus requiring an explicit @brief command for a brief description.)\r
-\r
-JAVADOC_AUTOBRIEF      = NO\r
-\r
-# If the QT_AUTOBRIEF tag is set to YES then Doxygen will \r
-# interpret the first line (until the first dot) of a Qt-style \r
-# comment as the brief description. If set to NO, the comments \r
-# will behave just like regular Qt-style comments (thus requiring \r
-# an explicit \brief command for a brief description.)\r
-\r
-QT_AUTOBRIEF           = NO\r
-\r
-# The MULTILINE_CPP_IS_BRIEF tag can be set to YES to make Doxygen \r
-# treat a multi-line C++ special comment block (i.e. a block of //! or /// \r
-# comments) as a brief description. This used to be the default behaviour. \r
-# The new default is to treat a multi-line C++ comment block as a detailed \r
-# description. Set this tag to YES if you prefer the old behaviour instead.\r
-\r
-MULTILINE_CPP_IS_BRIEF = NO\r
-\r
-# If the INHERIT_DOCS tag is set to YES (the default) then an undocumented \r
-# member inherits the documentation from any documented member that it \r
-# re-implements.\r
-\r
-INHERIT_DOCS           = YES\r
-\r
-# If the SEPARATE_MEMBER_PAGES tag is set to YES, then doxygen will produce \r
-# a new page for each member. If set to NO, the documentation of a member will \r
-# be part of the file/class/namespace that contains it.\r
-\r
-SEPARATE_MEMBER_PAGES  = NO\r
-\r
-# The TAB_SIZE tag can be used to set the number of spaces in a tab. \r
-# Doxygen uses this value to replace tabs by spaces in code fragments.\r
-\r
-TAB_SIZE               = 4\r
-\r
-# This tag can be used to specify a number of aliases that acts \r
-# as commands in the documentation. An alias has the form "name=value". \r
-# For example adding "sideeffect=\par Side Effects:\n" will allow you to \r
-# put the command \sideeffect (or @sideeffect) in the documentation, which \r
-# will result in a user-defined paragraph with heading "Side Effects:". \r
-# You can put \n's in the value part of an alias to insert newlines.\r
-\r
-ALIASES                = \r
-\r
-# Set the OPTIMIZE_OUTPUT_FOR_C tag to YES if your project consists of C \r
-# sources only. Doxygen will then generate output that is more tailored for C. \r
-# For instance, some of the names that are used will be different. The list \r
-# of all members will be omitted, etc.\r
-\r
-OPTIMIZE_OUTPUT_FOR_C  = YES\r
-\r
-# Set the OPTIMIZE_OUTPUT_JAVA tag to YES if your project consists of Java \r
-# sources only. Doxygen will then generate output that is more tailored for \r
-# Java. For instance, namespaces will be presented as packages, qualified \r
-# scopes will look different, etc.\r
-\r
-OPTIMIZE_OUTPUT_JAVA   = NO\r
-\r
-# Set the OPTIMIZE_FOR_FORTRAN tag to YES if your project consists of Fortran \r
-# sources only. Doxygen will then generate output that is more tailored for \r
-# Fortran.\r
-\r
-OPTIMIZE_FOR_FORTRAN   = NO\r
-\r
-# Set the OPTIMIZE_OUTPUT_VHDL tag to YES if your project consists of VHDL \r
-# sources. Doxygen will then generate output that is tailored for \r
-# VHDL.\r
-\r
-OPTIMIZE_OUTPUT_VHDL   = NO\r
-\r
-# If you use STL classes (i.e. std::string, std::vector, etc.) but do not want \r
-# to include (a tag file for) the STL sources as input, then you should \r
-# set this tag to YES in order to let doxygen match functions declarations and \r
-# definitions whose arguments contain STL classes (e.g. func(std::string); v.s. \r
-# func(std::string) {}). This also make the inheritance and collaboration \r
-# diagrams that involve STL classes more complete and accurate.\r
-\r
-BUILTIN_STL_SUPPORT    = NO\r
-\r
-# If you use Microsoft's C++/CLI language, you should set this option to YES to\r
-# enable parsing support.\r
-\r
-CPP_CLI_SUPPORT        = NO\r
-\r
-# Set the SIP_SUPPORT tag to YES if your project consists of sip sources only. \r
-# Doxygen will parse them like normal C++ but will assume all classes use public \r
-# instead of private inheritance when no explicit protection keyword is present.\r
-\r
-SIP_SUPPORT            = NO\r
-\r
-# For Microsoft's IDL there are propget and propput attributes to indicate getter \r
-# and setter methods for a property. Setting this option to YES (the default) \r
-# will make doxygen to replace the get and set methods by a property in the \r
-# documentation. This will only work if the methods are indeed getting or \r
-# setting a simple type. If this is not the case, or you want to show the \r
-# methods anyway, you should set this option to NO.\r
-\r
-IDL_PROPERTY_SUPPORT   = YES\r
-\r
-# If member grouping is used in the documentation and the DISTRIBUTE_GROUP_DOC \r
-# tag is set to YES, then doxygen will reuse the documentation of the first \r
-# member in the group (if any) for the other members of the group. By default \r
-# all members of a group must be documented explicitly.\r
-\r
-DISTRIBUTE_GROUP_DOC   = NO\r
-\r
-# Set the SUBGROUPING tag to YES (the default) to allow class member groups of \r
-# the same type (for instance a group of public functions) to be put as a \r
-# subgroup of that type (e.g. under the Public Functions section). Set it to \r
-# NO to prevent subgrouping. Alternatively, this can be done per class using \r
-# the \nosubgrouping command.\r
-\r
-SUBGROUPING            = YES\r
-\r
-# When TYPEDEF_HIDES_STRUCT is enabled, a typedef of a struct, union, or enum \r
-# is documented as struct, union, or enum with the name of the typedef. So \r
-# typedef struct TypeS {} TypeT, will appear in the documentation as a struct \r
-# with name TypeT. When disabled the typedef will appear as a member of a file, \r
-# namespace, or class. And the struct will be named TypeS. This can typically \r
-# be useful for C code in case the coding convention dictates that all compound \r
-# types are typedef'ed and only the typedef is referenced, never the tag name.\r
-\r
-TYPEDEF_HIDES_STRUCT   = NO\r
-\r
-# The SYMBOL_CACHE_SIZE determines the size of the internal cache use to \r
-# determine which symbols to keep in memory and which to flush to disk.\r
-# When the cache is full, less often used symbols will be written to disk.\r
-# For small to medium size projects (<1000 input files) the default value is \r
-# probably good enough. For larger projects a too small cache size can cause \r
-# doxygen to be busy swapping symbols to and from disk most of the time \r
-# causing a significant performance penality. \r
-# If the system has enough physical memory increasing the cache will improve the \r
-# performance by keeping more symbols in memory. Note that the value works on \r
-# a logarithmic scale so increasing the size by one will rougly double the \r
-# memory usage. The cache size is given by this formula: \r
-# 2^(16+SYMBOL_CACHE_SIZE). The valid range is 0..9, the default is 0, \r
-# corresponding to a cache size of 2^16 = 65536 symbols\r
-\r
-SYMBOL_CACHE_SIZE      = 0\r
-\r
-#---------------------------------------------------------------------------\r
-# Build related configuration options\r
-#---------------------------------------------------------------------------\r
-\r
-# If the EXTRACT_ALL tag is set to YES doxygen will assume all entities in \r
-# documentation are documented, even if no documentation was available. \r
-# Private class members and static file members will be hidden unless \r
-# the EXTRACT_PRIVATE and EXTRACT_STATIC tags are set to YES\r
-\r
-EXTRACT_ALL            = YES\r
-\r
-# If the EXTRACT_PRIVATE tag is set to YES all private members of a class \r
-# will be included in the documentation.\r
-\r
-EXTRACT_PRIVATE        = YES\r
-\r
-# If the EXTRACT_STATIC tag is set to YES all static members of a file \r
-# will be included in the documentation.\r
-\r
-EXTRACT_STATIC         = YES\r
-\r
-# If the EXTRACT_LOCAL_CLASSES tag is set to YES classes (and structs) \r
-# defined locally in source files will be included in the documentation. \r
-# If set to NO only classes defined in header files are included.\r
-\r
-EXTRACT_LOCAL_CLASSES  = YES\r
-\r
-# This flag is only useful for Objective-C code. When set to YES local \r
-# methods, which are defined in the implementation section but not in \r
-# the interface are included in the documentation. \r
-# If set to NO (the default) only methods in the interface are included.\r
-\r
-EXTRACT_LOCAL_METHODS  = NO\r
-\r
-# If this flag is set to YES, the members of anonymous namespaces will be \r
-# extracted and appear in the documentation as a namespace called \r
-# 'anonymous_namespace{file}', where file will be replaced with the base \r
-# name of the file that contains the anonymous namespace. By default \r
-# anonymous namespace are hidden.\r
-\r
-EXTRACT_ANON_NSPACES   = NO\r
-\r
-# If the HIDE_UNDOC_MEMBERS tag is set to YES, Doxygen will hide all \r
-# undocumented members of documented classes, files or namespaces. \r
-# If set to NO (the default) these members will be included in the \r
-# various overviews, but no documentation section is generated. \r
-# This option has no effect if EXTRACT_ALL is enabled.\r
-\r
-HIDE_UNDOC_MEMBERS     = NO\r
-\r
-# If the HIDE_UNDOC_CLASSES tag is set to YES, Doxygen will hide all \r
-# undocumented classes that are normally visible in the class hierarchy. \r
-# If set to NO (the default) these classes will be included in the various \r
-# overviews. This option has no effect if EXTRACT_ALL is enabled.\r
-\r
-HIDE_UNDOC_CLASSES     = NO\r
-\r
-# If the HIDE_FRIEND_COMPOUNDS tag is set to YES, Doxygen will hide all \r
-# friend (class|struct|union) declarations. \r
-# If set to NO (the default) these declarations will be included in the \r
-# documentation.\r
-\r
-HIDE_FRIEND_COMPOUNDS  = NO\r
-\r
-# If the HIDE_IN_BODY_DOCS tag is set to YES, Doxygen will hide any \r
-# documentation blocks found inside the body of a function. \r
-# If set to NO (the default) these blocks will be appended to the \r
-# function's detailed documentation block.\r
-\r
-HIDE_IN_BODY_DOCS      = NO\r
-\r
-# The INTERNAL_DOCS tag determines if documentation \r
-# that is typed after a \internal command is included. If the tag is set \r
-# to NO (the default) then the documentation will be excluded. \r
-# Set it to YES to include the internal documentation.\r
-\r
-INTERNAL_DOCS          = NO\r
-\r
-# If the CASE_SENSE_NAMES tag is set to NO then Doxygen will only generate \r
-# file names in lower-case letters. If set to YES upper-case letters are also \r
-# allowed. This is useful if you have classes or files whose names only differ \r
-# in case and if your file system supports case sensitive file names. Windows \r
-# and Mac users are advised to set this option to NO.\r
-\r
-CASE_SENSE_NAMES       = NO\r
-\r
-# If the HIDE_SCOPE_NAMES tag is set to NO (the default) then Doxygen \r
-# will show members with their full class and namespace scopes in the \r
-# documentation. If set to YES the scope will be hidden.\r
-\r
-HIDE_SCOPE_NAMES       = NO\r
-\r
-# If the SHOW_INCLUDE_FILES tag is set to YES (the default) then Doxygen \r
-# will put a list of the files that are included by a file in the documentation \r
-# of that file.\r
-\r
-SHOW_INCLUDE_FILES     = YES\r
-\r
-# If the INLINE_INFO tag is set to YES (the default) then a tag [inline] \r
-# is inserted in the documentation for inline members.\r
-\r
-INLINE_INFO            = YES\r
-\r
-# If the SORT_MEMBER_DOCS tag is set to YES (the default) then doxygen \r
-# will sort the (detailed) documentation of file and class members \r
-# alphabetically by member name. If set to NO the members will appear in \r
-# declaration order.\r
-\r
-SORT_MEMBER_DOCS       = YES\r
-\r
-# If the SORT_BRIEF_DOCS tag is set to YES then doxygen will sort the \r
-# brief documentation of file, namespace and class members alphabetically \r
-# by member name. If set to NO (the default) the members will appear in \r
-# declaration order.\r
-\r
-SORT_BRIEF_DOCS        = NO\r
-\r
-# If the SORT_GROUP_NAMES tag is set to YES then doxygen will sort the \r
-# hierarchy of group names into alphabetical order. If set to NO (the default) \r
-# the group names will appear in their defined order.\r
-\r
-SORT_GROUP_NAMES       = NO\r
-\r
-# If the SORT_BY_SCOPE_NAME tag is set to YES, the class list will be \r
-# sorted by fully-qualified names, including namespaces. If set to \r
-# NO (the default), the class list will be sorted only by class name, \r
-# not including the namespace part. \r
-# Note: This option is not very useful if HIDE_SCOPE_NAMES is set to YES.\r
-# Note: This option applies only to the class list, not to the \r
-# alphabetical list.\r
-\r
-SORT_BY_SCOPE_NAME     = NO\r
-\r
-# The GENERATE_TODOLIST tag can be used to enable (YES) or \r
-# disable (NO) the todo list. This list is created by putting \todo \r
-# commands in the documentation.\r
-\r
-GENERATE_TODOLIST      = NO\r
-\r
-# The GENERATE_TESTLIST tag can be used to enable (YES) or \r
-# disable (NO) the test list. This list is created by putting \test \r
-# commands in the documentation.\r
-\r
-GENERATE_TESTLIST      = NO\r
-\r
-# The GENERATE_BUGLIST tag can be used to enable (YES) or \r
-# disable (NO) the bug list. This list is created by putting \bug \r
-# commands in the documentation.\r
-\r
-GENERATE_BUGLIST       = NO\r
-\r
-# The GENERATE_DEPRECATEDLIST tag can be used to enable (YES) or \r
-# disable (NO) the deprecated list. This list is created by putting \r
-# \deprecated commands in the documentation.\r
-\r
-GENERATE_DEPRECATEDLIST= YES\r
-\r
-# The ENABLED_SECTIONS tag can be used to enable conditional \r
-# documentation sections, marked by \if sectionname ... \endif.\r
-\r
-ENABLED_SECTIONS       = \r
-\r
-# The MAX_INITIALIZER_LINES tag determines the maximum number of lines \r
-# the initial value of a variable or define consists of for it to appear in \r
-# the documentation. If the initializer consists of more lines than specified \r
-# here it will be hidden. Use a value of 0 to hide initializers completely. \r
-# The appearance of the initializer of individual variables and defines in the \r
-# documentation can be controlled using \showinitializer or \hideinitializer \r
-# command in the documentation regardless of this setting.\r
-\r
-MAX_INITIALIZER_LINES  = 30\r
-\r
-# Set the SHOW_USED_FILES tag to NO to disable the list of files generated \r
-# at the bottom of the documentation of classes and structs. If set to YES the \r
-# list will mention the files that were used to generate the documentation.\r
-\r
-SHOW_USED_FILES        = YES\r
-\r
-# If the sources in your project are distributed over multiple directories \r
-# then setting the SHOW_DIRECTORIES tag to YES will show the directory hierarchy \r
-# in the documentation. The default is NO.\r
-\r
-SHOW_DIRECTORIES       = YES\r
-\r
-# Set the SHOW_FILES tag to NO to disable the generation of the Files page.\r
-# This will remove the Files entry from the Quick Index and from the \r
-# Folder Tree View (if specified). The default is YES.\r
-\r
-SHOW_FILES             = YES\r
-\r
-# Set the SHOW_NAMESPACES tag to NO to disable the generation of the \r
-# Namespaces page.  This will remove the Namespaces entry from the Quick Index\r
-# and from the Folder Tree View (if specified). The default is YES.\r
-\r
-SHOW_NAMESPACES        = YES\r
-\r
-# The FILE_VERSION_FILTER tag can be used to specify a program or script that \r
-# doxygen should invoke to get the current version for each file (typically from \r
-# the version control system). Doxygen will invoke the program by executing (via \r
-# popen()) the command <command> <input-file>, where <command> is the value of \r
-# the FILE_VERSION_FILTER tag, and <input-file> is the name of an input file \r
-# provided by doxygen. Whatever the program writes to standard output \r
-# is used as the file version. See the manual for examples.\r
-\r
-FILE_VERSION_FILTER    = \r
-\r
-# The LAYOUT_FILE tag can be used to specify a layout file which will be parsed by \r
-# doxygen. The layout file controls the global structure of the generated output files \r
-# in an output format independent way. The create the layout file that represents \r
-# doxygen's defaults, run doxygen with the -l option. You can optionally specify a \r
-# file name after the option, if omitted DoxygenLayout.xml will be used as the name \r
-# of the layout file.\r
-\r
-LAYOUT_FILE            = \r
-\r
-#---------------------------------------------------------------------------\r
-# configuration options related to warning and progress messages\r
-#---------------------------------------------------------------------------\r
-\r
-# The QUIET tag can be used to turn on/off the messages that are generated \r
-# by doxygen. Possible values are YES and NO. If left blank NO is used.\r
-\r
-QUIET                  = YES\r
-\r
-# The WARNINGS tag can be used to turn on/off the warning messages that are \r
-# generated by doxygen. Possible values are YES and NO. If left blank \r
-# NO is used.\r
-\r
-WARNINGS               = YES\r
-\r
-# If WARN_IF_UNDOCUMENTED is set to YES, then doxygen will generate warnings \r
-# for undocumented members. If EXTRACT_ALL is set to YES then this flag will \r
-# automatically be disabled.\r
-\r
-WARN_IF_UNDOCUMENTED   = YES\r
-\r
-# If WARN_IF_DOC_ERROR is set to YES, doxygen will generate warnings for \r
-# potential errors in the documentation, such as not documenting some \r
-# parameters in a documented function, or documenting parameters that \r
-# don't exist or using markup commands wrongly.\r
-\r
-WARN_IF_DOC_ERROR      = YES\r
-\r
-# This WARN_NO_PARAMDOC option can be abled to get warnings for \r
-# functions that are documented, but have no documentation for their parameters \r
-# or return value. If set to NO (the default) doxygen will only warn about \r
-# wrong or incomplete parameter documentation, but not about the absence of \r
-# documentation.\r
-\r
-WARN_NO_PARAMDOC       = YES\r
-\r
-# The WARN_FORMAT tag determines the format of the warning messages that \r
-# doxygen can produce. The string should contain the $file, $line, and $text \r
-# tags, which will be replaced by the file and line number from which the \r
-# warning originated and the warning text. Optionally the format may contain \r
-# $version, which will be replaced by the version of the file (if it could \r
-# be obtained via FILE_VERSION_FILTER)\r
-\r
-WARN_FORMAT            = "$file:$line: $text"\r
-\r
-# The WARN_LOGFILE tag can be used to specify a file to which warning \r
-# and error messages should be written. If left blank the output is written \r
-# to stderr.\r
-\r
-WARN_LOGFILE           = \r
-\r
-#---------------------------------------------------------------------------\r
-# configuration options related to the input files\r
-#---------------------------------------------------------------------------\r
-\r
-# The INPUT tag can be used to specify the files and/or directories that contain \r
-# documented source files. You may enter file names like "myfile.cpp" or \r
-# directories like "/usr/src/myproject". Separate the files or directories \r
-# with spaces.\r
-\r
-INPUT                  = ./\r
-\r
-# This tag can be used to specify the character encoding of the source files \r
-# that doxygen parses. Internally doxygen uses the UTF-8 encoding, which is \r
-# also the default input encoding. Doxygen uses libiconv (or the iconv built \r
-# into libc) for the transcoding. See http://www.gnu.org/software/libiconv for \r
-# the list of possible encodings.\r
-\r
-INPUT_ENCODING         = UTF-8\r
-\r
-# If the value of the INPUT tag contains directories, you can use the \r
-# FILE_PATTERNS tag to specify one or more wildcard pattern (like *.cpp \r
-# and *.h) to filter out the source-files in the directories. If left \r
-# blank the following patterns are tested: \r
-# *.c *.cc *.cxx *.cpp *.c++ *.java *.ii *.ixx *.ipp *.i++ *.inl *.h *.hh *.hxx \r
-# *.hpp *.h++ *.idl *.odl *.cs *.php *.php3 *.inc *.m *.mm *.py *.f90\r
-\r
-FILE_PATTERNS          = *.h \\r
-                         *.c \\r
-                                                *.txt\r
-\r
-# The RECURSIVE tag can be used to turn specify whether or not subdirectories \r
-# should be searched for input files as well. Possible values are YES and NO. \r
-# If left blank NO is used.\r
-\r
-RECURSIVE              = YES\r
-\r
-# The EXCLUDE tag can be used to specify files and/or directories that should \r
-# excluded from the INPUT source files. This way you can easily exclude a \r
-# subdirectory from a directory tree whose root is specified with the INPUT tag.\r
-\r
-EXCLUDE                = \r
-\r
-# The EXCLUDE_SYMLINKS tag can be used select whether or not files or \r
-# directories that are symbolic links (a Unix filesystem feature) are excluded \r
-# from the input.\r
-\r
-EXCLUDE_SYMLINKS       = NO\r
-\r
-# If the value of the INPUT tag contains directories, you can use the \r
-# EXCLUDE_PATTERNS tag to specify one or more wildcard patterns to exclude \r
-# certain files from those directories. Note that the wildcards are matched \r
-# against the file with absolute path, so to exclude all test directories \r
-# for example use the pattern */test/*\r
-\r
-EXCLUDE_PATTERNS       = */LowLevel/USBMode.h\r
-\r
-# The EXCLUDE_SYMBOLS tag can be used to specify one or more symbol names \r
-# (namespaces, classes, functions, etc.) that should be excluded from the \r
-# output. The symbol name can be a fully qualified name, a word, or if the \r
-# wildcard * is used, a substring. Examples: ANamespace, AClass, \r
-# AClass::ANamespace, ANamespace::*Test\r
-\r
-EXCLUDE_SYMBOLS        = __*\r
-\r
-# The EXAMPLE_PATH tag can be used to specify one or more files or \r
-# directories that contain example code fragments that are included (see \r
-# the \include command).\r
-\r
-EXAMPLE_PATH           = \r
-\r
-# If the value of the EXAMPLE_PATH tag contains directories, you can use the \r
-# EXAMPLE_PATTERNS tag to specify one or more wildcard pattern (like *.cpp \r
-# and *.h) to filter out the source-files in the directories. If left \r
-# blank all files are included.\r
-\r
-EXAMPLE_PATTERNS       = *\r
-\r
-# If the EXAMPLE_RECURSIVE tag is set to YES then subdirectories will be \r
-# searched for input files to be used with the \include or \dontinclude \r
-# commands irrespective of the value of the RECURSIVE tag. \r
-# Possible values are YES and NO. If left blank NO is used.\r
-\r
-EXAMPLE_RECURSIVE      = NO\r
-\r
-# The IMAGE_PATH tag can be used to specify one or more files or \r
-# directories that contain image that are included in the documentation (see \r
-# the \image command).\r
-\r
-IMAGE_PATH             = \r
-\r
-# The INPUT_FILTER tag can be used to specify a program that doxygen should \r
-# invoke to filter for each input file. Doxygen will invoke the filter program \r
-# by executing (via popen()) the command <filter> <input-file>, where <filter> \r
-# is the value of the INPUT_FILTER tag, and <input-file> is the name of an \r
-# input file. Doxygen will then use the output that the filter program writes \r
-# to standard output.  If FILTER_PATTERNS is specified, this tag will be \r
-# ignored.\r
-\r
-INPUT_FILTER           = \r
-\r
-# The FILTER_PATTERNS tag can be used to specify filters on a per file pattern \r
-# basis.  Doxygen will compare the file name with each pattern and apply the \r
-# filter if there is a match.  The filters are a list of the form: \r
-# pattern=filter (like *.cpp=my_cpp_filter). See INPUT_FILTER for further \r
-# info on how filters are used. If FILTER_PATTERNS is empty, INPUT_FILTER \r
-# is applied to all files.\r
-\r
-FILTER_PATTERNS        = \r
-\r
-# If the FILTER_SOURCE_FILES tag is set to YES, the input filter (if set using \r
-# INPUT_FILTER) will be used to filter the input files when producing source \r
-# files to browse (i.e. when SOURCE_BROWSER is set to YES).\r
-\r
-FILTER_SOURCE_FILES    = NO\r
-\r
-#---------------------------------------------------------------------------\r
-# configuration options related to source browsing\r
-#---------------------------------------------------------------------------\r
-\r
-# If the SOURCE_BROWSER tag is set to YES then a list of source files will \r
-# be generated. Documented entities will be cross-referenced with these sources. \r
-# Note: To get rid of all source code in the generated output, make sure also \r
-# VERBATIM_HEADERS is set to NO.\r
-\r
-SOURCE_BROWSER         = NO\r
-\r
-# Setting the INLINE_SOURCES tag to YES will include the body \r
-# of functions and classes directly in the documentation.\r
-\r
-INLINE_SOURCES         = NO\r
-\r
-# Setting the STRIP_CODE_COMMENTS tag to YES (the default) will instruct \r
-# doxygen to hide any special comment blocks from generated source code \r
-# fragments. Normal C and C++ comments will always remain visible.\r
-\r
-STRIP_CODE_COMMENTS    = YES\r
-\r
-# If the REFERENCED_BY_RELATION tag is set to YES \r
-# then for each documented function all documented \r
-# functions referencing it will be listed.\r
-\r
-REFERENCED_BY_RELATION = NO\r
-\r
-# If the REFERENCES_RELATION tag is set to YES \r
-# then for each documented function all documented entities \r
-# called/used by that function will be listed.\r
-\r
-REFERENCES_RELATION    = NO\r
-\r
-# If the REFERENCES_LINK_SOURCE tag is set to YES (the default)\r
-# and SOURCE_BROWSER tag is set to YES, then the hyperlinks from\r
-# functions in REFERENCES_RELATION and REFERENCED_BY_RELATION lists will\r
-# link to the source code.  Otherwise they will link to the documentstion.\r
-\r
-REFERENCES_LINK_SOURCE = NO\r
-\r
-# If the USE_HTAGS tag is set to YES then the references to source code \r
-# will point to the HTML generated by the htags(1) tool instead of doxygen \r
-# built-in source browser. The htags tool is part of GNU's global source \r
-# tagging system (see http://www.gnu.org/software/global/global.html). You \r
-# will need version 4.8.6 or higher.\r
-\r
-USE_HTAGS              = NO\r
-\r
-# If the VERBATIM_HEADERS tag is set to YES (the default) then Doxygen \r
-# will generate a verbatim copy of the header file for each class for \r
-# which an include is specified. Set to NO to disable this.\r
-\r
-VERBATIM_HEADERS       = NO\r
-\r
-#---------------------------------------------------------------------------\r
-# configuration options related to the alphabetical class index\r
-#---------------------------------------------------------------------------\r
-\r
-# If the ALPHABETICAL_INDEX tag is set to YES, an alphabetical index \r
-# of all compounds will be generated. Enable this if the project \r
-# contains a lot of classes, structs, unions or interfaces.\r
-\r
-ALPHABETICAL_INDEX     = YES\r
-\r
-# If the alphabetical index is enabled (see ALPHABETICAL_INDEX) then \r
-# the COLS_IN_ALPHA_INDEX tag can be used to specify the number of columns \r
-# in which this list will be split (can be a number in the range [1..20])\r
-\r
-COLS_IN_ALPHA_INDEX    = 5\r
-\r
-# In case all classes in a project start with a common prefix, all \r
-# classes will be put under the same header in the alphabetical index. \r
-# The IGNORE_PREFIX tag can be used to specify one or more prefixes that \r
-# should be ignored while generating the index headers.\r
-\r
-IGNORE_PREFIX          = \r
-\r
-#---------------------------------------------------------------------------\r
-# configuration options related to the HTML output\r
-#---------------------------------------------------------------------------\r
-\r
-# If the GENERATE_HTML tag is set to YES (the default) Doxygen will \r
-# generate HTML output.\r
-\r
-GENERATE_HTML          = YES\r
-\r
-# The HTML_OUTPUT tag is used to specify where the HTML docs will be put. \r
-# If a relative path is entered the value of OUTPUT_DIRECTORY will be \r
-# put in front of it. If left blank `html' will be used as the default path.\r
-\r
-HTML_OUTPUT            = html\r
-\r
-# The HTML_FILE_EXTENSION tag can be used to specify the file extension for \r
-# each generated HTML page (for example: .htm,.php,.asp). If it is left blank \r
-# doxygen will generate files with .html extension.\r
-\r
-HTML_FILE_EXTENSION    = .html\r
-\r
-# The HTML_HEADER tag can be used to specify a personal HTML header for \r
-# each generated HTML page. If it is left blank doxygen will generate a \r
-# standard header.\r
-\r
-HTML_HEADER            = \r
-\r
-# The HTML_FOOTER tag can be used to specify a personal HTML footer for \r
-# each generated HTML page. If it is left blank doxygen will generate a \r
-# standard footer.\r
-\r
-HTML_FOOTER            = \r
-\r
-# The HTML_STYLESHEET tag can be used to specify a user-defined cascading \r
-# style sheet that is used by each HTML page. It can be used to \r
-# fine-tune the look of the HTML output. If the tag is left blank doxygen \r
-# will generate a default style sheet. Note that doxygen will try to copy \r
-# the style sheet file to the HTML output directory, so don't put your own \r
-# stylesheet in the HTML output directory as well, or it will be erased!\r
-\r
-HTML_STYLESHEET        = \r
-\r
-# If the HTML_ALIGN_MEMBERS tag is set to YES, the members of classes, \r
-# files or namespaces will be aligned in HTML using tables. If set to \r
-# NO a bullet list will be used.\r
-\r
-HTML_ALIGN_MEMBERS     = YES\r
-\r
-# If the HTML_DYNAMIC_SECTIONS tag is set to YES then the generated HTML \r
-# documentation will contain sections that can be hidden and shown after the \r
-# page has loaded. For this to work a browser that supports \r
-# JavaScript and DHTML is required (for instance Mozilla 1.0+, Firefox \r
-# Netscape 6.0+, Internet explorer 5.0+, Konqueror, or Safari).\r
-\r
-HTML_DYNAMIC_SECTIONS  = YES\r
-\r
-# If the GENERATE_DOCSET tag is set to YES, additional index files \r
-# will be generated that can be used as input for Apple's Xcode 3 \r
-# integrated development environment, introduced with OSX 10.5 (Leopard). \r
-# To create a documentation set, doxygen will generate a Makefile in the \r
-# HTML output directory. Running make will produce the docset in that \r
-# directory and running "make install" will install the docset in \r
-# ~/Library/Developer/Shared/Documentation/DocSets so that Xcode will find \r
-# it at startup. \r
-# See http://developer.apple.com/tools/creatingdocsetswithdoxygen.html for more information.\r
-\r
-GENERATE_DOCSET        = NO\r
-\r
-# When GENERATE_DOCSET tag is set to YES, this tag determines the name of the \r
-# feed. A documentation feed provides an umbrella under which multiple \r
-# documentation sets from a single provider (such as a company or product suite) \r
-# can be grouped.\r
-\r
-DOCSET_FEEDNAME        = "Doxygen generated docs"\r
-\r
-# When GENERATE_DOCSET tag is set to YES, this tag specifies a string that \r
-# should uniquely identify the documentation set bundle. This should be a \r
-# reverse domain-name style string, e.g. com.mycompany.MyDocSet. Doxygen \r
-# will append .docset to the name.\r
-\r
-DOCSET_BUNDLE_ID       = org.doxygen.Project\r
-\r
-# If the GENERATE_HTMLHELP tag is set to YES, additional index files \r
-# will be generated that can be used as input for tools like the \r
-# Microsoft HTML help workshop to generate a compiled HTML help file (.chm) \r
-# of the generated HTML documentation.\r
-\r
-GENERATE_HTMLHELP      = NO\r
-\r
-# If the GENERATE_HTMLHELP tag is set to YES, the CHM_FILE tag can \r
-# be used to specify the file name of the resulting .chm file. You \r
-# can add a path in front of the file if the result should not be \r
-# written to the html output directory.\r
-\r
-CHM_FILE               = \r
-\r
-# If the GENERATE_HTMLHELP tag is set to YES, the HHC_LOCATION tag can \r
-# be used to specify the location (absolute path including file name) of \r
-# the HTML help compiler (hhc.exe). If non-empty doxygen will try to run \r
-# the HTML help compiler on the generated index.hhp.\r
-\r
-HHC_LOCATION           = \r
-\r
-# If the GENERATE_HTMLHELP tag is set to YES, the GENERATE_CHI flag \r
-# controls if a separate .chi index file is generated (YES) or that \r
-# it should be included in the master .chm file (NO).\r
-\r
-GENERATE_CHI           = NO\r
-\r
-# If the GENERATE_HTMLHELP tag is set to YES, the CHM_INDEX_ENCODING\r
-# is used to encode HtmlHelp index (hhk), content (hhc) and project file\r
-# content.\r
-\r
-CHM_INDEX_ENCODING     = \r
-\r
-# If the GENERATE_HTMLHELP tag is set to YES, the BINARY_TOC flag \r
-# controls whether a binary table of contents is generated (YES) or a \r
-# normal table of contents (NO) in the .chm file.\r
-\r
-BINARY_TOC             = NO\r
-\r
-# The TOC_EXPAND flag can be set to YES to add extra items for group members \r
-# to the contents of the HTML help documentation and to the tree view.\r
-\r
-TOC_EXPAND             = YES\r
-\r
-# If the GENERATE_QHP tag is set to YES and both QHP_NAMESPACE and QHP_VIRTUAL_FOLDER \r
-# are set, an additional index file will be generated that can be used as input for \r
-# Qt's qhelpgenerator to generate a Qt Compressed Help (.qch) of the generated \r
-# HTML documentation.\r
-\r
-GENERATE_QHP           = NO\r
-\r
-# If the QHG_LOCATION tag is specified, the QCH_FILE tag can \r
-# be used to specify the file name of the resulting .qch file. \r
-# The path specified is relative to the HTML output folder.\r
-\r
-QCH_FILE               = \r
-\r
-# The QHP_NAMESPACE tag specifies the namespace to use when generating \r
-# Qt Help Project output. For more information please see \r
-# <a href="http://doc.trolltech.com/qthelpproject.html#namespace">Qt Help Project / Namespace</a>.\r
-\r
-QHP_NAMESPACE          = org.doxygen.Project\r
-\r
-# The QHP_VIRTUAL_FOLDER tag specifies the namespace to use when generating \r
-# Qt Help Project output. For more information please see \r
-# <a href="http://doc.trolltech.com/qthelpproject.html#virtual-folders">Qt Help Project / Virtual Folders</a>.\r
-\r
-QHP_VIRTUAL_FOLDER     = doc\r
-\r
-# If the GENERATE_QHP tag is set to YES, the QHG_LOCATION tag can \r
-# be used to specify the location of Qt's qhelpgenerator. \r
-# If non-empty doxygen will try to run qhelpgenerator on the generated \r
-# .qhp file .\r
-\r
-QHG_LOCATION           = \r
-\r
-# The DISABLE_INDEX tag can be used to turn on/off the condensed index at \r
-# top of each HTML page. The value NO (the default) enables the index and \r
-# the value YES disables it.\r
-\r
-DISABLE_INDEX          = NO\r
-\r
-# This tag can be used to set the number of enum values (range [1..20]) \r
-# that doxygen will group on one line in the generated HTML documentation.\r
-\r
-ENUM_VALUES_PER_LINE   = 1\r
-\r
-# The GENERATE_TREEVIEW tag is used to specify whether a tree-like index\r
-# structure should be generated to display hierarchical information.\r
-# If the tag value is set to FRAME, a side panel will be generated\r
-# containing a tree-like index structure (just like the one that \r
-# is generated for HTML Help). For this to work a browser that supports \r
-# JavaScript, DHTML, CSS and frames is required (for instance Mozilla 1.0+, \r
-# Netscape 6.0+, Internet explorer 5.0+, or Konqueror). Windows users are \r
-# probably better off using the HTML help feature. Other possible values \r
-# for this tag are: HIERARCHIES, which will generate the Groups, Directories,\r
-# and Class Hierarchy pages using a tree view instead of an ordered list;\r
-# ALL, which combines the behavior of FRAME and HIERARCHIES; and NONE, which\r
-# disables this behavior completely. For backwards compatibility with previous\r
-# releases of Doxygen, the values YES and NO are equivalent to FRAME and NONE\r
-# respectively.\r
-\r
-GENERATE_TREEVIEW      = YES\r
-\r
-# If the treeview is enabled (see GENERATE_TREEVIEW) then this tag can be \r
-# used to set the initial width (in pixels) of the frame in which the tree \r
-# is shown.\r
-\r
-TREEVIEW_WIDTH         = 250\r
-\r
-# Use this tag to change the font size of Latex formulas included \r
-# as images in the HTML documentation. The default is 10. Note that \r
-# when you change the font size after a successful doxygen run you need \r
-# to manually remove any form_*.png images from the HTML output directory \r
-# to force them to be regenerated.\r
-\r
-FORMULA_FONTSIZE       = 10\r
-\r
-#---------------------------------------------------------------------------\r
-# configuration options related to the LaTeX output\r
-#---------------------------------------------------------------------------\r
-\r
-# If the GENERATE_LATEX tag is set to YES (the default) Doxygen will \r
-# generate Latex output.\r
-\r
-GENERATE_LATEX         = NO\r
-\r
-# The LATEX_OUTPUT tag is used to specify where the LaTeX docs will be put. \r
-# If a relative path is entered the value of OUTPUT_DIRECTORY will be \r
-# put in front of it. If left blank `latex' will be used as the default path.\r
-\r
-LATEX_OUTPUT           = latex\r
-\r
-# The LATEX_CMD_NAME tag can be used to specify the LaTeX command name to be \r
-# invoked. If left blank `latex' will be used as the default command name.\r
-\r
-LATEX_CMD_NAME         = latex\r
-\r
-# The MAKEINDEX_CMD_NAME tag can be used to specify the command name to \r
-# generate index for LaTeX. If left blank `makeindex' will be used as the \r
-# default command name.\r
-\r
-MAKEINDEX_CMD_NAME     = makeindex\r
-\r
-# If the COMPACT_LATEX tag is set to YES Doxygen generates more compact \r
-# LaTeX documents. This may be useful for small projects and may help to \r
-# save some trees in general.\r
-\r
-COMPACT_LATEX          = NO\r
-\r
-# The PAPER_TYPE tag can be used to set the paper type that is used \r
-# by the printer. Possible values are: a4, a4wide, letter, legal and \r
-# executive. If left blank a4wide will be used.\r
-\r
-PAPER_TYPE             = a4wide\r
-\r
-# The EXTRA_PACKAGES tag can be to specify one or more names of LaTeX \r
-# packages that should be included in the LaTeX output.\r
-\r
-EXTRA_PACKAGES         = \r
-\r
-# The LATEX_HEADER tag can be used to specify a personal LaTeX header for \r
-# the generated latex document. The header should contain everything until \r
-# the first chapter. If it is left blank doxygen will generate a \r
-# standard header. Notice: only use this tag if you know what you are doing!\r
-\r
-LATEX_HEADER           = \r
-\r
-# If the PDF_HYPERLINKS tag is set to YES, the LaTeX that is generated \r
-# is prepared for conversion to pdf (using ps2pdf). The pdf file will \r
-# contain links (just like the HTML output) instead of page references \r
-# This makes the output suitable for online browsing using a pdf viewer.\r
-\r
-PDF_HYPERLINKS         = YES\r
-\r
-# If the USE_PDFLATEX tag is set to YES, pdflatex will be used instead of \r
-# plain latex in the generated Makefile. Set this option to YES to get a \r
-# higher quality PDF documentation.\r
-\r
-USE_PDFLATEX           = YES\r
-\r
-# If the LATEX_BATCHMODE tag is set to YES, doxygen will add the \\batchmode. \r
-# command to the generated LaTeX files. This will instruct LaTeX to keep \r
-# running if errors occur, instead of asking the user for help. \r
-# This option is also used when generating formulas in HTML.\r
-\r
-LATEX_BATCHMODE        = NO\r
-\r
-# If LATEX_HIDE_INDICES is set to YES then doxygen will not \r
-# include the index chapters (such as File Index, Compound Index, etc.) \r
-# in the output.\r
-\r
-LATEX_HIDE_INDICES     = NO\r
-\r
-#---------------------------------------------------------------------------\r
-# configuration options related to the RTF output\r
-#---------------------------------------------------------------------------\r
-\r
-# If the GENERATE_RTF tag is set to YES Doxygen will generate RTF output \r
-# The RTF output is optimized for Word 97 and may not look very pretty with \r
-# other RTF readers or editors.\r
-\r
-GENERATE_RTF           = NO\r
-\r
-# The RTF_OUTPUT tag is used to specify where the RTF docs will be put. \r
-# If a relative path is entered the value of OUTPUT_DIRECTORY will be \r
-# put in front of it. If left blank `rtf' will be used as the default path.\r
-\r
-RTF_OUTPUT             = rtf\r
-\r
-# If the COMPACT_RTF tag is set to YES Doxygen generates more compact \r
-# RTF documents. This may be useful for small projects and may help to \r
-# save some trees in general.\r
-\r
-COMPACT_RTF            = NO\r
-\r
-# If the RTF_HYPERLINKS tag is set to YES, the RTF that is generated \r
-# will contain hyperlink fields. The RTF file will \r
-# contain links (just like the HTML output) instead of page references. \r
-# This makes the output suitable for online browsing using WORD or other \r
-# programs which support those fields. \r
-# Note: wordpad (write) and others do not support links.\r
-\r
-RTF_HYPERLINKS         = NO\r
-\r
-# Load stylesheet definitions from file. Syntax is similar to doxygen's \r
-# config file, i.e. a series of assignments. You only have to provide \r
-# replacements, missing definitions are set to their default value.\r
-\r
-RTF_STYLESHEET_FILE    = \r
-\r
-# Set optional variables used in the generation of an rtf document. \r
-# Syntax is similar to doxygen's config file.\r
-\r
-RTF_EXTENSIONS_FILE    = \r
-\r
-#---------------------------------------------------------------------------\r
-# configuration options related to the man page output\r
-#---------------------------------------------------------------------------\r
-\r
-# If the GENERATE_MAN tag is set to YES (the default) Doxygen will \r
-# generate man pages\r
-\r
-GENERATE_MAN           = NO\r
-\r
-# The MAN_OUTPUT tag is used to specify where the man pages will be put. \r
-# If a relative path is entered the value of OUTPUT_DIRECTORY will be \r
-# put in front of it. If left blank `man' will be used as the default path.\r
-\r
-MAN_OUTPUT             = man\r
-\r
-# The MAN_EXTENSION tag determines the extension that is added to \r
-# the generated man pages (default is the subroutine's section .3)\r
-\r
-MAN_EXTENSION          = .3\r
-\r
-# If the MAN_LINKS tag is set to YES and Doxygen generates man output, \r
-# then it will generate one additional man file for each entity \r
-# documented in the real man page(s). These additional files \r
-# only source the real man page, but without them the man command \r
-# would be unable to find the correct page. The default is NO.\r
-\r
-MAN_LINKS              = NO\r
-\r
-#---------------------------------------------------------------------------\r
-# configuration options related to the XML output\r
-#---------------------------------------------------------------------------\r
-\r
-# If the GENERATE_XML tag is set to YES Doxygen will \r
-# generate an XML file that captures the structure of \r
-# the code including all documentation.\r
-\r
-GENERATE_XML           = NO\r
-\r
-# The XML_OUTPUT tag is used to specify where the XML pages will be put. \r
-# If a relative path is entered the value of OUTPUT_DIRECTORY will be \r
-# put in front of it. If left blank `xml' will be used as the default path.\r
-\r
-XML_OUTPUT             = xml\r
-\r
-# The XML_SCHEMA tag can be used to specify an XML schema, \r
-# which can be used by a validating XML parser to check the \r
-# syntax of the XML files.\r
-\r
-XML_SCHEMA             = \r
-\r
-# The XML_DTD tag can be used to specify an XML DTD, \r
-# which can be used by a validating XML parser to check the \r
-# syntax of the XML files.\r
-\r
-XML_DTD                = \r
-\r
-# If the XML_PROGRAMLISTING tag is set to YES Doxygen will \r
-# dump the program listings (including syntax highlighting \r
-# and cross-referencing information) to the XML output. Note that \r
-# enabling this will significantly increase the size of the XML output.\r
-\r
-XML_PROGRAMLISTING     = YES\r
-\r
-#---------------------------------------------------------------------------\r
-# configuration options for the AutoGen Definitions output\r
-#---------------------------------------------------------------------------\r
-\r
-# If the GENERATE_AUTOGEN_DEF tag is set to YES Doxygen will \r
-# generate an AutoGen Definitions (see autogen.sf.net) file \r
-# that captures the structure of the code including all \r
-# documentation. Note that this feature is still experimental \r
-# and incomplete at the moment.\r
-\r
-GENERATE_AUTOGEN_DEF   = NO\r
-\r
-#---------------------------------------------------------------------------\r
-# configuration options related to the Perl module output\r
-#---------------------------------------------------------------------------\r
-\r
-# If the GENERATE_PERLMOD tag is set to YES Doxygen will \r
-# generate a Perl module file that captures the structure of \r
-# the code including all documentation. Note that this \r
-# feature is still experimental and incomplete at the \r
-# moment.\r
-\r
-GENERATE_PERLMOD       = NO\r
-\r
-# If the PERLMOD_LATEX tag is set to YES Doxygen will generate \r
-# the necessary Makefile rules, Perl scripts and LaTeX code to be able \r
-# to generate PDF and DVI output from the Perl module output.\r
-\r
-PERLMOD_LATEX          = NO\r
-\r
-# If the PERLMOD_PRETTY tag is set to YES the Perl module output will be \r
-# nicely formatted so it can be parsed by a human reader.  This is useful \r
-# if you want to understand what is going on.  On the other hand, if this \r
-# tag is set to NO the size of the Perl module output will be much smaller \r
-# and Perl will parse it just the same.\r
-\r
-PERLMOD_PRETTY         = YES\r
-\r
-# The names of the make variables in the generated doxyrules.make file \r
-# are prefixed with the string contained in PERLMOD_MAKEVAR_PREFIX. \r
-# This is useful so different doxyrules.make files included by the same \r
-# Makefile don't overwrite each other's variables.\r
-\r
-PERLMOD_MAKEVAR_PREFIX = \r
-\r
-#---------------------------------------------------------------------------\r
-# Configuration options related to the preprocessor   \r
-#---------------------------------------------------------------------------\r
-\r
-# If the ENABLE_PREPROCESSING tag is set to YES (the default) Doxygen will \r
-# evaluate all C-preprocessor directives found in the sources and include \r
-# files.\r
-\r
-ENABLE_PREPROCESSING   = YES\r
-\r
-# If the MACRO_EXPANSION tag is set to YES Doxygen will expand all macro \r
-# names in the source code. If set to NO (the default) only conditional \r
-# compilation will be performed. Macro expansion can be done in a controlled \r
-# way by setting EXPAND_ONLY_PREDEF to YES.\r
-\r
-MACRO_EXPANSION        = YES\r
-\r
-# If the EXPAND_ONLY_PREDEF and MACRO_EXPANSION tags are both set to YES \r
-# then the macro expansion is limited to the macros specified with the \r
-# PREDEFINED and EXPAND_AS_DEFINED tags.\r
-\r
-EXPAND_ONLY_PREDEF     = YES\r
-\r
-# If the SEARCH_INCLUDES tag is set to YES (the default) the includes files \r
-# in the INCLUDE_PATH (see below) will be search if a #include is found.\r
-\r
-SEARCH_INCLUDES        = YES\r
-\r
-# The INCLUDE_PATH tag can be used to specify one or more directories that \r
-# contain include files that are not input files but should be processed by \r
-# the preprocessor.\r
-\r
-INCLUDE_PATH           = \r
-\r
-# You can use the INCLUDE_FILE_PATTERNS tag to specify one or more wildcard \r
-# patterns (like *.h and *.hpp) to filter out the header-files in the \r
-# directories. If left blank, the patterns specified with FILE_PATTERNS will \r
-# be used.\r
-\r
-INCLUDE_FILE_PATTERNS  = \r
-\r
-# The PREDEFINED tag can be used to specify one or more macro names that \r
-# are defined before the preprocessor is started (similar to the -D option of \r
-# gcc). The argument of the tag is a list of macros of the form: name \r
-# or name=definition (no spaces). If the definition and the = are \r
-# omitted =1 is assumed. To prevent a macro definition from being \r
-# undefined via #undef or recursively expanded use the := operator \r
-# instead of the = operator.\r
-\r
-PREDEFINED             = __DOXYGEN__\r
-\r
-# If the MACRO_EXPANSION and EXPAND_ONLY_PREDEF tags are set to YES then \r
-# this tag can be used to specify a list of macro names that should be expanded. \r
-# The macro definition that is found in the sources will be used. \r
-# Use the PREDEFINED tag if you want to use a different macro definition.\r
-\r
-EXPAND_AS_DEFINED      = BUTTLOADTAG\r
-\r
-# If the SKIP_FUNCTION_MACROS tag is set to YES (the default) then \r
-# doxygen's preprocessor will remove all function-like macros that are alone \r
-# on a line, have an all uppercase name, and do not end with a semicolon. Such \r
-# function macros are typically used for boiler-plate code, and will confuse \r
-# the parser if not removed.\r
-\r
-SKIP_FUNCTION_MACROS   = YES\r
-\r
-#---------------------------------------------------------------------------\r
-# Configuration::additions related to external references   \r
-#---------------------------------------------------------------------------\r
-\r
-# The TAGFILES option can be used to specify one or more tagfiles. \r
-# Optionally an initial location of the external documentation \r
-# can be added for each tagfile. The format of a tag file without \r
-# this location is as follows: \r
-#   TAGFILES = file1 file2 ... \r
-# Adding location for the tag files is done as follows: \r
-#   TAGFILES = file1=loc1 "file2 = loc2" ... \r
-# where "loc1" and "loc2" can be relative or absolute paths or \r
-# URLs. If a location is present for each tag, the installdox tool \r
-# does not have to be run to correct the links.\r
-# Note that each tag file must have a unique name\r
-# (where the name does NOT include the path)\r
-# If a tag file is not located in the directory in which doxygen \r
-# is run, you must also specify the path to the tagfile here.\r
-\r
-TAGFILES               = \r
-\r
-# When a file name is specified after GENERATE_TAGFILE, doxygen will create \r
-# a tag file that is based on the input files it reads.\r
-\r
-GENERATE_TAGFILE       = \r
-\r
-# If the ALLEXTERNALS tag is set to YES all external classes will be listed \r
-# in the class index. If set to NO only the inherited external classes \r
-# will be listed.\r
-\r
-ALLEXTERNALS           = NO\r
-\r
-# If the EXTERNAL_GROUPS tag is set to YES all external groups will be listed \r
-# in the modules index. If set to NO, only the current project's groups will \r
-# be listed.\r
-\r
-EXTERNAL_GROUPS        = YES\r
-\r
-# The PERL_PATH should be the absolute path and name of the perl script \r
-# interpreter (i.e. the result of `which perl').\r
-\r
-PERL_PATH              = /usr/bin/perl\r
-\r
-#---------------------------------------------------------------------------\r
-# Configuration options related to the dot tool   \r
-#---------------------------------------------------------------------------\r
-\r
-# If the CLASS_DIAGRAMS tag is set to YES (the default) Doxygen will \r
-# generate a inheritance diagram (in HTML, RTF and LaTeX) for classes with base \r
-# or super classes. Setting the tag to NO turns the diagrams off. Note that \r
-# this option is superseded by the HAVE_DOT option below. This is only a \r
-# fallback. It is recommended to install and use dot, since it yields more \r
-# powerful graphs.\r
-\r
-CLASS_DIAGRAMS         = NO\r
-\r
-# You can define message sequence charts within doxygen comments using the \msc \r
-# command. Doxygen will then run the mscgen tool (see \r
-# http://www.mcternan.me.uk/mscgen/) to produce the chart and insert it in the \r
-# documentation. The MSCGEN_PATH tag allows you to specify the directory where \r
-# the mscgen tool resides. If left empty the tool is assumed to be found in the \r
-# default search path.\r
-\r
-MSCGEN_PATH            = \r
-\r
-# If set to YES, the inheritance and collaboration graphs will hide \r
-# inheritance and usage relations if the target is undocumented \r
-# or is not a class.\r
-\r
-HIDE_UNDOC_RELATIONS   = YES\r
-\r
-# If you set the HAVE_DOT tag to YES then doxygen will assume the dot tool is \r
-# available from the path. This tool is part of Graphviz, a graph visualization \r
-# toolkit from AT&T and Lucent Bell Labs. The other options in this section \r
-# have no effect if this option is set to NO (the default)\r
-\r
-HAVE_DOT               = NO\r
-\r
-# By default doxygen will write a font called FreeSans.ttf to the output \r
-# directory and reference it in all dot files that doxygen generates. This \r
-# font does not include all possible unicode characters however, so when you need \r
-# these (or just want a differently looking font) you can specify the font name \r
-# using DOT_FONTNAME. You need need to make sure dot is able to find the font, \r
-# which can be done by putting it in a standard location or by setting the \r
-# DOTFONTPATH environment variable or by setting DOT_FONTPATH to the directory \r
-# containing the font.\r
-\r
-DOT_FONTNAME           = FreeSans\r
-\r
-# The DOT_FONTSIZE tag can be used to set the size of the font of dot graphs. \r
-# The default size is 10pt.\r
-\r
-DOT_FONTSIZE           = 10\r
-\r
-# By default doxygen will tell dot to use the output directory to look for the \r
-# FreeSans.ttf font (which doxygen will put there itself). If you specify a \r
-# different font using DOT_FONTNAME you can set the path where dot \r
-# can find it using this tag.\r
-\r
-DOT_FONTPATH           = \r
-\r
-# If the CLASS_GRAPH and HAVE_DOT tags are set to YES then doxygen \r
-# will generate a graph for each documented class showing the direct and \r
-# indirect inheritance relations. Setting this tag to YES will force the \r
-# the CLASS_DIAGRAMS tag to NO.\r
-\r
-CLASS_GRAPH            = NO\r
-\r
-# If the COLLABORATION_GRAPH and HAVE_DOT tags are set to YES then doxygen \r
-# will generate a graph for each documented class showing the direct and \r
-# indirect implementation dependencies (inheritance, containment, and \r
-# class references variables) of the class with other documented classes.\r
-\r
-COLLABORATION_GRAPH    = NO\r
-\r
-# If the GROUP_GRAPHS and HAVE_DOT tags are set to YES then doxygen \r
-# will generate a graph for groups, showing the direct groups dependencies\r
-\r
-GROUP_GRAPHS           = NO\r
-\r
-# If the UML_LOOK tag is set to YES doxygen will generate inheritance and \r
-# collaboration diagrams in a style similar to the OMG's Unified Modeling \r
-# Language.\r
-\r
-UML_LOOK               = NO\r
-\r
-# If set to YES, the inheritance and collaboration graphs will show the \r
-# relations between templates and their instances.\r
-\r
-TEMPLATE_RELATIONS     = NO\r
-\r
-# If the ENABLE_PREPROCESSING, SEARCH_INCLUDES, INCLUDE_GRAPH, and HAVE_DOT \r
-# tags are set to YES then doxygen will generate a graph for each documented \r
-# file showing the direct and indirect include dependencies of the file with \r
-# other documented files.\r
-\r
-INCLUDE_GRAPH          = NO\r
-\r
-# If the ENABLE_PREPROCESSING, SEARCH_INCLUDES, INCLUDED_BY_GRAPH, and \r
-# HAVE_DOT tags are set to YES then doxygen will generate a graph for each \r
-# documented header file showing the documented files that directly or \r
-# indirectly include this file.\r
-\r
-INCLUDED_BY_GRAPH      = NO\r
-\r
-# If the CALL_GRAPH and HAVE_DOT options are set to YES then \r
-# doxygen will generate a call dependency graph for every global function \r
-# or class method. Note that enabling this option will significantly increase \r
-# the time of a run. So in most cases it will be better to enable call graphs \r
-# for selected functions only using the \callgraph command.\r
-\r
-CALL_GRAPH             = NO\r
-\r
-# If the CALLER_GRAPH and HAVE_DOT tags are set to YES then \r
-# doxygen will generate a caller dependency graph for every global function \r
-# or class method. Note that enabling this option will significantly increase \r
-# the time of a run. So in most cases it will be better to enable caller \r
-# graphs for selected functions only using the \callergraph command.\r
-\r
-CALLER_GRAPH           = NO\r
-\r
-# If the GRAPHICAL_HIERARCHY and HAVE_DOT tags are set to YES then doxygen \r
-# will graphical hierarchy of all classes instead of a textual one.\r
-\r
-GRAPHICAL_HIERARCHY    = NO\r
-\r
-# If the DIRECTORY_GRAPH, SHOW_DIRECTORIES and HAVE_DOT tags are set to YES \r
-# then doxygen will show the dependencies a directory has on other directories \r
-# in a graphical way. The dependency relations are determined by the #include\r
-# relations between the files in the directories.\r
-\r
-DIRECTORY_GRAPH        = NO\r
-\r
-# The DOT_IMAGE_FORMAT tag can be used to set the image format of the images \r
-# generated by dot. Possible values are png, jpg, or gif\r
-# If left blank png will be used.\r
-\r
-DOT_IMAGE_FORMAT       = png\r
-\r
-# The tag DOT_PATH can be used to specify the path where the dot tool can be \r
-# found. If left blank, it is assumed the dot tool can be found in the path.\r
-\r
-DOT_PATH               = "C:/Program Files/Graphviz2.18/bin"\r
-\r
-# The DOTFILE_DIRS tag can be used to specify one or more directories that \r
-# contain dot files that are included in the documentation (see the \r
-# \dotfile command).\r
-\r
-DOTFILE_DIRS           = \r
-\r
-# The DOT_GRAPH_MAX_NODES tag can be used to set the maximum number of \r
-# nodes that will be shown in the graph. If the number of nodes in a graph \r
-# becomes larger than this value, doxygen will truncate the graph, which is \r
-# visualized by representing a node as a red box. Note that doxygen if the \r
-# number of direct children of the root node in a graph is already larger than \r
-# DOT_GRAPH_MAX_NODES then the graph will not be shown at all. Also note \r
-# that the size of a graph can be further restricted by MAX_DOT_GRAPH_DEPTH.\r
-\r
-DOT_GRAPH_MAX_NODES    = 15\r
-\r
-# The MAX_DOT_GRAPH_DEPTH tag can be used to set the maximum depth of the \r
-# graphs generated by dot. A depth value of 3 means that only nodes reachable \r
-# from the root by following a path via at most 3 edges will be shown. Nodes \r
-# that lay further from the root node will be omitted. Note that setting this \r
-# option to 1 or 2 may greatly reduce the computation time needed for large \r
-# code bases. Also note that the size of a graph can be further restricted by \r
-# DOT_GRAPH_MAX_NODES. Using a depth of 0 means no depth restriction.\r
-\r
-MAX_DOT_GRAPH_DEPTH    = 2\r
-\r
-# Set the DOT_TRANSPARENT tag to YES to generate images with a transparent \r
-# background. This is disabled by default, because dot on Windows does not \r
-# seem to support this out of the box. Warning: Depending on the platform used, \r
-# enabling this option may lead to badly anti-aliased labels on the edges of \r
-# a graph (i.e. they become hard to read).\r
-\r
-DOT_TRANSPARENT        = YES\r
-\r
-# Set the DOT_MULTI_TARGETS tag to YES allow dot to generate multiple output \r
-# files in one run (i.e. multiple -o and -T options on the command line). This \r
-# makes dot run faster, but since only newer versions of dot (>1.8.10) \r
-# support this, this feature is disabled by default.\r
-\r
-DOT_MULTI_TARGETS      = NO\r
-\r
-# If the GENERATE_LEGEND tag is set to YES (the default) Doxygen will \r
-# generate a legend page explaining the meaning of the various boxes and \r
-# arrows in the dot generated graphs.\r
-\r
-GENERATE_LEGEND        = YES\r
-\r
-# If the DOT_CLEANUP tag is set to YES (the default) Doxygen will \r
-# remove the intermediate dot files that are used to generate \r
-# the various graphs.\r
-\r
-DOT_CLEANUP            = YES\r
-\r
-#---------------------------------------------------------------------------\r
-# Configuration::additions related to the search engine   \r
-#---------------------------------------------------------------------------\r
-\r
-# The SEARCHENGINE tag specifies whether or not a search engine should be \r
-# used. If set to NO the values of all tags below this one will be ignored.\r
-\r
-SEARCHENGINE           = NO\r
diff --git a/Projects/AVRISP_Programmer/LUFA AVRISP_Programmer.inf b/Projects/AVRISP_Programmer/LUFA AVRISP_Programmer.inf
deleted file mode 100644 (file)
index bd9c8bf..0000000
+++ /dev/null
@@ -1,55 +0,0 @@
-;  Windows LUFA USB to Serial Setup File\r
-; Copyright (c) 2000 Microsoft Corporation\r
-\r
-[Version] \r
-Signature="$Windows NT$" \r
-Class=Ports\r
-ClassGuid={4D36E978-E325-11CE-BFC1-08002BE10318} \r
-Provider=%COMPANY% \r
-LayoutFile=layout.inf\r
-DriverVer=06/06/2006,1.0.0.0\r
-\r
-[Manufacturer] \r
-%MFGNAME% = ManufName\r
-\r
-[DestinationDirs] \r
-DefaultDestDir=12 \r
-\r
-[ManufName] \r
-%Modem3% = Modem3, USB\VID_03EB&PID_204B\r
-\r
-;------------------------------------------------------------------------------\r
-;  Windows 2000/XP Sections\r
-;------------------------------------------------------------------------------\r
-\r
-[Modem3.nt]\r
-CopyFiles=USBModemCopyFileSection\r
-AddReg=Modem3.nt.AddReg \r
-\r
-[USBModemCopyFileSection]\r
-usbser.sys,,,0x20\r
-\r
-[Modem3.nt.AddReg] \r
-HKR,,DevLoader,,*ntkern \r
-HKR,,NTMPDriver,,usbser.sys \r
-HKR,,EnumPropPages32,,"MsPorts.dll,SerialPortPropPageProvider" \r
-\r
-[Modem3.nt.Services] \r
-AddService=usbser, 0x00000002, DriverService\r
-\r
-[DriverService] \r
-DisplayName=%SERVICE%\r
-ServiceType=1\r
-StartType=3\r
-ErrorControl=1\r
-ServiceBinary=%12%\usbser.sys \r
-\r
-;------------------------------------------------------------------------------\r
-;  String Definitions\r
-;------------------------------------------------------------------------------\r
-\r
-[Strings] \r
-COMPANY="LUFA Library"\r
-MFGNAME="Dean Camera"\r
-Modem3="USB Virtual Serial Port" \r
-SERVICE="USB Virtual Serial Port CDC Driver"
\ No newline at end of file
diff --git a/Projects/AVRISP_Programmer/RingBuff.c b/Projects/AVRISP_Programmer/RingBuff.c
deleted file mode 100644 (file)
index 1f477f1..0000000
+++ /dev/null
@@ -1,120 +0,0 @@
-/*\r
-             LUFA Library\r
-     Copyright (C) Dean Camera, 2009.\r
-              \r
-  dean [at] fourwalledcubicle [dot] com\r
-      www.fourwalledcubicle.com\r
-*/\r
-\r
-/*\r
-  Copyright 2009  Dean Camera (dean [at] fourwalledcubicle [dot] com)\r
-\r
-  Permission to use, copy, modify, and distribute this software\r
-  and its documentation for any purpose and without fee is hereby\r
-  granted, provided that the above copyright notice appear in all\r
-  copies and that both that the copyright notice and this\r
-  permission notice and warranty disclaimer appear in supporting\r
-  documentation, and that the name of the author not be used in\r
-  advertising or publicity pertaining to distribution of the\r
-  software without specific, written prior permission.\r
-\r
-  The author disclaim all warranties with regard to this\r
-  software, including all implied warranties of merchantability\r
-  and fitness.  In no event shall the author be liable for any\r
-  special, indirect or consequential damages or any damages\r
-  whatsoever resulting from loss of use, data or profits, whether\r
-  in an action of contract, negligence or other tortious action,\r
-  arising out of or in connection with the use or performance of\r
-  this software.\r
-*/\r
-\r
-#include "RingBuff.h"\r
-\r
-void Buffer_Initialize(RingBuff_t* Buffer)\r
-{\r
-       BUFF_ATOMIC_BLOCK\r
-       {\r
-               Buffer->InPtr    = (RingBuff_Data_t*)&Buffer->Buffer;\r
-               Buffer->OutPtr   = (RingBuff_Data_t*)&Buffer->Buffer;\r
-               Buffer->Elements = 0;\r
-       }\r
-}\r
-\r
-void Buffer_StoreElement(RingBuff_t* Buffer, RingBuff_Data_t Data)\r
-{\r
-       BUFF_ATOMIC_BLOCK\r
-       {\r
-       #if defined(BUFF_DROPOLD)\r
-               if (Buffer->Elements == BUFF_LENGTH)\r
-               {\r
-                       Buffer->OutPtr++;\r
-       \r
-                       if (Buffer->OutPtr == &Buffer->Buffer[BUFF_LENGTH])\r
-                         Buffer->OutPtr = (RingBuff_Data_t*)&Buffer->Buffer;\r
-               }\r
-               else\r
-               {\r
-                       Buffer->Elements++;\r
-               }\r
-       #elif defined(BUFF_DROPNEW)\r
-               if (Buffer->Elements == BUFF_LENGTH)\r
-                 return;\r
-       \r
-                 Buffer->Elements++;\r
-       #elif defined(BUFF_NODROPCHECK)\r
-                 Buffer->Elements++;\r
-       #endif\r
-       \r
-               *(Buffer->InPtr) = Data;\r
-               Buffer->InPtr++;\r
-       \r
-               if (Buffer->InPtr == &Buffer->Buffer[BUFF_LENGTH])\r
-                 Buffer->InPtr = (RingBuff_Data_t*)&Buffer->Buffer;\r
-       }\r
-}\r
-\r
-RingBuff_Data_t Buffer_GetElement(RingBuff_t* Buffer)\r
-{\r
-       RingBuff_Data_t BuffData;\r
-       \r
-       BUFF_ATOMIC_BLOCK\r
-       {\r
-#if defined(BUFF_EMPTYRETURNSZERO)\r
-               if (!(Buffer->Elements))\r
-                 return 0;\r
-#elif !defined(BUFF_NOEMPTYCHECK)\r
-       #error No empty buffer check behaviour specified.\r
-#endif\r
-\r
-               BuffData = *(Buffer->OutPtr);\r
-       \r
-               Buffer->OutPtr++;\r
-               Buffer->Elements--;\r
-       \r
-               if (Buffer->OutPtr == &Buffer->Buffer[BUFF_LENGTH])\r
-                 Buffer->OutPtr = (RingBuff_Data_t*)&Buffer->Buffer;\r
-       }\r
-       \r
-       return BuffData;\r
-}\r
-\r
-#if defined(BUFF_USEPEEK)\r
-RingBuff_Data_t Buffer_PeekElement(const RingBuff_t* Buffer)\r
-{\r
-       RingBuff_Data_t BuffData;\r
-\r
-       BUFF_ATOMIC_BLOCK\r
-       {\r
-#if defined(BUFF_EMPTYRETURNSZERO)\r
-               if (!(Buffer->Elements))\r
-                 return 0;\r
-#elif !defined(BUFF_NOEMPTYCHECK)\r
-       #error No empty buffer check behaviour specified.\r
-#endif\r
-\r
-               BuffData = *(Buffer->OutPtr);\r
-       }\r
-\r
-       return BuffData;\r
-}\r
-#endif\r
diff --git a/Projects/AVRISP_Programmer/RingBuff.h b/Projects/AVRISP_Programmer/RingBuff.h
deleted file mode 100644 (file)
index 68e4a6e..0000000
+++ /dev/null
@@ -1,116 +0,0 @@
-/*\r
-             LUFA Library\r
-     Copyright (C) Dean Camera, 2009.\r
-              \r
-  dean [at] fourwalledcubicle [dot] com\r
-      www.fourwalledcubicle.com\r
-*/\r
-\r
-/*\r
-  Copyright 2009  Dean Camera (dean [at] fourwalledcubicle [dot] com)\r
-\r
-  Permission to use, copy, modify, and distribute this software\r
-  and its documentation for any purpose and without fee is hereby\r
-  granted, provided that the above copyright notice appear in all\r
-  copies and that both that the copyright notice and this\r
-  permission notice and warranty disclaimer appear in supporting\r
-  documentation, and that the name of the author not be used in\r
-  advertising or publicity pertaining to distribution of the\r
-  software without specific, written prior permission.\r
-\r
-  The author disclaim all warranties with regard to this\r
-  software, including all implied warranties of merchantability\r
-  and fitness.  In no event shall the author be liable for any\r
-  special, indirect or consequential damages or any damages\r
-  whatsoever resulting from loss of use, data or profits, whether\r
-  in an action of contract, negligence or other tortious action,\r
-  arising out of or in connection with the use or performance of\r
-  this software.\r
-*/\r
-\r
-/* Buffer Configuration: */\r
-   /* Buffer length - select static size of created ringbuffers: */\r
-        #define BUFF_STATICSIZE 128      // Set to the static ringbuffer size for all ringbuffers (place size after define)\r
-\r
-   /* Volatile mode - uncomment to make buffers volatile, for use in ISRs, etc: */\r
-        #define BUFF_VOLATILE            // Uncomment to cause all ring buffers to become volatile (and atomic if multi-byte) in access\r
-\r
-   /* Drop mode - select behaviour when Buffer_StoreElement called on a full buffer: */\r
-     #define BUFF_DROPOLD             // Uncomment to cause full ring buffers to drop the oldest character to make space when full\r
-     // #define BUFF_DROPNEW          // Uncomment to cause full ring buffers to drop the new character when full\r
-     // #define BUFF_NODROPCHECK      // Uncomment to ignore full ring buffer checks - checking left to user!\r
-\r
-   /* Underflow behaviour - select behaviour when Buffer_GetElement is called with an empty ringbuffer: */\r
-     //#define BUFF_EMPTYRETURNSZERO  // Uncomment to return 0 when an empty ringbuffer is read\r
-     #define BUFF_NOEMPTYCHECK        // Uncomment to disable checking of empty ringbuffers - checking left to user!\r
-       \r
-   /* Buffer storage type - set the datatype for the stored data */\r
-     #define BUFF_DATATYPE uint8_t    // Change to the data type that is going to be stored into the buffer\r
-       \r
-   /* Peek routine - uncomment to include the peek routine (fetches next byte without removing it from the buffer */\r
-     #define BUFF_USEPEEK\r
-               \r
-#ifndef _RINGBUFF_H_\r
-#define _RINGBUFF_H_\r
-\r
-       /* Includes: */\r
-       #include <avr/io.h>\r
-       #include <avr/interrupt.h>\r
-       #include <util/atomic.h>\r
-       #include <limits.h>\r
-\r
-       #include <LUFA/Common/Common.h>\r
-\r
-       /* Defines and checks: */\r
-       #if defined(BUFF_STATICSIZE)\r
-               #define BUFF_LENGTH BUFF_STATICSIZE\r
-       #else\r
-               #error No buffer length specified!\r
-       #endif\r
-\r
-       #if !(defined(BUFF_DROPOLD) || defined(BUFF_DROPNEW) || defined(BUFF_NODROPCHECK))\r
-               #error No buffer drop mode specified.\r
-       #endif\r
-\r
-       #if !defined(BUFF_DATATYPE)\r
-               #error Ringbuffer storage data type not specified.\r
-       #endif\r
-\r
-       #if defined(BUFF_VOLATILE)\r
-               #define BUFF_MODE            volatile\r
-               #define BUFF_ATOMIC_BLOCK    ATOMIC_BLOCK(ATOMIC_RESTORESTATE)\r
-       #else\r
-               #define BUFF_MODE\r
-               #define BUFF_ATOMIC_BLOCK\r
-       #endif\r
-\r
-       #if (BUFF_STATICSIZE   > LONG_MAX)\r
-               #define RingBuff_Elements_t uint64_t\r
-       #elif (BUFF_STATICSIZE > INT_MAX)\r
-               #define RingBuff_Elements_t uint32_t\r
-       #elif (BUFF_STATICSIZE > CHAR_MAX)\r
-               #define RingBuff_Elements_t uint16_t\r
-       #else\r
-               #define RingBuff_Elements_t uint8_t\r
-       #endif\r
-       \r
-       /* Type Defines: */\r
-       typedef BUFF_DATATYPE RingBuff_Data_t;\r
-\r
-       typedef BUFF_MODE struct\r
-       {\r
-               RingBuff_Data_t      Buffer[BUFF_LENGTH];\r
-               RingBuff_Data_t*     InPtr;\r
-               RingBuff_Data_t*     OutPtr;\r
-               RingBuff_Elements_t  Elements;\r
-       } RingBuff_t;\r
-               \r
-       /* Function Prototypes: */\r
-       void            Buffer_Initialize(RingBuff_t* Buff);\r
-       void            Buffer_StoreElement(RingBuff_t* Buffer, RingBuff_Data_t Data);\r
-       RingBuff_Data_t Buffer_GetElement(RingBuff_t* Buffer);\r
-       #if defined(BUFF_USEPEEK)\r
-               RingBuff_Data_t Buffer_PeekElement(const RingBuff_t* Buffer);\r
-       #endif\r
-       \r
-#endif\r
diff --git a/Projects/AVRISP_Programmer/Sample_Programming_Session.txt b/Projects/AVRISP_Programmer/Sample_Programming_Session.txt
deleted file mode 100644 (file)
index b5af76e..0000000
+++ /dev/null
@@ -1,104 +0,0 @@
-ubuntu@ubuntu:~/LUFA/Bootloaders/LUFA_DFU_Bootloader_AT90USB162$  sudo avrdude -vv -F -P /dev/ttyACM0 -c avr910 -p usb162 -U flash:w:BootloaderDFU.hex\r
-\r
-avrdude: Version 5.5, compiled on May  9 2008 at 13:04:46\r
-         Copyright (c) 2000-2005 Brian Dean, http://www.bdmicro.com/\r
-\r
-         System wide configuration file is "/etc/avrdude.conf"\r
-         User configuration file is "/home/ubuntu/.avrduderc"\r
-         User configuration file does not exist or is not a regular file, skipping\r
-\r
-         Using Port            : /dev/ttyACM0\r
-         Using Programmer      : avr910\r
-         AVR Part              : AT90USB162\r
-         Chip Erase delay      : 9000 us\r
-         PAGEL                 : PD7\r
-         BS2                   : PA0\r
-         RESET disposition     : dedicated\r
-         RETRY pulse           : SCK\r
-         serial program mode   : yes\r
-         parallel program mode : yes\r
-         Timeout               : 200\r
-         StabDelay             : 100\r
-         CmdexeDelay           : 25\r
-         SyncLoops             : 32\r
-         ByteDelay             : 0\r
-         PollIndex             : 3\r
-         PollValue             : 0x53\r
-         Memory Detail         :\r
-\r
-                                  Block Poll               Page                       Polled\r
-           Memory Type Mode Delay Size  Indx Paged  Size   Size #Pages MinW  MaxW   ReadBack\r
-           ----------- ---- ----- ----- ---- ------ ------ ---- ------ ----- ----- ---------\r
-           eeprom        65    10     8    0 no        512    4      0  9000  9000 0x00 0x00\r
-           flash         65     6   128    0 yes     16384  128    128  4500  4500 0x00 0x00\r
-           lfuse          0     0     0    0 no          1    0      0  9000  9000 0x00 0x00\r
-           hfuse          0     0     0    0 no          1    0      0  9000  9000 0x00 0x00\r
-           efuse          0     0     0    0 no          1    0      0  9000  9000 0x00 0x00\r
-           lock           0     0     0    0 no          1    0      0  9000  9000 0x00 0x00\r
-           calibration    0     0     0    0 no          1    0      0     0     0 0x00 0x00\r
-           signature      0     0     0    0 no          3    0      0     0     0 0x00 0x00\r
-\r
-         Programmer Type : avr910\r
-         Description     : Atmel Low Cost Serial Programmer\r
-\r
-Found programmer: Id = "AVR ISP"; type = S\r
-    Software Version = 2.3; Hardware Version = 1.0\r
-Programmer supports auto addr increment.\r
-\r
-Programmer supports the following devices:\r
-    Device code: 0x55 = ATtiny12\r
-    Device code: 0x56 = ATtiny15\r
-    Device code: 0x5e = ATtiny2313\r
-    Device code: 0x76 = ATMEGA8\r
-    Device code: 0x74 = ATMEGA6450\r
-    Device code: 0x72 = ATMEGA32\r
-    Device code: 0x45 = ATMEGA64\r
-    Device code: 0x74 = ATMEGA6450\r
-    Device code: 0x43 = ATMEGA128\r
-    Device code: 0x63 = ATMEGA162\r
-    Device code: 0x78 = ATMEGA169\r
-    Device code: 0x6c = AT90S4434\r
-    Device code: 0x38 = AT90S8515\r
-    Device code: 0x65 = (unknown)\r
-\r
-avrdude: warning: selected device is not supported by programmer: usb162\r
-avrdude: AVR device initialized and ready to accept instructions\r
-\r
-Reading | ################################################## | 100% 0.00s\r
-\r
-avrdude: Device signature = 0x1e9482\r
-avrdude: safemode: lfuse reads as 5E\r
-avrdude: safemode: hfuse reads as D9\r
-avrdude: safemode: efuse reads as F4\r
-avrdude: NOTE: FLASH memory has been specified, an erase cycle will be performed\r
-         To disable this feature, specify the -D option.\r
-avrdude: erasing chip\r
-avrdude: reading input file "BootloaderDFU.hex"\r
-avrdude: input file BootloaderDFU.hex auto detected as Intel Hex\r
-avrdude: writing flash (16066 bytes):\r
-\r
-Writing | ################################################## | 100% 33.39s\r
-\r
-\r
-\r
-avrdude: 16066 bytes of flash written\r
-avrdude: verifying flash memory against BootloaderDFU.hex:\r
-avrdude: load data flash data from input file BootloaderDFU.hex:\r
-avrdude: input file BootloaderDFU.hex auto detected as Intel Hex\r
-avrdude: input file BootloaderDFU.hex contains 16066 bytes\r
-avrdude: reading on-chip flash data:\r
-\r
-Reading | ################################################## | 100% 16.07s\r
-\r
-\r
-\r
-avrdude: verifying ...\r
-avrdude: 16066 bytes of flash verified\r
-\r
-avrdude: safemode: lfuse reads as 5E\r
-avrdude: safemode: hfuse reads as D9\r
-avrdude: safemode: efuse reads as F4\r
-avrdude: safemode: Fuses OK\r
-\r
-avrdude done.  Thank you.
-
diff --git a/Projects/AVRISP_Programmer/makefile b/Projects/AVRISP_Programmer/makefile
deleted file mode 100644 (file)
index 0938f05..0000000
+++ /dev/null
@@ -1,726 +0,0 @@
-# Hey Emacs, this is a -*- makefile -*-\r
-#----------------------------------------------------------------------------\r
-# WinAVR Makefile Template written by Eric B. Weddington, Jörg Wunsch, et al.\r
-#  >> Modified for use with the LUFA project. <<\r
-#\r
-# Released to the Public Domain\r
-#\r
-# Additional material for this makefile was written by:\r
-# Peter Fleury\r
-# Tim Henigan\r
-# Colin O'Flynn\r
-# Reiner Patommel\r
-# Markus Pfaff\r
-# Sander Pool\r
-# Frederik Rouleau\r
-# Carlos Lamas\r
-# Dean Camera\r
-# Opendous Inc.\r
-# Denver Gingerich\r
-#\r
-#----------------------------------------------------------------------------\r
-# On command line:\r
-#\r
-# make all = Make software.\r
-#\r
-# make clean = Clean out built project files.\r
-#\r
-# make coff = Convert ELF to AVR COFF.\r
-#\r
-# make extcoff = Convert ELF to AVR Extended COFF.\r
-#\r
-# make program = Download the hex file to the device, using avrdude.\r
-#                Please customize the avrdude settings below first!\r
-#\r
-# make dfu = Download the hex file to the device, using dfu-programmer (must\r
-#            have dfu-programmer installed).\r
-#\r
-# make flip = Download the hex file to the device, using Atmel FLIP (must\r
-#             have Atmel FLIP installed).\r
-#\r
-# make dfu-ee = Download the eeprom file to the device, using dfu-programmer\r
-#               (must have dfu-programmer installed).\r
-#\r
-# make flip-ee = Download the eeprom file to the device, using Atmel FLIP\r
-#                (must have Atmel FLIP installed).\r
-#\r
-# make doxygen = Generate DoxyGen documentation for the project (must have\r
-#                DoxyGen installed)\r
-#\r
-# make debug = Start either simulavr or avarice as specified for debugging, \r
-#              with avr-gdb or avr-insight as the front end for debugging.\r
-#\r
-# make filename.s = Just compile filename.c into the assembler code only.\r
-#\r
-# make filename.i = Create a preprocessed source file for use in submitting\r
-#                   bug reports to the GCC project.\r
-#\r
-# To rebuild project do "make clean" then "make all".\r
-#----------------------------------------------------------------------------\r
-\r
-\r
-# MCU name\r
-MCU = at90usb1287\r
-\r
-\r
-# Target board (USBKEY, STK525, STK526, RZUSBSTICK, USER or blank for projects not requiring\r
-# LUFA board drivers). If USER is selected, put custom board drivers in a directory called \r
-# "Board" inside the application directory.\r
-BOARD  = USBKEY\r
-\r
-\r
-# Processor frequency.\r
-#     This will define a symbol, F_CPU, in all source code files equal to the \r
-#     processor frequency. You can then use this symbol in your source code to \r
-#     calculate timings. Do NOT tack on a 'UL' at the end, this will be done\r
-#     automatically to create a 32-bit value in your source code.\r
-#     Typical values are:\r
-#         F_CPU =  1000000\r
-#         F_CPU =  1843200\r
-#         F_CPU =  2000000\r
-#         F_CPU =  3686400\r
-#         F_CPU =  4000000\r
-#         F_CPU =  7372800\r
-#         F_CPU =  8000000\r
-#         F_CPU = 11059200\r
-#         F_CPU = 14745600\r
-#         F_CPU = 16000000\r
-#         F_CPU = 18432000\r
-#         F_CPU = 20000000\r
-F_CPU = 8000000\r
-\r
-\r
-# Input clock frequency.\r
-#     This will define a symbol, F_CLOCK, in all source code files equal to the \r
-#     input clock frequency (before any prescaling is performed). This value may\r
-#     differ from F_CPU if prescaling is used on the latter, and is required as the\r
-#     raw input clock is fed directly to the PLL sections of the AVR for high speed\r
-#     clock generation for the USB and other AVR subsections. Do NOT tack on a 'UL'\r
-#     at the end, this will be done automatically to create a 32-bit value in your\r
-#     source code.\r
-#\r
-#     If no clock division is performed on the input clock inside the AVR (via the\r
-#     CPU clock adjust registers or the clock division fuses), this will be equal to F_CPU.\r
-F_CLOCK = 8000000\r
-\r
-\r
-# Output format. (can be srec, ihex, binary)\r
-FORMAT = ihex\r
-\r
-\r
-# Target file name (without extension).\r
-TARGET = AVRISP_Programmer\r
-\r
-\r
-# Object files directory\r
-#     To put object files in current directory, use a dot (.), do NOT make\r
-#     this an empty or blank macro!\r
-OBJDIR = .\r
-\r
-\r
-# List C source files here. (C dependencies are automatically generated.)\r
-SRC = $(TARGET).c                                          \\r
-         Descriptors.c                                        \\r
-         RingBuff.c                                           \\r
-         ../../LUFA/Scheduler/Scheduler.c                     \\r
-         ../../LUFA/Drivers/AT90USBXXX/Serial.c               \\r
-         ../../LUFA/Drivers/USB/LowLevel/LowLevel.c           \\r
-         ../../LUFA/Drivers/USB/LowLevel/Endpoint.c           \\r
-         ../../LUFA/Drivers/USB/LowLevel/DevChapter9.c        \\r
-         ../../LUFA/Drivers/USB/HighLevel/USBTask.c           \\r
-         ../../LUFA/Drivers/USB/HighLevel/USBInterrupt.c      \\r
-         ../../LUFA/Drivers/USB/HighLevel/Events.c            \\r
-         ../../LUFA/Drivers/USB/HighLevel/StdDescriptors.c    \\r
-         \r
-# List C++ source files here. (C dependencies are automatically generated.)\r
-CPPSRC = \r
-\r
-\r
-# List Assembler source files here.\r
-#     Make them always end in a capital .S.  Files ending in a lowercase .s\r
-#     will not be considered source files but generated files (assembler\r
-#     output from the compiler), and will be deleted upon "make clean"!\r
-#     Even though the DOS/Win* filesystem matches both .s and .S the same,\r
-#     it will preserve the spelling of the filenames, and gcc itself does\r
-#     care about how the name is spelled on its command-line.\r
-ASRC =\r
-\r
-\r
-# Optimization level, can be [0, 1, 2, 3, s]. \r
-#     0 = turn off optimization. s = optimize for size.\r
-#     (Note: 3 is not always the best optimization level. See avr-libc FAQ.)\r
-OPT = s\r
-\r
-\r
-# Debugging format.\r
-#     Native formats for AVR-GCC's -g are dwarf-2 [default] or stabs.\r
-#     AVR Studio 4.10 requires dwarf-2.\r
-#     AVR [Extended] COFF format requires stabs, plus an avr-objcopy run.\r
-DEBUG = dwarf-2\r
-\r
-\r
-# List any extra directories to look for include files here.\r
-#     Each directory must be seperated by a space.\r
-#     Use forward slashes for directory separators.\r
-#     For a directory that has spaces, enclose it in quotes.\r
-EXTRAINCDIRS = ../../\r
-\r
-\r
-# Compiler flag to set the C Standard level.\r
-#     c89   = "ANSI" C\r
-#     gnu89 = c89 plus GCC extensions\r
-#     c99   = ISO C99 standard (not yet fully implemented)\r
-#     gnu99 = c99 plus GCC extensions\r
-CSTANDARD = -std=gnu99\r
-\r
-\r
-# Place -D or -U options here for C sources\r
-CDEFS  = -DF_CPU=$(F_CPU)UL -DF_CLOCK=$(F_CLOCK)UL -DBOARD=BOARD_$(BOARD)\r
-CDEFS += -DUSE_NONSTANDARD_DESCRIPTOR_NAMES -DNO_STREAM_CALLBACKS -DUSB_DEVICE_ONLY\r
-CDEFS += -DUSE_STATIC_OPTIONS="(USB_DEVICE_OPT_FULLSPEED | USB_OPT_REG_ENABLED | USB_OPT_AUTO_PLL)"\r
-\r
-\r
-# Place -D or -U options here for ASM sources\r
-ADEFS = -DF_CPU=$(F_CPU)\r
-\r
-\r
-# Place -D or -U options here for C++ sources\r
-CPPDEFS = -DF_CPU=$(F_CPU)UL\r
-#CPPDEFS += -D__STDC_LIMIT_MACROS\r
-#CPPDEFS += -D__STDC_CONSTANT_MACROS\r
-\r
-\r
-\r
-#---------------- Compiler Options C ----------------\r
-#  -g*:          generate debugging information\r
-#  -O*:          optimization level\r
-#  -f...:        tuning, see GCC manual and avr-libc documentation\r
-#  -Wall...:     warning level\r
-#  -Wa,...:      tell GCC to pass this to the assembler.\r
-#    -adhlns...: create assembler listing\r
-CFLAGS = -g$(DEBUG)\r
-CFLAGS += $(CDEFS)\r
-CFLAGS += -O$(OPT)\r
-CFLAGS += -funsigned-char\r
-CFLAGS += -funsigned-bitfields\r
-CFLAGS += -ffunction-sections\r
-CFLAGS += -fpack-struct\r
-CFLAGS += -fshort-enums\r
-CFLAGS += -finline-limit=20\r
-CFLAGS += -Wall\r
-CFLAGS += -Wstrict-prototypes\r
-CFLAGS += -Wundef\r
-#CFLAGS += -fno-unit-at-a-time\r
-#CFLAGS += -Wunreachable-code\r
-#CFLAGS += -Wsign-compare\r
-CFLAGS += -Wa,-adhlns=$(<:%.c=$(OBJDIR)/%.lst)\r
-CFLAGS += $(patsubst %,-I%,$(EXTRAINCDIRS))\r
-CFLAGS += $(CSTANDARD)\r
-\r
-\r
-#---------------- Compiler Options C++ ----------------\r
-#  -g*:          generate debugging information\r
-#  -O*:          optimization level\r
-#  -f...:        tuning, see GCC manual and avr-libc documentation\r
-#  -Wall...:     warning level\r
-#  -Wa,...:      tell GCC to pass this to the assembler.\r
-#    -adhlns...: create assembler listing\r
-CPPFLAGS = -g$(DEBUG)\r
-CPPFLAGS += $(CPPDEFS)\r
-CPPFLAGS += -O$(OPT)\r
-CPPFLAGS += -funsigned-char\r
-CPPFLAGS += -funsigned-bitfields\r
-CPPFLAGS += -fpack-struct\r
-CPPFLAGS += -fshort-enums\r
-CPPFLAGS += -fno-exceptions\r
-CPPFLAGS += -Wall\r
-CFLAGS += -Wundef\r
-#CPPFLAGS += -mshort-calls\r
-#CPPFLAGS += -fno-unit-at-a-time\r
-#CPPFLAGS += -Wstrict-prototypes\r
-#CPPFLAGS += -Wunreachable-code\r
-#CPPFLAGS += -Wsign-compare\r
-CPPFLAGS += -Wa,-adhlns=$(<:%.cpp=$(OBJDIR)/%.lst)\r
-CPPFLAGS += $(patsubst %,-I%,$(EXTRAINCDIRS))\r
-#CPPFLAGS += $(CSTANDARD)\r
-\r
-\r
-#---------------- Assembler Options ----------------\r
-#  -Wa,...:   tell GCC to pass this to the assembler.\r
-#  -adhlns:   create listing\r
-#  -gstabs:   have the assembler create line number information; note that\r
-#             for use in COFF files, additional information about filenames\r
-#             and function names needs to be present in the assembler source\r
-#             files -- see avr-libc docs [FIXME: not yet described there]\r
-#  -listing-cont-lines: Sets the maximum number of continuation lines of hex \r
-#       dump that will be displayed for a given single line of source input.\r
-ASFLAGS = $(ADEFS) -Wa,-adhlns=$(<:%.S=$(OBJDIR)/%.lst),-gstabs,--listing-cont-lines=100\r
-\r
-\r
-#---------------- Library Options ----------------\r
-# Minimalistic printf version\r
-PRINTF_LIB_MIN = -Wl,-u,vfprintf -lprintf_min\r
-\r
-# Floating point printf version (requires MATH_LIB = -lm below)\r
-PRINTF_LIB_FLOAT = -Wl,-u,vfprintf -lprintf_flt\r
-\r
-# If this is left blank, then it will use the Standard printf version.\r
-PRINTF_LIB = \r
-#PRINTF_LIB = $(PRINTF_LIB_MIN)\r
-#PRINTF_LIB = $(PRINTF_LIB_FLOAT)\r
-\r
-\r
-# Minimalistic scanf version\r
-SCANF_LIB_MIN = -Wl,-u,vfscanf -lscanf_min\r
-\r
-# Floating point + %[ scanf version (requires MATH_LIB = -lm below)\r
-SCANF_LIB_FLOAT = -Wl,-u,vfscanf -lscanf_flt\r
-\r
-# If this is left blank, then it will use the Standard scanf version.\r
-SCANF_LIB = \r
-#SCANF_LIB = $(SCANF_LIB_MIN)\r
-#SCANF_LIB = $(SCANF_LIB_FLOAT)\r
-\r
-\r
-MATH_LIB = -lm\r
-\r
-\r
-# List any extra directories to look for libraries here.\r
-#     Each directory must be seperated by a space.\r
-#     Use forward slashes for directory separators.\r
-#     For a directory that has spaces, enclose it in quotes.\r
-EXTRALIBDIRS = \r
-\r
-\r
-\r
-#---------------- External Memory Options ----------------\r
-\r
-# 64 KB of external RAM, starting after internal RAM (ATmega128!),\r
-# used for variables (.data/.bss) and heap (malloc()).\r
-#EXTMEMOPTS = -Wl,-Tdata=0x801100,--defsym=__heap_end=0x80ffff\r
-\r
-# 64 KB of external RAM, starting after internal RAM (ATmega128!),\r
-# only used for heap (malloc()).\r
-#EXTMEMOPTS = -Wl,--section-start,.data=0x801100,--defsym=__heap_end=0x80ffff\r
-\r
-EXTMEMOPTS =\r
-\r
-\r
-\r
-#---------------- Linker Options ----------------\r
-#  -Wl,...:     tell GCC to pass this to linker.\r
-#    -Map:      create map file\r
-#    --cref:    add cross reference to  map file\r
-LDFLAGS = -Wl,-Map=$(TARGET).map,--cref\r
-LDFLAGS += -Wl,--relax \r
-LDFLAGS += -Wl,--gc-sections\r
-LDFLAGS += $(EXTMEMOPTS)\r
-LDFLAGS += $(patsubst %,-L%,$(EXTRALIBDIRS))\r
-LDFLAGS += $(PRINTF_LIB) $(SCANF_LIB) $(MATH_LIB)\r
-#LDFLAGS += -T linker_script.x\r
-\r
-\r
-\r
-#---------------- Programming Options (avrdude) ----------------\r
-\r
-# Programming hardware: alf avr910 avrisp bascom bsd \r
-# dt006 pavr picoweb pony-stk200 sp12 stk200 stk500\r
-#\r
-# Type: avrdude -c ?\r
-# to get a full listing.\r
-#\r
-AVRDUDE_PROGRAMMER = jtagmkII\r
-\r
-# com1 = serial port. Use lpt1 to connect to parallel port.\r
-AVRDUDE_PORT = usb\r
-\r
-AVRDUDE_WRITE_FLASH = -U flash:w:$(TARGET).hex\r
-#AVRDUDE_WRITE_EEPROM = -U eeprom:w:$(TARGET).eep\r
-\r
-\r
-# Uncomment the following if you want avrdude's erase cycle counter.\r
-# Note that this counter needs to be initialized first using -Yn,\r
-# see avrdude manual.\r
-#AVRDUDE_ERASE_COUNTER = -y\r
-\r
-# Uncomment the following if you do /not/ wish a verification to be\r
-# performed after programming the device.\r
-#AVRDUDE_NO_VERIFY = -V\r
-\r
-# Increase verbosity level.  Please use this when submitting bug\r
-# reports about avrdude. See <http://savannah.nongnu.org/projects/avrdude> \r
-# to submit bug reports.\r
-#AVRDUDE_VERBOSE = -v -v\r
-\r
-AVRDUDE_FLAGS = -p $(MCU) -P $(AVRDUDE_PORT) -c $(AVRDUDE_PROGRAMMER)\r
-AVRDUDE_FLAGS += $(AVRDUDE_NO_VERIFY)\r
-AVRDUDE_FLAGS += $(AVRDUDE_VERBOSE)\r
-AVRDUDE_FLAGS += $(AVRDUDE_ERASE_COUNTER)\r
-\r
-\r
-\r
-#---------------- Debugging Options ----------------\r
-\r
-# For simulavr only - target MCU frequency.\r
-DEBUG_MFREQ = $(F_CPU)\r
-\r
-# Set the DEBUG_UI to either gdb or insight.\r
-# DEBUG_UI = gdb\r
-DEBUG_UI = insight\r
-\r
-# Set the debugging back-end to either avarice, simulavr.\r
-DEBUG_BACKEND = avarice\r
-#DEBUG_BACKEND = simulavr\r
-\r
-# GDB Init Filename.\r
-GDBINIT_FILE = __avr_gdbinit\r
-\r
-# When using avarice settings for the JTAG\r
-JTAG_DEV = /dev/com1\r
-\r
-# Debugging port used to communicate between GDB / avarice / simulavr.\r
-DEBUG_PORT = 4242\r
-\r
-# Debugging host used to communicate between GDB / avarice / simulavr, normally\r
-#     just set to localhost unless doing some sort of crazy debugging when \r
-#     avarice is running on a different computer.\r
-DEBUG_HOST = localhost\r
-\r
-\r
-\r
-#============================================================================\r
-\r
-\r
-# Define programs and commands.\r
-SHELL = sh\r
-CC = avr-gcc\r
-OBJCOPY = avr-objcopy\r
-OBJDUMP = avr-objdump\r
-SIZE = avr-size\r
-AR = avr-ar rcs\r
-NM = avr-nm\r
-AVRDUDE = avrdude\r
-REMOVE = rm -f\r
-REMOVEDIR = rm -rf\r
-COPY = cp\r
-WINSHELL = cmd\r
-\r
-# Define Messages\r
-# English\r
-MSG_ERRORS_NONE = Errors: none\r
-MSG_BEGIN = -------- begin --------\r
-MSG_END = --------  end  --------\r
-MSG_SIZE_BEFORE = Size before: \r
-MSG_SIZE_AFTER = Size after:\r
-MSG_COFF = Converting to AVR COFF:\r
-MSG_EXTENDED_COFF = Converting to AVR Extended COFF:\r
-MSG_FLASH = Creating load file for Flash:\r
-MSG_EEPROM = Creating load file for EEPROM:\r
-MSG_EXTENDED_LISTING = Creating Extended Listing:\r
-MSG_SYMBOL_TABLE = Creating Symbol Table:\r
-MSG_LINKING = Linking:\r
-MSG_COMPILING = Compiling C:\r
-MSG_COMPILING_CPP = Compiling C++:\r
-MSG_ASSEMBLING = Assembling:\r
-MSG_CLEANING = Cleaning project:\r
-MSG_CREATING_LIBRARY = Creating library:\r
-\r
-\r
-\r
-\r
-# Define all object files.\r
-OBJ = $(SRC:%.c=$(OBJDIR)/%.o) $(CPPSRC:%.cpp=$(OBJDIR)/%.o) $(ASRC:%.S=$(OBJDIR)/%.o) \r
-\r
-# Define all listing files.\r
-LST = $(SRC:%.c=$(OBJDIR)/%.lst) $(CPPSRC:%.cpp=$(OBJDIR)/%.lst) $(ASRC:%.S=$(OBJDIR)/%.lst) \r
-\r
-\r
-# Compiler flags to generate dependency files.\r
-GENDEPFLAGS = -MMD -MP -MF .dep/$(@F).d\r
-\r
-\r
-# Combine all necessary flags and optional flags.\r
-# Add target processor to flags.\r
-ALL_CFLAGS = -mmcu=$(MCU) -I. $(CFLAGS) $(GENDEPFLAGS)\r
-ALL_CPPFLAGS = -mmcu=$(MCU) -I. -x c++ $(CPPFLAGS) $(GENDEPFLAGS)\r
-ALL_ASFLAGS = -mmcu=$(MCU) -I. -x assembler-with-cpp $(ASFLAGS)\r
-\r
-\r
-\r
-\r
-\r
-# Default target.\r
-all: begin gccversion sizebefore build checkhooks checklibmode checkboard sizeafter end\r
-\r
-# Change the build target to build a HEX file or a library.\r
-build: elf hex eep lss sym\r
-#build: lib\r
-\r
-\r
-elf: $(TARGET).elf\r
-hex: $(TARGET).hex\r
-eep: $(TARGET).eep\r
-lss: $(TARGET).lss\r
-sym: $(TARGET).sym\r
-LIBNAME=lib$(TARGET).a\r
-lib: $(LIBNAME)\r
-\r
-\r
-\r
-# Eye candy.\r
-# AVR Studio 3.x does not check make's exit code but relies on\r
-# the following magic strings to be generated by the compile job.\r
-begin:\r
-       @echo\r
-       @echo $(MSG_BEGIN)\r
-\r
-end:\r
-       @echo $(MSG_END)\r
-       @echo\r
-\r
-\r
-# Display size of file.\r
-HEXSIZE = $(SIZE) --target=$(FORMAT) $(TARGET).hex\r
-ELFSIZE = $(SIZE) $(MCU_FLAG) $(FORMAT_FLAG) $(TARGET).elf\r
-MCU_FLAG = $(shell $(SIZE) --help | grep -- --mcu > /dev/null && echo --mcu=$(MCU) )\r
-FORMAT_FLAG = $(shell $(SIZE) --help | grep -- --format=.*avr > /dev/null && echo --format=avr )\r
-\r
-sizebefore:\r
-       @if test -f $(TARGET).elf; then echo; echo $(MSG_SIZE_BEFORE); $(ELFSIZE); \\r
-       2>/dev/null; echo; fi\r
-\r
-sizeafter:\r
-       @if test -f $(TARGET).elf; then echo; echo $(MSG_SIZE_AFTER); $(ELFSIZE); \\r
-       2>/dev/null; echo; fi\r
-\r
-checkhooks: build\r
-       @echo\r
-       @echo ------- Unhooked LUFA Events -------\r
-       @$(shell) (grep -s '^Event.*LUFA/.*\\.o' $(TARGET).map | \\r
-                  cut -d' ' -f1 | cut -d'_' -f2- | grep ".*") || \\r
-                          echo "(None)"\r
-       @echo ------------------------------------\r
-\r
-checklibmode:\r
-       @echo\r
-       @echo ----------- Library Mode -----------\r
-       @$(shell) ($(CC) $(ALL_CFLAGS) -E -dM - < /dev/null \\r
-                 | grep 'USB_\(DEVICE\|HOST\)_ONLY' | cut -d' ' -f2 | grep ".*") \\r
-                 || echo "No specific mode (both device and host mode allowable)."\r
-       @echo ------------------------------------\r
-\r
-checkboard:\r
-       @echo\r
-       @echo ---------- Selected Board ----------\r
-       @echo Selected board model is $(BOARD).\r
-       @echo ------------------------------------\r
-       \r
-# Display compiler version information.\r
-gccversion : \r
-       @$(CC) --version\r
-\r
-\r
-\r
-# Program the device.  \r
-program: $(TARGET).hex $(TARGET).eep\r
-       $(AVRDUDE) $(AVRDUDE_FLAGS) $(AVRDUDE_WRITE_FLASH) $(AVRDUDE_WRITE_EEPROM)\r
-\r
-flip: $(TARGET).hex\r
-       batchisp -hardware usb -device $(MCU) -operation erase f\r
-       batchisp -hardware usb -device $(MCU) -operation loadbuffer $(TARGET).hex program\r
-       batchisp -hardware usb -device $(MCU) -operation start reset 0\r
-\r
-dfu: $(TARGET).hex\r
-       dfu-programmer $(MCU) erase\r
-       dfu-programmer $(MCU) flash --debug 1 $(TARGET).hex\r
-       dfu-programmer $(MCU) reset\r
-\r
-flip-ee: $(TARGET).hex $(TARGET).eep\r
-       copy $(TARGET).eep $(TARGET)eep.hex\r
-       batchisp -hardware usb -device $(MCU) -operation memory EEPROM erase\r
-       batchisp -hardware usb -device $(MCU) -operation memory EEPROM loadbuffer $(TARGET)eep.hex program\r
-       batchisp -hardware usb -device $(MCU) -operation start reset 0\r
-\r
-dfu-ee: $(TARGET).hex $(TARGET).eep\r
-       dfu-programmer $(MCU) flash-eeprom --debug 1 --suppress-bootloader-mem $(TARGET).eep\r
-       dfu-programmer $(MCU) reset\r
-\r
-\r
-# Generate avr-gdb config/init file which does the following:\r
-#     define the reset signal, load the target file, connect to target, and set \r
-#     a breakpoint at main().\r
-gdb-config: \r
-       @$(REMOVE) $(GDBINIT_FILE)\r
-       @echo define reset >> $(GDBINIT_FILE)\r
-       @echo SIGNAL SIGHUP >> $(GDBINIT_FILE)\r
-       @echo end >> $(GDBINIT_FILE)\r
-       @echo file $(TARGET).elf >> $(GDBINIT_FILE)\r
-       @echo target remote $(DEBUG_HOST):$(DEBUG_PORT)  >> $(GDBINIT_FILE)\r
-ifeq ($(DEBUG_BACKEND),simulavr)\r
-       @echo load  >> $(GDBINIT_FILE)\r
-endif\r
-       @echo break main >> $(GDBINIT_FILE)\r
-\r
-debug: gdb-config $(TARGET).elf\r
-ifeq ($(DEBUG_BACKEND), avarice)\r
-       @echo Starting AVaRICE - Press enter when "waiting to connect" message displays.\r
-       @$(WINSHELL) /c start avarice --jtag $(JTAG_DEV) --erase --program --file \\r
-       $(TARGET).elf $(DEBUG_HOST):$(DEBUG_PORT)\r
-       @$(WINSHELL) /c pause\r
-\r
-else\r
-       @$(WINSHELL) /c start simulavr --gdbserver --device $(MCU) --clock-freq \\r
-       $(DEBUG_MFREQ) --port $(DEBUG_PORT)\r
-endif\r
-       @$(WINSHELL) /c start avr-$(DEBUG_UI) --command=$(GDBINIT_FILE)\r
-\r
-\r
-\r
-\r
-# Convert ELF to COFF for use in debugging / simulating in AVR Studio or VMLAB.\r
-COFFCONVERT = $(OBJCOPY) --debugging\r
-COFFCONVERT += --change-section-address .data-0x800000\r
-COFFCONVERT += --change-section-address .bss-0x800000\r
-COFFCONVERT += --change-section-address .noinit-0x800000\r
-COFFCONVERT += --change-section-address .eeprom-0x810000\r
-\r
-\r
-\r
-coff: $(TARGET).elf\r
-       @echo\r
-       @echo $(MSG_COFF) $(TARGET).cof\r
-       $(COFFCONVERT) -O coff-avr $< $(TARGET).cof\r
-\r
-\r
-extcoff: $(TARGET).elf\r
-       @echo\r
-       @echo $(MSG_EXTENDED_COFF) $(TARGET).cof\r
-       $(COFFCONVERT) -O coff-ext-avr $< $(TARGET).cof\r
-\r
-\r
-\r
-# Create final output files (.hex, .eep) from ELF output file.\r
-%.hex: %.elf\r
-       @echo\r
-       @echo $(MSG_FLASH) $@\r
-       $(OBJCOPY) -O $(FORMAT) -R .eeprom $< $@\r
-\r
-%.eep: %.elf\r
-       @echo\r
-       @echo $(MSG_EEPROM) $@\r
-       -$(OBJCOPY) -j .eeprom --set-section-flags=.eeprom="alloc,load" \\r
-       --change-section-lma .eeprom=0 --no-change-warnings -O $(FORMAT) $< $@ || exit 0\r
-\r
-# Create extended listing file from ELF output file.\r
-%.lss: %.elf\r
-       @echo\r
-       @echo $(MSG_EXTENDED_LISTING) $@\r
-       $(OBJDUMP) -h -z -S $< > $@\r
-\r
-# Create a symbol table from ELF output file.\r
-%.sym: %.elf\r
-       @echo\r
-       @echo $(MSG_SYMBOL_TABLE) $@\r
-       $(NM) -n $< > $@\r
-\r
-\r
-\r
-# Create library from object files.\r
-.SECONDARY : $(TARGET).a\r
-.PRECIOUS : $(OBJ)\r
-%.a: $(OBJ)\r
-       @echo\r
-       @echo $(MSG_CREATING_LIBRARY) $@\r
-       $(AR) $@ $(OBJ)\r
-\r
-\r
-# Link: create ELF output file from object files.\r
-.SECONDARY : $(TARGET).elf\r
-.PRECIOUS : $(OBJ)\r
-%.elf: $(OBJ)\r
-       @echo\r
-       @echo $(MSG_LINKING) $@\r
-       $(CC) $(ALL_CFLAGS) $^ --output $@ $(LDFLAGS)\r
-\r
-\r
-# Compile: create object files from C source files.\r
-$(OBJDIR)/%.o : %.c\r
-       @echo\r
-       @echo $(MSG_COMPILING) $<\r
-       $(CC) -c $(ALL_CFLAGS) $< -o $@ \r
-\r
-\r
-# Compile: create object files from C++ source files.\r
-$(OBJDIR)/%.o : %.cpp\r
-       @echo\r
-       @echo $(MSG_COMPILING_CPP) $<\r
-       $(CC) -c $(ALL_CPPFLAGS) $< -o $@ \r
-\r
-\r
-# Compile: create assembler files from C source files.\r
-%.s : %.c\r
-       $(CC) -S $(ALL_CFLAGS) $< -o $@\r
-\r
-\r
-# Compile: create assembler files from C++ source files.\r
-%.s : %.cpp\r
-       $(CC) -S $(ALL_CPPFLAGS) $< -o $@\r
-\r
-\r
-# Assemble: create object files from assembler source files.\r
-$(OBJDIR)/%.o : %.S\r
-       @echo\r
-       @echo $(MSG_ASSEMBLING) $<\r
-       $(CC) -c $(ALL_ASFLAGS) $< -o $@\r
-\r
-\r
-# Create preprocessed source for use in sending a bug report.\r
-%.i : %.c\r
-       $(CC) -E -mmcu=$(MCU) -I. $(CFLAGS) $< -o $@ \r
-       \r
-\r
-# Target: clean project.\r
-clean: begin clean_list clean_binary end\r
-\r
-clean_binary:\r
-       $(REMOVE) $(TARGET).hex\r
-       \r
-clean_list:\r
-       @echo $(MSG_CLEANING)\r
-       $(REMOVE) $(TARGET).eep\r
-       $(REMOVE) $(TARGET)eep.hex\r
-       $(REMOVE) $(TARGET).cof\r
-       $(REMOVE) $(TARGET).elf\r
-       $(REMOVE) $(TARGET).map\r
-       $(REMOVE) $(TARGET).sym\r
-       $(REMOVE) $(TARGET).lss\r
-       $(REMOVE) $(SRC:%.c=$(OBJDIR)/%.o)\r
-       $(REMOVE) $(SRC:%.c=$(OBJDIR)/%.lst)\r
-       $(REMOVE) $(SRC:.c=.s)\r
-       $(REMOVE) $(SRC:.c=.d)\r
-       $(REMOVE) $(SRC:.c=.i)\r
-       $(REMOVEDIR) .dep\r
-\r
-\r
-doxygen:\r
-       @echo Generating Project Documentation...\r
-       @doxygen Doxygen.conf\r
-       @echo Documentation Generation Complete.\r
-\r
-clean_doxygen:\r
-       rm -rf Documentation\r
-\r
-# Create object files directory\r
-$(shell mkdir $(OBJDIR) 2>/dev/null)\r
-\r
-\r
-# Include the dependency files.\r
--include $(shell mkdir .dep 2>/dev/null) $(wildcard .dep/*)\r
-\r
-\r
-# Listing of phony targets.\r
-.PHONY : all checkhooks checklibmode checkboard   \\r
-begin finish end sizebefore sizeafter gccversion  \\r
-build elf hex eep lss sym coff extcoff clean      \\r
-clean_list clean_binary program debug gdb-config  \\r
-doxygen dfu flip flip-ee dfu-ee
\ No newline at end of file
index d91fddd..af95650 100644 (file)
@@ -5,7 +5,36 @@
  */\r
  \r
 /** \mainpage Denver Gingerich's USBSnoop Magnetic Card Reader Project\r
- * \r
+ *\r
+ *  \section SSec_Info USB Information:\r
+ *\r
+ *  The following table gives a rundown of the USB utilization of this demo.\r
+ *\r
+ * <table>\r
+ *  <tr>\r
+ *   <td><b>USB Mode:</b></td>\r
+ *   <td>Device</td>\r
+ *  </tr>\r
+ *  <tr>\r
+ *   <td><b>USB Class:</b></td>\r
+ *   <td>Human Interface Device (HID)</td>\r
+ *  </tr>\r
+ *  <tr> \r
+ *   <td><b>USB Subclass:</b></td>\r
+ *   <td>Keyboard</td>\r
+ *  </tr>\r
+ *  <tr>\r
+ *   <td><b>Relevant Standards:</b></td>\r
+ *   <td>USBIF HID Standard, USBIF HID Usage Tables</td>\r
+ *  </tr>\r
+ *  <tr>\r
+ *   <td><b>Usable Speeds:</b></td>\r
+ *   <td>Low Speed Mode, Full Speed Mode</td>\r
+ *  </tr>\r
+ * </table>\r
+ *\r
+ *  \section SSec_Description Project Description: \r
+ *\r
  *  Firmware for a USB AVR powered USB TTL magnetic stripe reader (using a card\r
  *  reader such as the Omron V3B-4K) by Denver Gingerich. This project is designed\r
  *  to be used with the open source Stripe Snoop project at http://stripesnoop.sourceforge.net/.\r
@@ -51,7 +80,6 @@
  *   </tr>\r
  *  </table>\r
  *\r
- * \r
  *  This project is based on the LUFA Keyboard demonstration application,\r
  *  written by Denver Gingerich.\r
  *\r
  *  obtained from the magnetic stripe reader is "typed" through the keyboard\r
  *  driver as 0's and 1's. After every card swipe, the demo will send a return key.\r
  *\r
- * <table>\r
- *  <tr>\r
- *   <td><b>USB Mode:</b></td>\r
- *   <td>Device</td>\r
- *  </tr>\r
- *  <tr>\r
- *   <td><b>USB Class:</b></td>\r
- *   <td>Human Interface Device (HID)</td>\r
- *  </tr>\r
- *  <tr> \r
- *   <td><b>USB Subclass:</b></td>\r
- *   <td>Keyboard</td>\r
- *  </tr>\r
- *  <tr>\r
- *   <td><b>Relevant Standards:</b></td>\r
- *   <td>USBIF HID Standard, USBIF HID Usage Tables</td>\r
- *  </tr>\r
- *  <tr>\r
- *   <td><b>Usable Speeds:</b></td>\r
- *   <td>Low Speed Mode, Full Speed Mode</td>\r
- *  </tr>\r
- * </table>\r
- */\r
+ *  \section SSec_Options Project Options\r
+ *\r
+ *  The following defines can be found in this demo, which can control the demo behaviour when defined, or changed in value.\r
+ *\r
+ *  <table>\r
+ *   <tr>\r
+ *    <td><b>Define Name:</b></td>\r
+ *    <td><b>Location:</b></td>\r
+ *    <td><b>Description:</b></td>\r
+ *   </tr>\r
+ *   <tr>\r
+ *    <td>MAX_BITS</td>\r
+ *    <td>CircularBitBuffer.h</td>\r
+ *    <td>Gives the maximum number of bits per track which can be buffered by the device for later transmission to a host.</td>\r
+ *   </tr>\r
+ *  </table>\r
+ */
\ No newline at end of file
index 50851a3..59de892 100644 (file)
 all:
        make -C Magstripe clean
        make -C Magstripe all
-       
-       make -C AVRISP_Programmer clean
-       make -C AVRISP_Programmer all
 
 %:
        make -C Magstripe $@
-       make -C AVRISP_Programmer $@