Fast MSP430 Flash writes.
[goodfet] / client / goodfet.msp430
1 #!/usr/bin/env python
2
3 import sys;
4 import binascii;
5
6 from GoodFETMSP430 import GoodFETMSP430;
7 from intelhex import IntelHex16bit, IntelHex;
8
9
10
11 if(len(sys.argv)==1):
12     print "Usage: %s verb [objects]\n" % sys.argv[0];
13     print "%s test" % sys.argv[0];
14     print "%s dump $foo.hex [0x$start 0x$stop]" % sys.argv[0];
15     print "%s erase" % sys.argv[0];
16     print "%s flash $foo.hex [0x$start 0x$stop]" % sys.argv[0];
17     print "%s verify $foo.hex [0x$start 0x$stop]" % sys.argv[0];
18     sys.exit();
19
20 #Initialize FET and set baud rate
21 client=GoodFETMSP430();
22 client.serInit()
23
24 #Connect to target
25 client.MSP430setup();
26 #print "setup"
27
28 #Identify model number.
29 client.MSP430start();
30 client.MSP430haltcpu();
31 #print "started"
32
33 if(sys.argv[1]=="info"):
34     #print "Model    %08x " % client.MSP430deviceid();
35     #print "Core     %04x " % client.MSP430coreid();
36     #print "Identity %04x" % client.MSP430ident();
37     print "Identifies as %s (%04x)" % (
38         client.MSP430identstr(),
39         client.MSP430ident());
40 if(sys.argv[1]=="test"):
41     client.MSP430test();
42 if(sys.argv[1]=="glitch"):
43     for foo in range(0,100):
44         print "Identifies as %04x" % client.MSP430ident();
45 if(sys.argv[1]=="dump"):
46     f = sys.argv[2];
47     start=0x0200;
48     stop=0xFFFF;
49     if(len(sys.argv)>3):
50         start=int(sys.argv[3],16);
51     if(len(sys.argv)>4):
52         stop=int(sys.argv[4],16);
53     
54     print "Dumping from %04x to %04x as %s." % (start,stop,f);
55     #h = IntelHex16bit(None);
56     h = IntelHex(None);
57     i=start;
58     while i<=stop:
59         data=client.MSP430peekblock(i);
60         print "Dumped %06x."%i;
61         for j in data:
62             if i<=stop: h[i]=ord(j);
63             i+=1;
64     h.write_hex_file(f);
65 if(sys.argv[1]=="erase"):
66     client.MSP430masserase();
67 if(sys.argv[1]=="ivt"):
68     client.MSP430dumpmem(0xFFE0,0xFFFF);
69 if(sys.argv[1]=="flash"):
70     f=sys.argv[2];
71     start=0;
72     stop=0xFFFF;
73     if(len(sys.argv)>3):
74         start=int(sys.argv[3],16);
75     if(len(sys.argv)>4):
76         stop=int(sys.argv[4],16);
77     
78     h = IntelHex16bit(f);
79     
80     #Should this be default?
81     #Makes flashing multiple images inconvenient.
82     client.MSP430masserase();
83     
84     count=0; #Bytes in commit.
85     first=0;
86     vals=[];
87     last=0;  #Last address committed.
88     for i in h._buf.keys():
89         if((count>0x40 or last+2!=i) and count>0 and i&1==0):
90             #print "%i, %x, %x" % (len(vals), last, i);
91             client.MSP430pokeflashblock(first,vals);
92             count=0;
93             first=0;
94             last=0;
95             vals=[];
96         if(i>=start and i<stop  and i&1==0):
97             val=h[i>>1];
98             if(count==0):
99                 first=i;
100             last=i;
101             count+=2;
102             #val2=client.MSP430pokeflash(i,val);
103             #if(val!=val2):
104             #    print "Write error at %04x, %04x!=%04x." %(
105             #        i, val, val2);
106             vals+=[val&0xff,(val&0xff00)>>8];
107             if(i%0x100==0):
108                 print "%04x" % i;
109     if count>0: #last commit, ivt
110         client.MSP430pokeflashblock(first,vals);
111 if(sys.argv[1]=="verify"):
112     f=sys.argv[2];
113     start=0;
114     stop=0xFFFF;
115     if(len(sys.argv)>3):
116         start=int(sys.argv[3],16);
117     if(len(sys.argv)>4):
118         stop=int(sys.argv[4],16);
119     
120     h = IntelHex16bit(f);
121     for i in h._buf.keys():
122         if(i>=start and i<stop and i&1==0):
123             peek=client.MSP430peek(i)
124             if(h[i>>1]!=peek):
125                 print "ERROR at %04x, found %04x not %04x"%(i,peek,h[i>>1]);
126             if(i%0x100==0):
127                 print "%04x" % i;
128 if(sys.argv[1]=="peek"):
129     start=0x0000;
130     if(len(sys.argv)>2):
131         start=int(sys.argv[2],16);
132     stop=start;
133     if(len(sys.argv)>3):
134         stop=int(sys.argv[3],16);
135     print "Peeking from %04x to %04x." % (start,stop);
136     while start<=stop:
137         print "%04x: %04x" % (start,client.MSP430peek(start));
138         start=start+2;
139
140 if(sys.argv[1]=="poke"):
141     start=0x0000;
142     val=0x00;
143     if(len(sys.argv)>2):
144         start=int(sys.argv[2],16);
145     if(len(sys.argv)>3):
146         val=int(sys.argv[3],16);
147     print "Poking %06x to become %04x." % (start,val);
148     
149     while client.MSP430peek(start)!=val:
150         client.MSP430pokeflash(start,val);
151         print "Poked to %04x" % client.MSP430peek(start);
152
153
154
155 if(sys.argv[1]=="whatever"):
156     for i in [0x24FF, 0x2500, 0x2502, 0x2504]:
157         print "%04x" % client.MSP430peek(i);
158
159 client.MSP430releasecpu();
160 client.MSP430stop();