def reset(self):
self.client.MCPsetup();
+
##########################
# SNIFF
##########################
row.append(0); #since we don't check for errors if we're not in debug mode...
row.append(comment)
+ #write packet to file
for byte in packet:
row.append("%02x"%ord(byte));
dataWriter.writerow(row);
outfile.close()
print "Listened for %d seconds, captured %d packets." %(duration,packetcount);
-
+ return packetcount
+
+
+ def filterStdSweep(self, freq = freq, time = 5):
+ msgIDs = []
+ niff(self,freq,duration,description, verbose=True, comment=None, filename=None, standardid=None, debug = False):
+ for i in range(0, 2047, 6):
+ print "sniffing id: %d, %d, %d, %d, %d, %d" % (i,i+1,i+2,i+3,i+4,i+5)
+ comment = "sweepFilter_%d_%d_%d_%d_%d_%d" % (i,i+1,i+2,i+3,i+4,i+5)
+ description = "Running a sweep filer for all the possible standard IDs. This run filters for: %d, %d, %d, %d, %d, %d" % (i,i+1,i+2,i+3,i+4,i+5)
+ count = self.sniff(freq=freq, duration = time, description = description,comment = comment, standardid = [i, i+1, i+2, i+3, i+4, i+5])
+ if( count != 0):
+ for j in range(i,i+5):
+ comment = "sweepFilter: %d" % (j)
+ description = "Running a sweep filer for all the possible standard IDs. This run filters for: %d " % j
+ count = self.sniff(freq=freq, duration = time, description = description,comment = comment, standardid = [j])
+ if( count != 0):
+ msgIDs.append(j)
+ return msgIDs
+
def sniffTest(self, freq):
rate = freq;
break;
- def spit(self,freq):
+ def spit(self,freq, standardid,debug):
+
self.client.MCPsetrate(freq);
self.client.MCPreqstatNormal();
- print "Tx Errors: %3d" % self.client.peek8(0x1c);
- print "Rx Errors: %3d" % self.client.peek8(0x1d);
- print "Error Flags: %02x\n" % self.client.peek8(0x2d);
- print "TXB0CTRL: %02x" %self.client.peek8(0x30);
- print "CANINTF: %02x" %self.client.peek8(0x2C);
+ if(debug==true):
+ print "Tx Errors: %3d" % self.client.peek8(0x1c);
+ print "Rx Errors: %3d" % self.client.peek8(0x1d);
+ print "Error Flags: %02x\n" % self.client.peek8(0x2d);
+ print "TXB0CTRL: %02x" %self.client.peek8(0x30);
+ print "CANINTF: %02x" %self.client.peek8(0x2C);
+ #### split SID into different regs
+ SIDlow = (standardid & 0x03) << 5; # get SID bits 2:0, rotate them to bits 7:5
+ SIDhigh = (standardid >> 3) & 0xFF; # get SID bits 10:3, rotate them to bits 7:0
- packet = [0x00,
- 0x08, # LOWER nibble must be 8 or greater to set EXTENDED ID
- 0x00, 0x00,
- 0x08, # UPPER nibble must be 0 to set RTR bit for DATA FRAME
- # LOWER nibble is DLC
- 0x01,0x02, 0x03, 0x04, 0x05, 0x06, 0x07, 0xFF]
+ packet = [SIDhigh, SIDlow,
+ 0x08, # bit 6 must be set to 0 for data frame (1 for RTR)
+ # lower nibble is DLC
+ 0x01,0x02, 0x03, 0x04, 0x05, 0x06, 0x07, 0xFF]
self.client.txpacket(packet);
print "TXB0CTRL: %02x" %self.client.peek8(0x30);
self.client.MCPbitmodify(0x30,0x08,0x00);
print "TXB0CTRL modified to: %02x\n" %self.client.peek8(0x30);
-
- print "message sending attempted.";
- print "Tx Errors: %02x" % self.client.peek8(0x1c);
- print "Rx Errors: %02x" % self.client.peek8(0x1d);
- print "Error Flags: %02x" % self.client.peek8(0x2d);
+
+ if (debug==true):
+ print "message sending attempted.";
+ print "Tx Errors: %02x" % self.client.peek8(0x1c);
+ print "Rx Errors: %02x" % self.client.peek8(0x1d);
+ print "Error Flags: %02x" % self.client.peek8(0x2d);
if(args.verb=="snifftest"):
comm.sniffTest(freq=freq)
+
##########################
# FREQ TEST
##########################
if(args.verb=="freqtest"):
comm.freqtest(freq=freq)
+
+
##########################
# iSniff
##########################
# transmission (travis thinks this is because we're sniffing in listen-only
# and thus not generating an ack bit on the recieving board)
if(args.verb=="spit"):
- comm.spit(freq=freq)
+ comm.spit(freq=freq, standardid=standardid, debug=debug)