X-Git-Url: http://git.rot13.org/?p=goodfet;a=blobdiff_plain;f=client%2Fgoodfet.cc;h=7a8fe49b258120e1ac92520b35e62d8e05d194cb;hp=445f3583aff8559ca791fccc580a12b437d9f446;hb=c8701c0a1cb2ab3a1a12ac24f17619575671df76;hpb=6fd9d83bf8e87be5220afc68963bdf2b000b6e3b diff --git a/client/goodfet.cc b/client/goodfet.cc index 445f358..7a8fe49 100755 --- a/client/goodfet.cc +++ b/client/goodfet.cc @@ -3,11 +3,10 @@ import sys; import binascii; -from GoodFET import GoodFET; +from GoodFET import GoodFETCC; from intelhex import IntelHex; - if(len(sys.argv)==1): print "Usage: %s verb [objects]\n" % sys.argv[0]; print "%s test" % sys.argv[0]; @@ -23,8 +22,8 @@ if(len(sys.argv)==1): sys.exit(); #Initailize FET and set baud rate -client=GoodFET(); -client.serInit("/dev/ttyUSB0") +client=GoodFETCC(); +client.serInit() #Connect to target client.CCsetup(); @@ -32,6 +31,9 @@ client.CCstart(); if(sys.argv[1]=="test"): client.CCtest(); +if(sys.argv[1]=="deadtest"): + for i in range(1,10): + print "IDENT as %s" % client.CCidentstr(); if(sys.argv[1]=="dumpcode"): f = sys.argv[2]; start=0x0000; @@ -68,29 +70,31 @@ if(sys.argv[1]=="dumpdata"): print "Dumped %04x."%i; i+=1; h.write_hex_file(f); +if(sys.argv[1]=="status"): + print "Status: %s" %client.CCstatusstr(); if(sys.argv[1]=="erase"): - print "Status: %s" % client.CCstatusstr(); - client.CCchiperase(); - print "Status: %s" %client.CCstatusstr(); + print "Status: %s" % client.CCstatusstr(); + 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<=stop and i&1==0): - client.MSP430writeflash(i,h[i>>1]); - if(i%0x100==0): - print "%04x" % i; +# 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; @@ -107,25 +111,8 @@ if(sys.argv[1]=="writedata"): client.CCpokedatabyte(i,h[i]); if(i%0x100==0): print "%04x" % i; -if(sys.argv[1]=="flashtest"): - client.MSP430flashtest(); -if(sys.argv[1]=="verifycode"): - 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); - for i in h._buf.keys(): - if(i>=start and i<=stop): - 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]=="flashtest"): +# client.CCflashtest(); if(sys.argv[1]=="peekdata"): start=0x0000; if(len(sys.argv)>2): @@ -137,6 +124,17 @@ if(sys.argv[1]=="peekdata"): 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;