+if(sys.argv[1]=="erase"):
+ client.MSP430masserase();
+if(sys.argv[1]=="ivt"):
+ client.MSP430dumpmem(0xFFE0,0xFFFF);
+if(sys.argv[1]=="flash"):
+ f=sys.argv[2];
+ start=0;
+ stop=0xFFFF;
+ if(len(sys.argv)>3):
+ start=int(sys.argv[3],16);
+ if(len(sys.argv)>4):
+ stop=int(sys.argv[4],16);
+
+ h = IntelHex16bit(f);
+
+ client.MSP430masserase();
+ for i in h._buf.keys():
+ #print "%04x: %04x"%(i,h[i>>1]);
+ if(i>=start and i<stop and i&1==0):
+ client.MSP430writeflash(i,h[i>>1]);
+ if(i%0x100==0):
+ print "%04x" % i;
+if(sys.argv[1]=="flashtest"):
+ client.MSP430flashtest();
+if(sys.argv[1]=="verify"):
+ f=sys.argv[2];
+ start=0;
+ stop=0xFFFF;
+ if(len(sys.argv)>3):
+ start=int(sys.argv[3],16);
+ if(len(sys.argv)>4):
+ stop=int(sys.argv[4],16);
+
+ h = IntelHex16bit(f);
+ for i in h._buf.keys():
+ if(i>=start and i<stop and i&1==0):
+ peek=client.MSP430peek(i)
+ if(h[i>>1]!=peek):
+ print "ERROR at %04x, found %04x not %04x"%(i,peek,h[i>>1]);
+ if(i%0x100==0):
+ print "%04x" % i;
+if(sys.argv[1]=="peek"):
+ start=0x0000;
+ if(len(sys.argv)>2):
+ start=int(sys.argv[2],16);
+ stop=start;
+ if(len(sys.argv)>3):
+ stop=int(sys.argv[3],16);
+ print "Peeking from %04x to %04x." % (start,stop);
+ while start<=stop:
+ print "%04x: %04x" % (start,client.MSP430peek(start));
+ start=start+2;
+if(sys.argv[1]=="poke"):
+ start=0x0000;
+ val=0x00;
+ if(len(sys.argv)>2):
+ start=int(sys.argv[2],16);
+ if(len(sys.argv)>3):
+ val=int(sys.argv[3],16);
+ print "Poking %06x to become %02x." % (start,val);
+
+ while client.MSP430peek(start)!=val:
+ client.MSP430poke(start,val);
+ print "Poked to %04x" % client.MSP430peek(start);
+
+
+
+if(sys.argv[1]=="whatever"):
+ for i in [0x24FF, 0x2500, 0x2502, 0x2504]:
+ print "%04x" % client.MSP430peek(i);
+
+client.MSP430releasecpu();