Cleaner error message for failing to print the radio state.
[goodfet] / client / goodfet.cc
1 #!/usr/bin/env python
2 # GoodFET Chipcon Example
3
4 # (C) 2009 Travis Goodspeed <travis at radiantmachines.com>
5 #
6 # This code is being rewritten and refactored.  You've been warned!
7
8 import sys;
9 import binascii;
10
11 from GoodFETCC import GoodFETCC;
12 from GoodFETConsole import GoodFETConsole;
13 from intelhex import IntelHex;
14
15 if(len(sys.argv)==1):
16     print "Usage: %s verb [objects]\n" % sys.argv[0];
17     print "%s erase" % sys.argv[0];
18     print "%s flash $foo.hex" % sys.argv[0];
19     print "%s test" % sys.argv[0];
20     print "%s term" % sys.argv[0];
21     print "%s info" % sys.argv[0];
22     print "%s radioinfo" % sys.argv[0];
23     print "%s dumpcode $foo.hex [0x$start 0x$stop]" % sys.argv[0];
24     print "%s dumpdata $foo.hex [0x$start 0x$stop]" % sys.argv[0];
25     print "%s writedata $foo.hex [0x$start 0x$stop]" % sys.argv[0];
26     print "%s verify $foo.hex [0x$start 0x$stop]" % sys.argv[0];
27     print "%s peekdata 0x$start [0x$stop]" % sys.argv[0];
28     print "%s pokedata 0x$adr 0x$val" % sys.argv[0];
29     print "%s peek 0x$iram" % sys.argv[0];
30     print "%s poke 0x$iram 0x$val" % sys.argv[0];
31     print "%s peekcode 0x$start [0x$stop]" % sys.argv[0];
32     sys.exit();
33
34 #Initailize FET and set baud rate
35 #client=GoodFET.GoodFETCC.GoodFETCC();
36 client=GoodFETCC();
37 client.serInit()
38
39 #Connect to target
40 client.setup();
41 client.start();
42
43
44 if(sys.argv[1]=="explore"):
45     print "Exploring undefined commands."
46     print "Status: %s" %client.status();
47     
48     cmd=0x04; #read status
49     for foo in range(0,0x5):
50         client.CCcmd([(0x0F<<3)|(0x00)|0x03,0x09<<3]);
51         print "Status %02x: %s" % (foo,client.status());
52     for foo in range(0,3):
53         print "PC: %04x" % client.CCgetPC();
54 if(sys.argv[1]=="term"):
55     GoodFETConsole(client).run();
56 if(sys.argv[1]=="test"):
57     client.test();
58 if(sys.argv[1]=="deadtest"):
59     for i in range(1,10):
60         print "IDENT as %s" % client.CCidentstr();
61 if(sys.argv[1]=="dumpcode"):
62     f = sys.argv[2];
63     start=0x0000;
64     stop=0xFFFF;
65     if(len(sys.argv)>3):
66         start=int(sys.argv[3],16);
67     if(len(sys.argv)>4):
68         stop=int(sys.argv[4],16);
69     
70     print "Dumping code from %04x to %04x as %s." % (start,stop,f);
71     h = IntelHex(None);
72     i=start;
73     while i<=stop:
74         h[i]=client.CCpeekcodebyte(i);
75         if(i%0x100==0):
76             print "Dumped %04x."%i;
77         i+=1;
78     h.write_hex_file(f);
79 if(sys.argv[1]=="dumpdata"):
80     f = sys.argv[2];
81     start=0xE000;
82     stop=0xFFFF;
83     if(len(sys.argv)>3):
84         start=int(sys.argv[3],16);
85     if(len(sys.argv)>4):
86         stop=int(sys.argv[4],16);
87     
88     print "Dumping data from %04x to %04x as %s." % (start,stop,f);
89     h = IntelHex(None);
90     i=start;
91     while i<=stop:
92         h[i]=client.CCpeekdatabyte(i);
93         if(i%0x100==0):
94             print "Dumped %04x."%i;
95         i+=1;
96     h.write_hex_file(f);
97 if(sys.argv[1]=="status"):
98     print "Status: %s" %client.status();
99 if(sys.argv[1]=="info"):
100     print "%s" % client.CCidentstr();
101 if(sys.argv[1]=="radioinfo"):
102     client.CMDrs();
103 if(sys.argv[1]=="erase"):
104     print "Status: %s" % client.status();
105     client.CCchiperase();
106     print "Status: %s" %client.status();
107
108 if(sys.argv[1]=="peekinfo"):
109     print "Select info flash."
110     client.CCwr_config(1);
111     print "Config is %02x" % client.CCrd_config();
112     
113     start=0x0000;
114     if(len(sys.argv)>2):
115         start=int(sys.argv[2],16);
116     stop=start;
117     if(len(sys.argv)>3):
118         stop=int(sys.argv[3],16);
119     print "Peeking from %04x to %04x." % (start,stop);
120     while start<=stop:
121         print "%04x: %02x" % (start,client.CCpeekcodebyte(start));
122         start=start+1;
123 if(sys.argv[1]=="poke"):
124     client.CCpokeirambyte(int(sys.argv[2],16),
125                           int(sys.argv[3],16));
126 if(sys.argv[1]=="randtest"):
127     #Seed RNG
128     client.CCpokeirambyte(0xBD,0x01); #RNDH=0x01
129     client.CCpokeirambyte(0xB4,0x04); #ADCCON1=0x04
130     client.CCpokeirambyte(0xBD,0x01); #RNDH=0x01
131     client.CCpokeirambyte(0xB4,0x04); #ADCCON1=0x04
132     
133     #Dump values
134     for foo in range(1,10):
135         print "%02x" % client.CCpeekirambyte(0xBD); #RNDH
136         client.CCpokeirambyte(0xB4,0x04); #ADCCON1=0x04
137         client.CCreleasecpu();
138         client.CChaltcpu();
139     print "%02x" % client.CCpeekdatabyte(0xDF61); #CHIP ID
140 if(sys.argv[1]=="adctest"):
141     # ADCTest 0xDF3A 0xDF3B
142     print "ADC TEST %02x%02x" % (
143         client.CCpeekdatabyte(0xDF3A),
144         client.CCpeekdatabyte(0xDF3B));
145 if(sys.argv[1]=="config"):
146     print "Config is %02x" % client.CCrd_config();
147
148 if(sys.argv[1]=="flash"):
149      f=sys.argv[2];
150      start=0;
151      stop=0xFFFF;
152      if(len(sys.argv)>3):
153          start=int(sys.argv[3],16);
154      if(len(sys.argv)>4):
155          stop=int(sys.argv[4],16);
156    
157      client.flash(f);
158 if(sys.argv[1]=="lock"):
159     print "Status: %s" %client.status();
160     client.CClockchip();
161     print "Status: %s" %client.status();
162 if(sys.argv[1]=="flashpage"):
163     target=0;
164     if(len(sys.argv)>2):
165         target=int(sys.argv[2],16);
166     print "Writing a page of flash from 0xF000 in XDATA"
167     client.CCflashpage(target);
168 if(sys.argv[1]=="erasebuffer"):
169     print "Erasing flash buffer.";
170     client.CCeraseflashbuffer();
171
172 if(sys.argv[1]=="writedata"):
173     f=sys.argv[2];
174     start=0;
175     stop=0xFFFF;
176     if(len(sys.argv)>3):
177         start=int(sys.argv[3],16);
178     if(len(sys.argv)>4):
179         stop=int(sys.argv[4],16);
180     
181     h = IntelHex(f);
182     
183     for i in h._buf.keys():
184         if(i>=start and i<=stop):
185             client.CCpokedatabyte(i,h[i]);
186             if(i%0x100==0):
187                 print "%04x" % i;
188 #if(sys.argv[1]=="flashtest"):
189 #    client.CCflashtest();
190 if(sys.argv[1]=="peekdata"):
191     start=0x0000;
192     if(len(sys.argv)>2):
193         start=int(sys.argv[2],16);
194     stop=start;
195     if(len(sys.argv)>3):
196         stop=int(sys.argv[3],16);
197     print "Peeking from %04x to %04x." % (start,stop);
198     while start<=stop:
199         print "%04x: %02x" % (start,client.CCpeekdatabyte(start));
200         start=start+1;
201 if(sys.argv[1]=="peek"):
202     start=0x0000;
203     if(len(sys.argv)>2):
204         start=int(sys.argv[2],16);
205     stop=start;
206     if(len(sys.argv)>3):
207         stop=int(sys.argv[3],16);
208     print "Peeking from %04x to %04x." % (start,stop);
209     while start<=stop:
210         print "%04x: %02x" % (start,client.CCpeekirambyte(start));
211         start=start+1;
212 if(sys.argv[1]=="verify"):
213     f=sys.argv[2];
214     start=0;
215     stop=0xFFFF;
216     if(len(sys.argv)>3):
217         start=int(sys.argv[3],16);
218     if(len(sys.argv)>4):
219         stop=int(sys.argv[4],16);
220     
221     h = IntelHex(f);
222     for i in h._buf.keys():
223         if(i>=start and i<stop):
224             peek=client.CCpeekcodebyte(i)
225             if(h[i]!=peek):
226                 print "ERROR at %04x, found %02x not %02x"%(i,peek,h[i]);
227             if(i%0x100==0):
228                 print "%04x" % i;
229 if(sys.argv[1]=="peekcode"):
230     start=0x0000;
231     if(len(sys.argv)>2):
232         start=int(sys.argv[2],16);
233     stop=start;
234     if(len(sys.argv)>3):
235         stop=int(sys.argv[3],16);
236     print "Peeking from %04x to %04x." % (start,stop);
237     while start<=stop:
238         print "%04x: %02x" % (start,client.CCpeekcodebyte(start));
239         start=start+1;
240 if(sys.argv[1]=="pokedata"):
241     start=0x0000;
242     val=0x00;
243     if(len(sys.argv)>2):
244         start=int(sys.argv[2],16);
245     if(len(sys.argv)>3):
246         val=int(sys.argv[3],16);
247     print "Poking %04x to become %02x." % (start,val);
248     client.CCpokedatabyte(start,val);
249
250 client.stop();