X-Git-Url: http://git.rot13.org/?p=goodfet;a=blobdiff_plain;f=client%2FGoodFETAVR.py;h=f48001736214a5efb77e88dcd8cd49d6cbd96abb;hp=46efed70d86c120f85d09e6283458017dfe99821;hb=6097d6dc581f9331d80c8f1a04d307dd68a2fd0d;hpb=c84fe49161b904593101f7fa21aee65d54e03987 diff --git a/client/GoodFETAVR.py b/client/GoodFETAVR.py index 46efed7..f480017 100644 --- a/client/GoodFETAVR.py +++ b/client/GoodFETAVR.py @@ -11,6 +11,7 @@ from GoodFET import GoodFET; class GoodFETAVR(GoodFET): AVRAPP=0x32; + APP=AVRAPP; AVRVendors={0x1E: "Atmel", 0x00: "Locked", }; @@ -23,7 +24,9 @@ class GoodFETAVR(GoodFET): 0x9005: "tiny12", 0x9006: "tiny15", 0x9007: "tiny13", + 0x9108: "tiny25", 0x930B: "tiny85", + 0x9206: "tiny45", 0x9001: "S1200", @@ -33,20 +36,26 @@ class GoodFETAVR(GoodFET): 0x9103: "S2343", 0x9201: "S4414", - 0x9203: "S4433", + 0x9203: "S4433", 0x9202: "S4434", 0x9301: "S8515", 0x9303: "S8535", 0x9305: "mega83", + 0x930a: "mega88", 0x9701: "mega103", 0x9401: "mega161", 0x9402: "mega163", + 0x9406: "mega168", + + 0x950f: "mega328", + 0x950d: "mega325", + 0x9508: "mega32" }; def setup(self): - """Move the FET into the SPI application.""" + """Move the FET into the AVR application.""" self.writecmd(self.AVRAPP,0x10,0,self.data); #SPI/SETUP def trans(self,data): @@ -59,6 +68,15 @@ class GoodFETAVR(GoodFET): def start(self): """Start the connection.""" self.writecmd(self.AVRAPP,0x20,0,None); + def forcestart(self): + """Forcibly start a connection.""" + + for i in range(0x880,0xfff): + #self.glitchVoltages(0x880, i); + self.start(); + bits=self.lockbits(); + print "At %04x, Lockbits: %02x" % (i,bits); + if(bits==0xFF): return; def erase(self): """Erase the target chip.""" self.writecmd(self.AVRAPP,0xF0,0,None); @@ -66,12 +84,30 @@ class GoodFETAVR(GoodFET): """Read the target's lockbits.""" self.writecmd(self.AVRAPP,0x82,0,None); return ord(self.data[0]); + def setlockbits(self,bits=0x00): + """Read the target's lockbits.""" + self.writecmd(self.AVRAPP,0x92,1,[bits]); + return self.lockbits(); + def eeprompeek(self, adr): """Read a byte of the target's EEPROM.""" self.writecmd(self.AVRAPP,0x81 ,2, [ (adr&0xFF), (adr>>8)] );#little-endian address return ord(self.data[0]); + def flashpeek(self, adr): + """Read a byte of the target's EEPROM.""" + self.writecmd(self.AVRAPP,0x02 ,2, + [ (adr&0xFF), (adr>>8)] + );#little-endian address + return ord(self.data[0]); + def flashpeekblock(self, adr): + """Read a byte of the target's EEPROM.""" + self.writecmd(self.AVRAPP,0x02 ,4, + [ (adr&0xFF), (adr>>8) &0xFF, 0x80, 0x00] + ); + return self.data; + def eeprompoke(self, adr, val): """Write a byte of the target's EEPROM.""" self.writecmd(self.AVRAPP,0x91 ,3, @@ -91,4 +127,4 @@ class GoodFETAVR(GoodFET): if device==None: device=("0x%04x" % deviceid); - return device; + return "%s %s" % (vendor,device);