-/*\r
- LUFA Library\r
- Copyright (C) Dean Camera, 2010.\r
- \r
- dean [at] fourwalledcubicle [dot] com\r
- www.fourwalledcubicle.com\r
-*/\r
-\r
-/*\r
- Copyright 2010 Dean Camera (dean [at] fourwalledcubicle [dot] com)\r
-\r
- Permission to use, copy, modify, distribute, and sell this \r
- software and its documentation for any purpose is hereby granted\r
- without fee, provided that the above copyright notice appear in \r
- all 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
- * \brief USB mode and capability macros.\r
- *\r
- * This file defines macros indicating the type of USB controller the library is being compiled for, and its\r
- * capabilities. These macros may then be referenced in the user application to selectively enable or disable\r
- * code sections depending on if they are defined or not.\r
- *\r
- * \note This file should not be included directly. It is automatically included as needed by the USB driver\r
- * dispatch header located in LUFA/Drivers/USB/USB.h.\r
- */\r
-\r
-/** \ingroup Group_USB\r
- * @defgroup Group_USBMode USB Mode Tokens\r
- *\r
- * After the inclusion of the master USB driver header, one or more of the following\r
- * tokens may be defined, to allow the user code to conditionally enable or disable\r
- * code based on the USB controller family and allowable USB modes. These tokens may\r
- * be tested against to eliminate code relating to a USB mode which is not enabled for\r
- * the given compilation.\r
- *\r
- * @{\r
- */\r
-\r
-#ifndef __USBMODE_H__\r
-#define __USBMODE_H__\r
-\r
- /* Preprocessor Checks: */\r
- #if !defined(__INCLUDE_FROM_USB_DRIVER)\r
- #error Do not include this file directly. Include LUFA/Drivers/USB/USB.h instead.\r
- #endif\r
- \r
- /* Public Interface - May be used in end-application: */\r
- #if defined(__DOXYGEN__)\r
- /** Indicates that the target AVR microcontroller belongs to the Series 2 USB controller\r
- * (i.e. AT90USBXXX2 or ATMEGAXXU2) when defined.\r
- */\r
- #define USB_SERIES_2_AVR\r
-\r
- /** Indicates that the target AVR microcontroller belongs to the Series 4 USB controller\r
- * (i.e. ATMEGAXXU4) when defined.\r
- */\r
- #define USB_SERIES_4_AVR\r
-\r
- /** Indicates that the target AVR microcontroller belongs to the Series 6 USB controller\r
- * (i.e. AT90USBXXX6) when defined.\r
- */\r
- #define USB_SERIES_6_AVR\r
-\r
- /** Indicates that the target AVR microcontroller belongs to the Series 7 USB controller\r
- * (i.e. AT90USBXXX7) when defined.\r
- */\r
- #define USB_SERIES_7_AVR\r
-\r
- /** Indicates that the target AVR microcontroller and compilation settings allow for the\r
- * target to be configured in USB Device mode when defined.\r
- */\r
- #define USB_CAN_BE_DEVICE\r
-\r
- /** Indicates that the target AVR microcontroller and compilation settings allow for the\r
- * target to be configured in USB Host mode when defined.\r
- */\r
- #define USB_CAN_BE_HOST\r
-\r
- /** Indicates that the target AVR microcontroller and compilation settings allow for the\r
- * target to be configured in either USB Device or Host mode when defined.\r
- */\r
- #define USB_CAN_BE_BOTH\r
- #else\r
- /* Macros: */ \r
- #if (defined(__AVR_AT90USB162__) || defined(__AVR_AT90USB82__) || \\r
- defined(__AVR_ATmega32U2__) || defined(__AVR_ATmega16U2__) || defined(__AVR_ATmega8U2__))\r
- #define USB_SERIES_2_AVR\r
- #elif (defined(__AVR_ATmega32U4__) || defined(__AVR_ATmega16U4__))\r
- #define USB_SERIES_4_AVR\r
- #elif (defined(__AVR_ATmega32U6__) || defined(__AVR_AT90USB646__) || defined(__AVR_AT90USB1286__))\r
- #define USB_SERIES_6_AVR\r
- #elif (defined(__AVR_AT90USB647__) || defined(__AVR_AT90USB1287__))\r
- #define USB_SERIES_7_AVR\r
- #endif \r
-\r
- #if !defined(USB_SERIES_7_AVR) \r
- #if defined(USB_HOST_ONLY)\r
- #error USB_HOST_ONLY is not available for the currently selected USB AVR model.\r
- #endif\r
- \r
- #if !defined(USB_DEVICE_ONLY)\r
- #define USB_DEVICE_ONLY\r
- #endif\r
- #endif\r
-\r
- #if (!defined(USB_DEVICE_ONLY) && !defined(USB_HOST_ONLY))\r
- #define USB_CAN_BE_BOTH\r
- #define USB_CAN_BE_HOST\r
- #define USB_CAN_BE_DEVICE\r
- #elif defined(USB_HOST_ONLY)\r
- #define USB_CAN_BE_HOST\r
- #elif defined(USB_DEVICE_ONLY)\r
- #define USB_CAN_BE_DEVICE\r
- #endif\r
- \r
- #if (defined(USB_HOST_ONLY) && defined(USB_DEVICE_ONLY))\r
- #error USB_HOST_ONLY and USB_DEVICE_ONLY are mutually exclusive.\r
- #endif\r
- #endif\r
- \r
-#endif\r
-\r
+/*
+ LUFA Library
+ Copyright (C) Dean Camera, 2010.
+
+ dean [at] fourwalledcubicle [dot] com
+ www.fourwalledcubicle.com
+*/
+
+/*
+ Copyright 2010 Dean Camera (dean [at] fourwalledcubicle [dot] com)
+
+ Permission to use, copy, modify, distribute, and sell this
+ software and its documentation for any purpose is hereby granted
+ without fee, provided that the above copyright notice appear in
+ all copies and that both that the copyright notice and this
+ permission notice and warranty disclaimer appear in supporting
+ documentation, and that the name of the author not be used in
+ advertising or publicity pertaining to distribution of the
+ software without specific, written prior permission.
+
+ The author disclaim all warranties with regard to this
+ software, including all implied warranties of merchantability
+ and fitness. In no event shall the author be liable for any
+ special, indirect or consequential damages or any damages
+ whatsoever resulting from loss of use, data or profits, whether
+ in an action of contract, negligence or other tortious action,
+ arising out of or in connection with the use or performance of
+ this software.
+*/
+
+/** \file
+ * \brief USB mode and capability macros.
+ *
+ * This file defines macros indicating the type of USB controller the library is being compiled for, and its
+ * capabilities. These macros may then be referenced in the user application to selectively enable or disable
+ * code sections depending on if they are defined or not.
+ *
+ * \note This file should not be included directly. It is automatically included as needed by the USB driver
+ * dispatch header located in LUFA/Drivers/USB/USB.h.
+ */
+
+/** \ingroup Group_USB
+ * @defgroup Group_USBMode USB Mode Tokens
+ *
+ * After the inclusion of the master USB driver header, one or more of the following
+ * tokens may be defined, to allow the user code to conditionally enable or disable
+ * code based on the USB controller family and allowable USB modes. These tokens may
+ * be tested against to eliminate code relating to a USB mode which is not enabled for
+ * the given compilation.
+ *
+ * @{
+ */
+
+#ifndef __USBMODE_H__
+#define __USBMODE_H__
+
+ /* Preprocessor Checks: */
+ #if !defined(__INCLUDE_FROM_USB_DRIVER)
+ #error Do not include this file directly. Include LUFA/Drivers/USB/USB.h instead.
+ #endif
+
+ /* Public Interface - May be used in end-application: */
+ #if defined(__DOXYGEN__)
+ /** Indicates that the target AVR microcontroller belongs to the Series 2 USB controller
+ * (i.e. AT90USBXXX2 or ATMEGAXXU2) when defined.
+ */
+ #define USB_SERIES_2_AVR
+
+ /** Indicates that the target AVR microcontroller belongs to the Series 4 USB controller
+ * (i.e. ATMEGAXXU4) when defined.
+ */
+ #define USB_SERIES_4_AVR
+
+ /** Indicates that the target AVR microcontroller belongs to the Series 6 USB controller
+ * (i.e. AT90USBXXX6) when defined.
+ */
+ #define USB_SERIES_6_AVR
+
+ /** Indicates that the target AVR microcontroller belongs to the Series 7 USB controller
+ * (i.e. AT90USBXXX7) when defined.
+ */
+ #define USB_SERIES_7_AVR
+
+ /** Indicates that the target AVR microcontroller and compilation settings allow for the
+ * target to be configured in USB Device mode when defined.
+ */
+ #define USB_CAN_BE_DEVICE
+
+ /** Indicates that the target AVR microcontroller and compilation settings allow for the
+ * target to be configured in USB Host mode when defined.
+ */
+ #define USB_CAN_BE_HOST
+
+ /** Indicates that the target AVR microcontroller and compilation settings allow for the
+ * target to be configured in either USB Device or Host mode when defined.
+ */
+ #define USB_CAN_BE_BOTH
+ #else
+ /* Macros: */
+ #if (defined(__AVR_AT90USB162__) || defined(__AVR_AT90USB82__) || \
+ defined(__AVR_ATmega32U2__) || defined(__AVR_ATmega16U2__) || defined(__AVR_ATmega8U2__))
+ #define USB_SERIES_2_AVR
+ #elif (defined(__AVR_ATmega32U4__) || defined(__AVR_ATmega16U4__))
+ #define USB_SERIES_4_AVR
+ #elif (defined(__AVR_ATmega32U6__) || defined(__AVR_AT90USB646__) || defined(__AVR_AT90USB1286__))
+ #define USB_SERIES_6_AVR
+ #elif (defined(__AVR_AT90USB647__) || defined(__AVR_AT90USB1287__))
+ #define USB_SERIES_7_AVR
+ #endif
+
+ #if !defined(USB_SERIES_7_AVR)
+ #if defined(USB_HOST_ONLY)
+ #error USB_HOST_ONLY is not available for the currently selected USB AVR model.
+ #endif
+
+ #if !defined(USB_DEVICE_ONLY)
+ #define USB_DEVICE_ONLY
+ #endif
+ #endif
+
+ #if (!defined(USB_DEVICE_ONLY) && !defined(USB_HOST_ONLY))
+ #define USB_CAN_BE_BOTH
+ #define USB_CAN_BE_HOST
+ #define USB_CAN_BE_DEVICE
+ #elif defined(USB_HOST_ONLY)
+ #define USB_CAN_BE_HOST
+ #elif defined(USB_DEVICE_ONLY)
+ #define USB_CAN_BE_DEVICE
+ #endif
+
+ #if (defined(USB_HOST_ONLY) && defined(USB_DEVICE_ONLY))
+ #error USB_HOST_ONLY and USB_DEVICE_ONLY are mutually exclusive.
+ #endif
+ #endif
+
+#endif
+
/** @} */
\ No newline at end of file