X-Git-Url: http://git.linex4red.de/pub/USBasp.git/blobdiff_plain/071e02c6b6b4837fa9cf0b6d4c749994e02638d7..857641b98e0ad1f7d30ae1fc8fc63f97018ae711:/Projects/AVRISP-MKII/Lib/XPROG/XPROGTarget.h diff --git a/Projects/AVRISP-MKII/Lib/XPROG/XPROGTarget.h b/Projects/AVRISP-MKII/Lib/XPROG/XPROGTarget.h index 436f0f30d..2df1e38a1 100644 --- a/Projects/AVRISP-MKII/Lib/XPROG/XPROGTarget.h +++ b/Projects/AVRISP-MKII/Lib/XPROG/XPROGTarget.h @@ -1,21 +1,21 @@ /* LUFA Library - Copyright (C) Dean Camera, 2010. - + Copyright (C) Dean Camera, 2012. + dean [at] fourwalledcubicle [dot] com - www.fourwalledcubicle.com + www.lufa-lib.org */ /* - Copyright 2010 Dean Camera (dean [at] fourwalledcubicle [dot] com) + Copyright 2012 Dean Camera (dean [at] fourwalledcubicle [dot] com) - Permission to use, copy, modify, distribute, and sell this + 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 + 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 + 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 @@ -40,27 +40,28 @@ #include #include #include - + #include - + #include "../V2Protocol.h" #include "XPROGProtocol.h" - + #include "Config/AppConfig.h" + /* Preprocessor Checks: */ #if ((BOARD == BOARD_XPLAIN) || (BOARD == BOARD_XPLAIN_REV1)) #undef ENABLE_ISP_PROTOCOL - + #if !defined(ENABLE_XPROG_PROTOCOL) #define ENABLE_XPROG_PROTOCOL #endif #endif - - /** Serial carrier TPI/PDI speed when hardware TPI/PDI mode is used */ - #define XPROG_HARDWARE_SPEED 1000000 - /** Total number of bits in a single USART frame */ + /** Serial carrier TPI/PDI speed in Hz, when hardware TPI/PDI mode is used. */ + #define XPROG_HARDWARE_SPEED 250000 + + /** Total number of bits in a single USART frame. */ #define BITS_IN_USART_FRAME 12 - + #define PDI_CMD_LDS 0x00 #define PDI_CMD_LD 0x20 #define PDI_CMD_STS 0x40 @@ -69,11 +70,11 @@ #define PDI_CMD_REPEAT 0xA0 #define PDI_CMD_STCS 0xC0 #define PDI_CMD_KEY 0xE0 - + #define PDI_STATUS_REG 0 #define PDI_RESET_REG 1 #define PDI_CTRL_REG 2 - + #define PDI_STATUS_NVM (1 << 1) #define PDI_RESET_KEY 0x59 @@ -83,7 +84,7 @@ #define PDI_DATSIZE_2BYTES 1 #define PDI_DATSIZE_3BYTES 2 #define PDI_DATSIZE_4BYTES 3 - + #define PDI_POINTER_INDIRECT 0 #define PDI_POINTER_INDIRECT_PI 1 #define PDI_POINTER_DIRECT 2 @@ -100,14 +101,14 @@ #define TPI_STATUS_REG 0x00 #define TPI_CTRL_REG 0x02 #define TPI_ID_REG 0x0F - + #define TPI_STATUS_NVM (1 << 1) #define TPI_NVMENABLE_KEY (uint8_t[]){0x12, 0x89, 0xAB, 0x45, 0xCD, 0xD8, 0x88, 0xFF} #define TPI_POINTER_INDIRECT 0 #define TPI_POINTER_INDIRECT_PI 4 - + /* Function Prototypes: */ void XPROGTarget_EnableTargetPDI(void); void XPROGTarget_EnableTargetTPI(void); @@ -115,12 +116,13 @@ void XPROGTarget_DisableTargetTPI(void); void XPROGTarget_SendByte(const uint8_t Byte); uint8_t XPROGTarget_ReceiveByte(void); - void XPROGTarget_SendBreak(void); + void XPROGTarget_SendIdle(void); bool XPROGTarget_WaitWhileNVMBusBusy(void); - - #if defined(INCLUDE_FROM_XPROGTARGET_C) + + #if (defined(INCLUDE_FROM_XPROGTARGET_C) && defined(ENABLE_XPROG_PROTOCOL)) static void XPROGTarget_SetTxMode(void); static void XPROGTarget_SetRxMode(void); #endif #endif +