Add more information on the integrated Help package to the Atmel Studio Getting Start...
[pub/USBasp.git] / Projects / AVRISP-MKII / Lib / V2ProtocolParams.h
index bfbd357..09c092d 100644 (file)
@@ -1,82 +1,91 @@
-/*\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, 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
- *\r
- *  Header file for V2ProtocolParams.c.\r
- */\r
-\r
-#ifndef _V2_PROTOCOL_PARAMS_\r
-#define _V2_PROTOCOL_PARAMS_\r
-\r
-       /* Includes: */\r
-               #include <avr/io.h>\r
-               #include <avr/eeprom.h>\r
-\r
-               #include <LUFA/Version.h>\r
-\r
-               #if defined(ADC)\r
-                       #include <LUFA/Drivers/Peripheral/ADC.h>\r
-               #endif\r
-               \r
-               #include "V2Protocol.h"\r
-               #include "V2ProtocolConstants.h"\r
-               #include "ISP/ISPTarget.h"\r
-\r
-       /* Macros: */\r
-               /** Parameter privilege mask to allow the host PC to read the parameter's value */\r
-               #define PARAM_PRIV_READ   (1 << 0)\r
-\r
-               /** Parameter privilege mask to allow the host PC to change the parameter's value */\r
-               #define PARAM_PRIV_WRITE  (1 << 1)\r
-\r
-       /* Type Defines: */\r
-               /** Type define for a parameter table entry indicating a PC readable or writable device parameter. */\r
-               typedef struct\r
-               {\r
-                       const uint8_t ParamID; /**< Parameter ID number to uniquely identify the parameter within the device */\r
-                       const uint8_t ParamPrivileges;  /**< Parameter privileges to allow the host to read or write the parameter's value */\r
-                       uint8_t ParamValue; /**< Current parameter's value within the device */\r
-               } ParameterItem_t;\r
-\r
-       /* Function Prototypes: */\r
-               void    V2Params_LoadNonVolatileParamValues(void);\r
-               void    V2Params_UpdateParamValues(void);\r
-       \r
-               uint8_t V2Params_GetParameterPrivileges(const uint8_t ParamID);\r
-               uint8_t V2Params_GetParameterValue(const uint8_t ParamID);\r
-               void    V2Params_SetParameterValue(const uint8_t ParamID, const uint8_t Value);\r
-               \r
-               #if defined(INCLUDE_FROM_V2PROTOCOL_PARAMS_C)\r
-                       static ParameterItem_t* V2Params_GetParamFromTable(const uint8_t ParamID);\r
-               #endif\r
-\r
-#endif\r
-\r
+/*
+             LUFA Library
+     Copyright (C) Dean Camera, 2013.
+
+  dean [at] fourwalledcubicle [dot] com
+           www.lufa-lib.org
+*/
+
+/*
+  Copyright 2013  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 disclaims 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
+ *
+ *  Header file for V2ProtocolParams.c.
+ */
+
+#ifndef _V2_PROTOCOL_PARAMS_
+#define _V2_PROTOCOL_PARAMS_
+
+       /* Includes: */
+               #include <avr/io.h>
+               #include <avr/eeprom.h>
+
+               #if defined(ADC)
+                       #include <LUFA/Drivers/Peripheral/ADC.h>
+               #endif
+
+               #include "V2Protocol.h"
+               #include "V2ProtocolConstants.h"
+               #include "ISP/ISPTarget.h"
+               #include "Config/AppConfig.h"
+
+       /* Macros: */
+               /** Parameter privilege mask to allow the host PC to read the parameter's value. */
+               #define PARAM_PRIV_READ     (1 << 0)
+
+               /** Parameter privilege mask to allow the host PC to change the parameter's value. */
+               #define PARAM_PRIV_WRITE    (1 << 1)
+
+               /** Total number of parameters in the parameter table */
+               #define TABLE_PARAM_COUNT   (sizeof(ParameterTable) / sizeof(ParameterTable[0]))
+
+               #if (!defined(FIRMWARE_VERSION_MINOR) || defined(__DOXYGEN__))
+                       /** Minor firmware version, reported to the host on request; must match the version
+                        *  the host is expecting, or it (may) reject further communications with the programmer. */
+                       #define FIRMWARE_VERSION_MINOR   0x16
+               #endif
+
+       /* Type Defines: */
+               /** Type define for a parameter table entry indicating a PC readable or writable device parameter. */
+               typedef struct
+               {
+                       const uint8_t ParamID; /**< Parameter ID number to uniquely identify the parameter within the device */
+                       const uint8_t ParamPrivileges;  /**< Parameter privileges to allow the host to read or write the parameter's value */
+                       uint8_t ParamValue; /**< Current parameter's value within the device */
+               } ParameterItem_t;
+
+       /* Function Prototypes: */
+               void    V2Params_LoadNonVolatileParamValues(void);
+               void    V2Params_UpdateParamValues(void);
+
+               uint8_t V2Params_GetParameterPrivileges(const uint8_t ParamID);
+               uint8_t V2Params_GetParameterValue(const uint8_t ParamID);
+               void    V2Params_SetParameterValue(const uint8_t ParamID,
+                                                  const uint8_t Value);
+
+               #if defined(INCLUDE_FROM_V2PROTOCOL_PARAMS_C)
+                       static ParameterItem_t* const V2Params_GetParamFromTable(const uint8_t ParamID);
+               #endif
+
+#endif
+