Files
dragonpilot/selfdrive/debug/can_printer.py

45 lines
1.3 KiB
Python
Raw Normal View History

2017-05-11 12:41:17 -07:00
#!/usr/bin/env python
import os
2017-09-30 03:07:27 -07:00
import sys
2017-05-11 12:41:17 -07:00
from collections import defaultdict
from common.realtime import sec_since_boot
import zmq
import selfdrive.messaging as messaging
from selfdrive.services import service_list
2018-06-16 20:59:34 -07:00
def can_printer(bus=0, max_msg=None, addr="127.0.0.1"):
2017-05-11 12:41:17 -07:00
context = zmq.Context()
2017-09-30 03:07:27 -07:00
logcan = messaging.sub_sock(context, service_list['can'].port, addr=addr)
2017-05-11 12:41:17 -07:00
start = sec_since_boot()
lp = sec_since_boot()
msgs = defaultdict(list)
2017-09-30 03:07:27 -07:00
canbus = int(os.getenv("CAN", bus))
2017-05-11 12:41:17 -07:00
while 1:
can_recv = messaging.drain_sock(logcan, wait_for_one=True)
for x in can_recv:
for y in x.can:
if y.src == canbus:
msgs[y.address].append(y.dat)
if sec_since_boot() - lp > 0.1:
dd = chr(27) + "[2J"
dd += "%5.2f\n" % (sec_since_boot() - start)
for k,v in sorted(zip(msgs.keys(), map(lambda x: x[-1].encode("hex"), msgs.values()))):
2018-06-16 20:59:34 -07:00
if max_msg is None or k < max_msg:
2017-09-30 03:07:27 -07:00
dd += "%s(%6d) %s\n" % ("%04X(%4d)" % (k,k),len(msgs[k]), v)
2019-04-23 01:41:19 +00:00
print(dd)
2017-05-11 12:41:17 -07:00
lp = sec_since_boot()
if __name__ == "__main__":
2017-09-30 03:07:27 -07:00
if len(sys.argv) > 3:
can_printer(int(sys.argv[1]), int(sys.argv[2]), sys.argv[3])
elif len(sys.argv) > 2:
can_printer(int(sys.argv[1]), int(sys.argv[2]))
elif len(sys.argv) > 1:
can_printer(int(sys.argv[1]))
else:
can_printer()