X-Git-Url: http://git.rot13.org/?p=goodfet;a=blobdiff_plain;f=client%2FGoodFET.py;h=5a0f78ba70f690fcbdcb67b2fb77813efb18b2dc;hp=583f1b12bb6149421d524af2d994448a847194a1;hb=1536c622c446a0928fb2e9e44cdc67e7cceb6e7e;hpb=e12a1ab7338cb974193113dce8c2413c0fd1bc78 diff --git a/client/GoodFET.py b/client/GoodFET.py index 583f1b1..5a0f78b 100755 --- a/client/GoodFET.py +++ b/client/GoodFET.py @@ -69,7 +69,7 @@ class GoodFET: return self.symbols.get(name); def timeout(self): print "timeout\n"; - def serInit(self, port=None, timeout=1): + def serInit(self, port=None, timeout=2): """Open the serial port""" # Make timeout None to wait forever, 0 for non-blocking mode. @@ -77,6 +77,8 @@ class GoodFET: glob_list = glob.glob(os.environ.get("GOODFET")); if len(glob_list) > 0: port = glob_list[0]; + else: + port = os.environ.get("GOODFET"); if port is None: glob_list = glob.glob("/dev/tty.usbserial*"); if len(glob_list) > 0: @@ -86,6 +88,7 @@ class GoodFET: if len(glob_list) > 0: port = glob_list[0]; + self.serialport = serial.Serial( port, #9600, @@ -95,7 +98,10 @@ class GoodFET: ) self.verb=0; + attempts=0; while self.verb!=0x7F: + self.serialport.flushInput() + self.serialport.flushOutput() #Explicitly set RTS and DTR to halt board. self.serialport.setRTS(1); self.serialport.setDTR(1); @@ -103,14 +109,13 @@ class GoodFET: self.serialport.setDTR(0); self.serialport.flushInput() self.serialport.flushOutput() - - #Read and handle the initial command. - #time.sleep(1); + #time.sleep(.1); + attempts=attempts+1; self.readcmd(); #Read the first command. - #if(self.verb!=0x7F): - # print "Verb %02x is wrong. Incorrect firmware or bad Info guess?" % self.verb; - # print "http://goodfet.sf.net/faq/"; - #print "Connected." + + #print "Connected after %02i attempts." % attempts; + self.mon_connected(); + def getbuffer(self,size=0x1c00): writecmd(0,0xC2,[size&0xFF,(size>>16)&0xFF]); print "Got %02x%02x buffer size." % (self.data[1],self.data[0]); @@ -221,7 +226,9 @@ class GoodFET: self.besilent=s; print "besilent is %i" % self.besilent; self.writecmd(0,0xB0,1,[s]); - + def mon_connected(self): + """Announce to the monitor that the connection is good.""" + self.writecmd(0,0xB1,0,[]); def out(self,byte): """Write a byte to P5OUT.""" self.writecmd(0,0xA1,1,[byte]); @@ -308,12 +315,13 @@ class GoodFET: """Self-test several functions through the monitor.""" print "Performing monitor self-test."; - if self.peekword(0x0c00)!=0x0c04 and self.peekword(0x0c00)!=0x0c06: - print "ERROR Fetched wrong value from 0x0c04."; - self.pokebyte(0x0021,0); #Drop LED - if self.peekbyte(0x0021)!=0: - print "ERROR, P1OUT not cleared."; - self.pokebyte(0x0021,1); #Light LED + for f in range(0,30): + if self.peekword(0x0c00)!=0x0c04 and self.peekword(0x0c00)!=0x0c06: + print "ERROR Fetched wrong value from 0x0c04."; + self.pokebyte(0x0021,0); #Drop LED + if self.peekbyte(0x0021)!=0: + print "ERROR, P1OUT not cleared."; + self.pokebyte(0x0021,1); #Light LED print "Self-test complete.";