X-Git-Url: http://git.rot13.org/?p=goodfet;a=blobdiff_plain;f=client%2Fgoodfet.cc;h=3b97280ec42891c5216e1a38343d9bc7ca0b24b5;hp=4da29c572576d403f43c9421ca77098a9354be74;hb=4ad169e89a063394cbc38963eba6fdd0b52ceba4;hpb=b86fb0f2dec49f42a9c9531f37b29e8815fc1384 diff --git a/client/goodfet.cc b/client/goodfet.cc index 4da29c5..3b97280 100755 --- a/client/goodfet.cc +++ b/client/goodfet.cc @@ -7,21 +7,23 @@ from GoodFET import GoodFET; from intelhex import IntelHex; - if(len(sys.argv)==1): print "Usage: %s verb [objects]\n" % sys.argv[0]; print "%s test" % sys.argv[0]; + print "%s info" % sys.argv[0]; print "%s dumpcode $foo.hex [0x$start 0x$stop]" % sys.argv[0]; + print "%s dumpdata $foo.hex [0x$start 0x$stop]" % sys.argv[0]; print "%s erase" % sys.argv[0]; - print "%s flash $foo.hex [0x$start 0x$stop]" % sys.argv[0]; + print "%s writedata $foo.hex [0x$start 0x$stop]" % sys.argv[0]; print "%s verify $foo.hex [0x$start 0x$stop]" % sys.argv[0]; + print "%s peekdata 0x$start [0x$stop]" % sys.argv[0]; + print "%s pokedata 0x$adr 0x$val" % sys.argv[0]; + #print "%s peekcode 0x$start [0x$stop]" % sys.argv[0]; sys.exit(); #Initailize FET and set baud rate client=GoodFET(); -client.serInit("/dev/ttyUSB0") - - +client.serInit() #Connect to target client.CCsetup(); @@ -41,7 +43,7 @@ if(sys.argv[1]=="dumpcode"): print "Dumping code from %04x to %04x as %s." % (start,stop,f); h = IntelHex(None); i=start; - while i>1]=client.CCpeekcodebyte(i); if(i%0x100==0): print "Dumped %04x."%i; @@ -59,8 +61,8 @@ if(sys.argv[1]=="dumpdata"): print "Dumping data from %04x to %04x as %s." % (start,stop,f); h = IntelHex(None); i=start; - while i>1]=client.CCpeekdatabyte(i); + while i<=stop: + h[i]=client.CCpeekdatabyte(i); if(i%0x100==0): print "Dumped %04x."%i; i+=1; @@ -70,27 +72,25 @@ if(sys.argv[1]=="erase"): client.CCchiperase(); print "Status: %s" %client.CCstatusstr(); -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); +# 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 = IntelHex(f); +# h = IntelHex(f); - client.MSP430masserase(); - for i in h._buf.keys(): - #print "%04x: %04x"%(i,h[i>>1]); - if(i>=start and i>1]); - if(i%0x100==0): - print "%04x" % i; -if(sys.argv[1]=="flashtest"): - client.MSP430flashtest(); -if(sys.argv[1]=="verify"): +# client.CCchiperase(); +# for i in h._buf.keys(): +# #print "%04x: %04x"%(i,h[i>>1]); +# if(i>=start and i<=stop and i&1==0): +# client.CCwriteflash(i,h[i>>1]); +# if(i%0x100==0): +# print "%04x" % i; +if(sys.argv[1]=="writedata"): f=sys.argv[2]; start=0; stop=0xFFFF; @@ -100,12 +100,44 @@ if(sys.argv[1]=="verify"): stop=int(sys.argv[4],16); h = IntelHex(f); + for i in h._buf.keys(): - if(i>=start and i>1]!=peek): - print "ERROR at %04x, found %04x not %04x"%(i,peek,h[i>>1]); + if(i>=start and i<=stop): + client.CCpokedatabyte(i,h[i]); if(i%0x100==0): print "%04x" % i; +#if(sys.argv[1]=="flashtest"): +# client.CCflashtest(); +if(sys.argv[1]=="peekdata"): + 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: %02x" % (start,client.CCpeekdatabyte(start)); + start=start+1; +if(sys.argv[1]=="peekcode"): + 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: %02x" % (start,client.CCpeekcodebyte(start)); + start=start+1; +if(sys.argv[1]=="pokedata"): + 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 %04x to become %02x." % (start,val); + client.CCpokedatabyte(start,val); client.CCstop();