Self test code.
authortravisutk <travisutk@12e2690d-a6be-4b82-a7b7-67c4a43b65c8>
Sun, 6 Jun 2010 00:03:00 +0000 (00:03 +0000)
committertravisutk <travisutk@12e2690d-a6be-4b82-a7b7-67c4a43b65c8>
Sun, 6 Jun 2010 00:03:00 +0000 (00:03 +0000)
git-svn-id: https://svn.code.sf.net/p/goodfet/code/trunk@601 12e2690d-a6be-4b82-a7b7-67c4a43b65c8

client/GoodFETMSP430.py
client/goodfet.msp430

index a70c656..ef9c64d 100644 (file)
@@ -38,7 +38,7 @@ class GoodFETMSP430(GoodFET):
         return DeviceID;
     def peek16(self,adr,memory="vn"):
         return self.MSP430peek(adr);
-    def peek8(self,address, memory="vn"):
+    def peek8(self,adr, memory="vn"):
         adr=self.MSP430peek(adr&~1);
         if adr&1==0: return adr&0xFF;
         else: return adr>>8;
index 23f4d1e..a52a3b4 100755 (executable)
@@ -72,14 +72,24 @@ if(sys.argv[1]=="eraseinfo"):
     client.MSP430infoerase();
 
 if(sys.argv[1]=="selftest"):
+    import time;
+    
     entry=client.peek16(0xFFC0);
     print "Calling self-test at 0x%04x." %entry;
+    print "Memory from 0x3020 to 0x3030 should be zeroed.";
+    
+    for i in range(0x3020,0x3030):
+        client.MSP430poke(i,0xFFFF);
     client.MSP430setPC(entry);
-    #client.MSP430releasecpu();
+    time.sleep(2);
+    errors=0;
+    for i in range(0x3020,0x3030):
+        ret=client.peek8(i);
+        if ret!=0:
+            errors=errors+1;
+            print "Failure at 0x%04x, returned %02xh." % (i,ret);
+    #client.MSP430dumpmem(0x3020,0x3030);
     
-    import time;
-    time.sleep(30)
-
 if(sys.argv[1]=="ivt"):
     client.MSP430dumpmem(0xFFC0,0xFFFF);
 if(sys.argv[1]=="regs"):