Files
panda-meb/scripts/can_printer.py

47 lines
1.1 KiB
Python
Raw Normal View History

2019-09-24 17:50:53 -07:00
#!/usr/bin/env python3
2017-05-27 12:31:29 -07:00
import os
import time
from collections import defaultdict
2018-03-04 13:52:53 -06:00
import binascii
from opendbc.car.structs import CarParams
2023-08-06 14:59:22 -07:00
from panda import Panda
2017-05-27 12:31:29 -07:00
# fake
def sec_since_boot():
return time.time()
def can_printer():
p = Panda()
print(f"Connected to id: {p.get_serial()[0]}: {p.get_version()}")
time.sleep(1)
p.can_clear(0xFFFF)
p.set_safety_mode(CarParams.SafetyModel.allOutput)
2017-05-27 12:31:29 -07:00
start = sec_since_boot()
lp = sec_since_boot()
all_msgs = defaultdict(list)
canbus = os.getenv("CAN")
if canbus == "3":
p.set_obd(True)
canbus = "1"
while True:
2017-05-27 12:31:29 -07:00
can_recv = p.can_recv()
for addr, dat, bus in can_recv:
if canbus is None or str(bus) == canbus:
all_msgs[(addr, bus)].append((dat))
2017-05-27 12:31:29 -07:00
if sec_since_boot() - lp > 0.1:
dd = chr(27) + "[2J"
dd += "%5.2f\n" % (sec_since_boot() - start)
for (addr, bus), dat_log in sorted(all_msgs.items()):
dd += "%d: %s(%6d): %s\n" % (bus, "%04X(%4d)" % (addr, addr), len(dat_log), binascii.hexlify(dat_log[-1]).decode())
print(dd)
2017-05-27 12:31:29 -07:00
lp = sec_since_boot()
if __name__ == "__main__":
can_printer()