1 // Command handling functions.
3 //! Global data buffer.
4 extern unsigned char cmddata[256];
5 #define cmddataword ((unsigned int*) cmddata)
6 #define cmddatalong ((unsigned long*) cmddata)
7 #define memorybyte ((unsigned char*) 0)
8 #define memoryword ((unsigned int*) 0)
22 #define MONITOR_CHANGE_BAUD 0x80
23 #define MONITOR_RAM_PATTERN 0x90
24 #define MONITOR_RAM_DEPTH 0x91
26 #define MONITOR_DIR 0xA0
27 #define MONITOR_OUT 0xA1
28 #define MONITOR_IN 0xA2
31 #define CC_CHIP_ERASE 0x80
32 #define CC_WR_CONFIG 0x81
33 #define CC_RD_CONFIG 0x82
34 #define CC_GET_PC 0x83
35 #define CC_READ_STATUS 0x84
36 #define CC_SET_HW_BRKPNT 0x85
38 #define CC_RESUME 0x87
39 #define CC_DEBUG_INSTR 0x88
40 #define CC_STEP_INSTR 0x89
41 #define CC_STEP_REPLACE 0x8a
42 #define CC_GET_CHIP_ID 0x8b
44 #define CC_READ_CODE_MEMORY 0x90
45 #define CC_READ_XDATA_MEMORY 0x91
46 #define CC_WRITE_XDATA_MEMORY 0x92
47 #define CC_SET_PC 0x93
48 #define CC_CLOCK_INIT 0x94
49 #define CC_WRITE_FLASH_PAGE 0x95
50 #define CC_READ_FLASH_PAGE 0x96
51 #define CC_MASS_ERASE_FLASH 0x97
52 #define CC_PROGRAM_FLASH 0x98
55 #define JTAG_IR_SHIFT 0x80
56 #define JTAG_DR_SHIFT 0x81
57 #define JTAG_DR_SHIFT20 0x91
60 #define SPI_JEDEC 0x80
61 #define SPI_ERASE 0x81
68 #define JTAG430_HALTCPU 0xA0
69 #define JTAG430_RELEASECPU 0xA1
70 #define JTAG430_SETINSTRFETCH 0xC1
71 #define JTAG430_SETPC 0xC2
72 #define JTAG430_WRITEMEM 0xE0
73 #define JTAG430_WRITEFLASH 0xE1
74 #define JTAG430_READMEM 0xE2
75 #define JTAG430_ERASEFLASH 0xE3
76 #define JTAG430_ERASECHECK 0xE4
77 #define JTAG430_VERIFYMEM 0xE5
78 #define JTAG430_BLOWFUSE 0xE6
79 #define JTAG430_ISFUSEBLOWN 0xE7
80 #define JTAG430_COREIP_ID 0xF0
81 #define JTAG430_DEVICE_ID 0xF1
83 //! Handle a command. Defined in goodfet.c
84 void handle(unsigned char app,
89 void txdata(unsigned char app,
92 //! Transmit a string.
93 void txstring(unsigned char app,
98 void delay(unsigned int count);
100 void msdelay(unsigned int ms);
103 void monitorhandle(unsigned char, unsigned char, unsigned char);
104 void spihandle(unsigned char, unsigned char, unsigned char);
105 void i2chandle(unsigned char, unsigned char, unsigned char);
106 void cchandle(unsigned char, unsigned char, unsigned char);
107 void jtaghandle(unsigned char, unsigned char, unsigned char);
108 void jtag430handle(unsigned char, unsigned char, unsigned char);
109 void jtag430x2handle(unsigned char app, unsigned char verb,