Allowing a rate of 83.3
[goodfet] / client / goodfet.mcpcan
1 #!/usr/bin/env python
2 # GoodFET SPI Flash Client
3 #
4 # (C) 2012 Travis Goodspeed <travis at radiantmachines.com>
5 #
6 # This code is being rewritten and refactored.  You've been warned!
7
8 import sys;
9 import binascii;
10 import array;
11
12 from GoodFETMCPCAN import GoodFETMCPCAN;
13 from intelhex import IntelHex;
14
15 if(len(sys.argv)==1):
16     print "Usage: %s verb [objects]\n" % sys.argv[0];
17     print "%s info" % sys.argv[0];
18     print "%s test" % sys.argv[0];
19     print "%s peek 0x$start [0x$stop]" % sys.argv[0];
20     #print "%s poke 0x$adr 0x$val" % sys.argv[0];
21
22     print "\n%s sniff [kHz]" % sys.argv[0];
23     sys.exit();
24
25 #Initialize FET and set baud rate
26 client=GoodFETMCPCAN();
27 client.serInit()
28
29
30 client.MCPsetup();
31
32 #Dummy read.
33 #Might read as all ones if chip has a startup delay.
34
35 if(sys.argv[1]=="info"):
36     print "MCP2515 Info:\n\n";
37     
38     print "Mode: %s" % client.MCPcanstatstr();
39     print "Read Status: %02x" % client.MCPreadstatus();
40     print "Rx Status:   %02x" % client.MCPrxstatus();
41     print "Tx Errors:  %3d" % client.peek8(0x1c);
42     print "Rx Errors:  %3d" % client.peek8(0x1d);
43     print "RX Buffers:"
44     packet0=client.readrxbuffer(0);
45     packet1=client.readrxbuffer(1);
46     for foo in [packet0, packet1]:
47         print client.packet2str(foo);
48 if(sys.argv[1]=="sniff"):
49     if len(sys.argv)>2:
50         rate=float(sys.argv[2]);
51         client.MCPsetrate(rate);
52     client.MCPreqstatListenOnly();
53     while 1:
54         packet=client.rxpacket();
55         if packet!=None:
56             print client.packet2str(packet);
57
58 if(sys.argv[1]=="test"):
59     print "MCP2515 Self Test:";
60     
61     #Switch to config mode and try to rewrite TEC.
62     client.MCPreqstatConfiguration();
63     client.poke8(0x00,0xde);
64     if client.peek8(0x00)!=0xde:
65         print "ERROR: Poke to TEC failed.";
66     else:
67         print "SUCCESS: Register read/write.";
68     
69     #Switch to Loopback mode and try to catch our own packet.
70     client.MCPreqstatLoopback();
71     client.txpacket([0xb1, 0x6b, 0x00, 0x65,
72                      0xb1, 0x6b, 0x00, 0x65
73                      ]);
74     print "Waiting on loopback packet.";
75     packet=None;
76     while packet==None:
77         packet=client.rxpacket();
78     print "Success!  Got %s" % client.packet2str(packet);
79 if(sys.argv[1]=="peek"):
80     start=0x0000;
81     if(len(sys.argv)>2):
82         start=int(sys.argv[2],16);
83     stop=start;
84     if(len(sys.argv)>3):
85         stop=int(sys.argv[3],16);
86     print "Peeking from %04x to %04x." % (start,stop);
87     while start<=stop:
88         print "%04x: %02x" % (start,client.peek8(start));
89         start=start+1;