aboutsummaryrefslogtreecommitdiffstats
path: root/Projects/AVRISP-MKII/Lib/ISP/ISPProtocol.h
diff options
context:
space:
mode:
authorDean Camera <dean@fourwalledcubicle.com>2019-01-08 19:52:34 +1100
committerDean Camera <dean@fourwalledcubicle.com>2019-01-08 19:52:34 +1100
commite1886429972095e7d453adcbdb26910f94c29ffd (patch)
treea50d08711be5ce3d5098125aea9f1fb7cd690cb6 /Projects/AVRISP-MKII/Lib/ISP/ISPProtocol.h
parentb0c8a5d342626ab2e92608e2f91784f3bcce6f47 (diff)
downloadlufa-e1886429972095e7d453adcbdb26910f94c29ffd.tar.gz
lufa-e1886429972095e7d453adcbdb26910f94c29ffd.tar.bz2
lufa-e1886429972095e7d453adcbdb26910f94c29ffd.zip
AVRISP-MKII Clone: Clean up ISP driver code, namespace module variables.
Diffstat (limited to 'Projects/AVRISP-MKII/Lib/ISP/ISPProtocol.h')
-rw-r--r--Projects/AVRISP-MKII/Lib/ISP/ISPProtocol.h17
1 files changed, 17 insertions, 0 deletions
diff --git a/Projects/AVRISP-MKII/Lib/ISP/ISPProtocol.h b/Projects/AVRISP-MKII/Lib/ISP/ISPProtocol.h
index 7bf2ff7b5..0a84e044b 100644
--- a/Projects/AVRISP-MKII/Lib/ISP/ISPProtocol.h
+++ b/Projects/AVRISP-MKII/Lib/ISP/ISPProtocol.h
@@ -38,6 +38,7 @@
/* Includes: */
#include <avr/io.h>
+ #include <util/atomic.h>
#include <util/delay.h>
#include <LUFA/Drivers/USB/USB.h>
@@ -45,6 +46,22 @@
#include "../V2Protocol.h"
#include "Config/AppConfig.h"
+ /* Macros: */
+ /** Calibration clock frequency for target OSCCAL calibration, see AVR053 application note. */
+ #define ISPPROTOCOL_CALIB_CLOCK_HZ 32768
+
+ /** Internal timer ticks per calibration clock cycle, see AVR053 application note. */
+ #define ISPPROTOCOL_CALIB_TICKS ( (F_CPU + ISPPROTOCOL_CALIB_CLOCK_HZ) / (2 * ISPPROTOCOL_CALIB_CLOCK_HZ) )
+
+ /** Per AVR053, calibration guaranteed to take 1024 cycles (2048 half-cycles) or fewer;
+ * add some cycles for response delay (5-10 after success) and response itself.
+ */
+ #define ISPPROTOCOL_CALIB_HALF_CYCLE_LIMIT (2*1024 + 50)
+
+ /** Per AVR053, target will toggle I/O pin 8 times to indicate a successful clock calibration.
+ */
+ #define ISPPROTOCOL_CALIB_SUCCESS_TOGGLE_NUM 8
+
/* Preprocessor Checks: */
#if ((BOARD == BOARD_XPLAIN) || (BOARD == BOARD_XPLAIN_REV1))
#undef ENABLE_ISP_PROTOCOL