X-Git-Url: http://git.rot13.org/?a=blobdiff_plain;ds=sidebyside;f=client%2Fgoodfet.ccspi;h=d0b42464741c2f1d3e02096a3f17687849c53f82;hb=4c3cdeb4d074b093a6806929f2b25c61890439b0;hp=50501c59b60222f334c53e4b907b04e6b43c192b;hpb=7e2e3f1a4091ba1ca11982f0ba2b09809e298d94;p=goodfet diff --git a/client/goodfet.ccspi b/client/goodfet.ccspi index 50501c5..d0b4246 100755 --- a/client/goodfet.ccspi +++ b/client/goodfet.ccspi @@ -8,16 +8,30 @@ import sys; import binascii; -import array; +import array, time; from GoodFETCCSPI import GoodFETCCSPI; +def printpacket(packet): + s=""; + i=0; + for foo in packet: + s="%s %02x" % (s,ord(foo)); + print "#%s" % s; + + if(len(sys.argv)==1): print "Usage: %s verb [objects]\n" % sys.argv[0]; + print "%s info" % sys.argv[0]; print "%s regs" % sys.argv[0]; print "%s test" % sys.argv[0]; print "%s peek 0x$start [0x$stop]" % sys.argv[0]; print "%s poke 0x$adr 0x$val" % sys.argv[0]; + print "%s txtest" % sys.argv[0]; + + print "\n%s rssi" % sys.argv[0]; + print "%s sniff" % sys.argv[0]; + sys.exit(); #Initialize FET and set baud rate @@ -30,18 +44,92 @@ client.setup(); #Dummy read. #Might read as all ones if chip has a startup delay. +if(sys.argv[1]=="carrier"): + if len(sys.argv)>2: + client.RF_setfreq(eval(sys.argv[2])); + while 1: + client.RF_carrier(); + while(1): + time.sleep(1); + +if(sys.argv[1]=="modulated_spectrum"): + if len(sys.argv)>2: + client.RF_setfreq(eval(sys.argv[2])); + while 1: + client.RF_modulated_spectrum(); + while(1): + time.sleep(1); + if(sys.argv[1]=="info"): - print "Status is %02x" % client.strobe(0x00); + print "Found %s" % client.identstr(); + print "Freq: %05f MHz" % (client.RF_getfreq()/(10**6)); + print "Status: %s" % client.status(); if(sys.argv[1]=="regs"): for adr in range(0x10,0x40): #*1024): val=client.peek(adr); - print "%04x:=%02x" % (adr,val); + print "%04x:=0x%04x" % (adr,val); if(sys.argv[1]=="test"): data=client.trans([0x20, 0xde, 0xad]); print "%02x %02x" % (ord(data[1]), ord(data[2])); data=client.trans([0x40|0x20, 0xde, 0xad]); print "%02x %02x" % (ord(data[1]), ord(data[2])); +if(sys.argv[1]=="rssi"): + if len(sys.argv)>2: + client.RF_setfreq(eval(sys.argv[2])); + print "Listening on %f MHz." % (client.RF_getfreq()/10.0**6); + + client.strobe(0x02); #Calibrate + time.sleep(1); + while 1: + client.CC_RFST_RX(); + #client.strobe(0x03); #SRXON + rssi=client.RF_getrssi(); + #client.CC_RFST_IDLE(); #idle + time.sleep(0.01); + string=""; + for foo in range(0,rssi>>2): + string=("%s."%string); + print "%02x %04i %s" % (rssi,rssi, string); +if(sys.argv[1]=="sniff"): + #Promiscuous mode. + client.RF_promiscuity(1); + + if len(sys.argv)>2: + freq=eval(sys.argv[2]); + if freq>100: + client.RF_setfreq(freq); + else: + print "Channels not yet supported." + client.CC_RFST_RX(); + print "Listening as %010x on %i MHz" % (client.RF_getsmac(), + client.RF_getfreq()/10**6); + #Now we're ready to get packets. + + while 1: + packet=None; + while packet==None: + packet=client.RF_rxpacket(); + printpacket(packet); + sys.stdout.flush(); +if(sys.argv[1]=="txtest"): + if len(sys.argv)>2: + freq=eval(sys.argv[2]); + if freq>100: + client.RF_setfreq(freq); + else: + print "Channels not yet supported." + print "Transmitting DEADBEEF as %010x on %i MHz" % ( + client.RF_getsmac(), + client.RF_getfreq()/10**6); + + + while 1: + client.RF_txpacket([0x0f, 0x01, 0x08, 0x82, + 0xff, 0xff, 0xff, 0xff, + 0xde, 0xad, 0xbe, 0xef, + 0xba, 0xbe, 0xc0]); + if(sys.argv[1]=="peek"): start=0x0000; if(len(sys.argv)>2): @@ -51,7 +139,7 @@ if(sys.argv[1]=="peek"): stop=int(sys.argv[3],16); print "Peeking from %04x to %04x." % (start,stop); while start<=stop: - print "%04x: %02x" % (start,client.peek(start)); + print "%04x: 0x%04x" % (start,client.peek(start)); start=start+1; if(sys.argv[1]=="poke"): start=0x0000; @@ -60,7 +148,7 @@ if(sys.argv[1]=="poke"): start=int(sys.argv[2],16); if(len(sys.argv)>3): val=int(sys.argv[3],16); - print "Poking %02x to become %010x." % (start,val); + print "Poking r%02x to become 0x%04x." % (start,val); client.poke(start,val);