X-Git-Url: http://git.rot13.org/?p=goodfet;a=blobdiff_plain;f=client%2Fgoodfet.spiflash;h=7aa287d1f6cf9e2bd52aa061964152479bafbd27;hp=a04ed19f4bbc888c2951b3e260f0c0e8d7b8f050;hb=fbf1dcfd59f6213926c78178115c1b7110afdf8f;hpb=d0d48d9cdb77bee064236d148002f98f3c247121 diff --git a/client/goodfet.spiflash b/client/goodfet.spiflash index a04ed19..7aa287d 100755 --- a/client/goodfet.spiflash +++ b/client/goodfet.spiflash @@ -10,7 +10,7 @@ import sys; import binascii; import array; -from GoodFET import GoodFET; +from GoodFETSPI import GoodFETSPIFlash; from intelhex import IntelHex; if(len(sys.argv)==1): @@ -18,18 +18,23 @@ if(len(sys.argv)==1): print "%s info" % sys.argv[0]; print "%s dump $foo.hex [0x$start 0x$stop]" % sys.argv[0]; print "%s erase" % sys.argv[0]; - print "%s write $foo.hex [0x$start 0x$stop]" % sys.argv[0]; + print "%s flash $foo.hex [0x$start 0x$stop]" % sys.argv[0]; print "%s verify $foo.hex [0x$start 0x$stop]" % sys.argv[0]; print "%s peek 0x$start [0x$stop]" % sys.argv[0]; print "%s poke 0x$adr 0x$val" % sys.argv[0]; sys.exit(); -#Initailize FET and set baud rate -client=GoodFET(); -client.serInit("/dev/ttyUSB0") +#Initialize FET and set baud rate +client=GoodFETSPIFlash(); +client.serInit() + client.SPIsetup(); +#Dummy read. +#Might read as all ones if chip has a startup delay. +client.SPIjedec(); + if(sys.argv[1]=="test"): result=""; dropped=0; @@ -51,16 +56,17 @@ if(sys.argv[1]=="test"): if(sys.argv[1]=="info"): data=client.SPIjedec(); - print "Ident as %s\nManufacturer: %02x %s\nType: %02x\nCapacity: %02x" % ( + print "Ident as %s\nManufacturer: %02x %s\nType: %02x\nCapacity: %02x (%i bytes)" % ( client.SPIjedecstr(), ord(data[1]),client.SPIjedecmanstr(), ord(data[2]), - ord(data[3])); + ord(data[3]), + client.JEDECsize); if(sys.argv[1]=="dump"): f = sys.argv[2]; start=0x0000; - stop=0x100000; #TODO, adjust this by the JEDEC size parameter. + stop=client.JEDECsize; if(len(sys.argv)>3): start=int(sys.argv[3],16); if(len(sys.argv)>4): @@ -68,22 +74,48 @@ if(sys.argv[1]=="dump"): print "Dumping code from %06x to %06x as %s." % (start,stop,f); file = open(f, mode='wb') + + i=start; + while i<=stop: + data=client.SPIpeekblock(i,255); + #if(i%0x1000==0): + print "Dumped %06x."%i; + for j in data: + if i3): + start=int(sys.argv[3],16); + if(len(sys.argv)>4): + stop=int(sys.argv[4],16); + + print "Verifying code from %06x to %06x as %s." % (start,stop,f); + file = open(f, mode='rb') + i=start; + bits=0; while i<=stop: - data=client.SPIpeekblock(i); - - - if(i%0x100==0): - print "Dumped %06x."%i; + data=client.SPIpeekblock(i,255); + print "Verified %06x." % i; for j in data: - file.write(j); + if i3): start=int(sys.argv[3],16); if(len(sys.argv)>4): @@ -93,12 +125,18 @@ if(sys.argv[1]=="flash"): file = open(f, mode='rb') i=start; - bytes=file.read(); + chars=list(file.read()); + chunksize=0x80; + while i<=stop: - client.SPIpokebyte(i,ord(bytes[i])); + bytes=range(0,chunksize); + for j in range(0,chunksize): + bytes[j]=ord(chars[i+j]); + #client.SPIpokebyte(i,ord(chars[i])); + client.SPIpokebytes(i,bytes); - i+=1; - if(i%0x100==0): + i+=chunksize; + if(i%0x1000==0): print "Flashed %06x."%i; file.close()