3      Copyright (C) Dean Camera, 2009. 
   5   dean [at] fourwalledcubicle [dot] com 
   6       www.fourwalledcubicle.com 
  10   Copyright 2009  Dean Camera (dean [at] fourwalledcubicle [dot] com) 
  12   Permission to use, copy, modify, and distribute this software 
  13   and its documentation for any purpose and without fee is hereby 
  14   granted, provided that the above copyright notice appear in all 
  15   copies and that both that the copyright notice and this 
  16   permission notice and warranty disclaimer appear in supporting 
  17   documentation, and that the name of the author not be used in 
  18   advertising or publicity pertaining to distribution of the 
  19   software without specific, written prior permission. 
  21   The author disclaim all warranties with regard to this 
  22   software, including all implied warranties of merchantability 
  23   and fitness.  In no event shall the author be liable for any 
  24   special, indirect or consequential damages or any damages 
  25   whatsoever resulting from loss of use, data or profits, whether 
  26   in an action of contract, negligence or other tortious action, 
  27   arising out of or in connection with the use or performance of 
  33  *  Header file for PDITarget.c. 
  41                 #include <avr/interrupt.h> 
  44                 #include <LUFA/Common/Common.h> 
  46         /* Preprocessor Checks: */ 
  47                 #if ((BOARD == BOARD_XPLAIN) || (BOARD == BOARD_XPLAIN_REV1)) 
  48                         #undef ENABLE_ISP_PROTOCOL 
  50                         #if !defined(ENABLE_PDI_PROTOCOL) 
  51                                 #define ENABLE_PDI_PROTOCOL 
  56                 #if ((BOARD == BOARD_XPLAIN) || (BOARD == BOARD_XPLAIN_REV1)) 
  57                         #define PDI_VIA_HARDWARE_USART 
  59                         #define BITBANG_PDIDATA_PORT     PORTB 
  60                         #define BITBANG_PDIDATA_DDR      DDRB 
  61                         #define BITBANG_PDIDATA_PIN      PINB 
  62                         #define BITBANG_PDIDATA_MASK     (1 << 3) 
  64                         #define BITBANG_PDICLOCK_PORT    RESET_LINE_PORT 
  65                         #define BITBANG_PDICLOCK_DDR     RESET_LINE_DDR 
  66                         #define BITBANG_PDICLOCK_PIN     RESET_LINE_PIN 
  67                         #define BITBANG_PDICLOCK_MASK    RESET_LINE_MASK 
  70                 #define BITS_IN_FRAME            12 
  72                 #define PDI_NVM_TIMEOUT_MS       200 
  74                 #define PDI_CMD_LDS              0x00 
  75                 #define PDI_CMD_LD               0x20 
  76                 #define PDI_CMD_STS              0x40 
  77                 #define PDI_CMD_ST               0x60 
  78                 #define PDI_CMD_LDCS             0x80 
  79                 #define PDI_CMD_REPEAT           0xA0 
  80                 #define PDI_CMD_STCS             0xC0 
  81                 #define PDI_CMD_KEY              0xE0 
  83                 #define PDI_STATUS_REG           0 
  84                 #define PDI_RESET_REG            1 
  85                 #define PDI_CTRL_REG             2 
  87                 #define PDI_STATUS_NVM           (1 << 1) 
  88                 #define PDI_RESET_KEY            0x59 
  90                 #define PDI_NVMENABLE_KEY        (uint8_t[]){0x12, 0x89, 0xAB, 0x45, 0xCD, 0xD8, 0x88, 0xFF} 
  92                 #define PDI_DATSIZE_1BYTE        0 
  93                 #define PDI_DATSIZE_2BYTES       1 
  94                 #define PDI_DATSIZE_3BYTES       2 
  95                 #define PDI_DATSIZE_4BYTES       3 
  97                 #define PDI_POINTER_INDIRECT     0 
  98                 #define PDI_POINTER_INDIRECT_PI  1 
  99                 #define PDI_POINTER_DIRECT       2 
 101         /* Function Prototypes: */ 
 102                 void    PDITarget_EnableTargetPDI(void); 
 103                 void    PDITarget_DisableTargetPDI(void); 
 104                 void    PDITarget_SendByte(const uint8_t Byte
); 
 105                 uint8_t PDITarget_ReceiveByte(void); 
 106                 void    PDITarget_SendBreak(void); 
 107                 bool    PDITarget_WaitWhileNVMBusBusy(void);