|
|
|
@ -8,7 +8,7 @@ EXT_DIAG_RESPONSE = b'\x50\x03' |
|
|
|
|
COM_CONT_RESPONSE = b'' |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
def disable_ecu(logcan, sendcan, bus=0, addr=0x7d0, sub_addr=None, com_cont_req=b'\x28\x83\x01', timeout=0.1, retry=10, debug=False): |
|
|
|
|
def disable_ecu(logcan, can_send, bus=0, addr=0x7d0, sub_addr=None, com_cont_req=b'\x28\x83\x01', timeout=0.1, retry=10, debug=False): |
|
|
|
|
"""Silence an ECU by disabling sending and receiving messages using UDS 0x28. |
|
|
|
|
The ECU will stay silent as long as openpilot keeps sending Tester Present. |
|
|
|
|
|
|
|
|
@ -18,12 +18,12 @@ def disable_ecu(logcan, sendcan, bus=0, addr=0x7d0, sub_addr=None, com_cont_req= |
|
|
|
|
|
|
|
|
|
for i in range(retry): |
|
|
|
|
try: |
|
|
|
|
query = IsoTpParallelQuery(sendcan, logcan, bus, [(addr, sub_addr)], [EXT_DIAG_REQUEST], [EXT_DIAG_RESPONSE], debug=debug) |
|
|
|
|
query = IsoTpParallelQuery(can_send, logcan, bus, [(addr, sub_addr)], [EXT_DIAG_REQUEST], [EXT_DIAG_RESPONSE], debug=debug) |
|
|
|
|
|
|
|
|
|
for _, _ in query.get_data(timeout).items(): |
|
|
|
|
carlog.warning("communication control disable tx/rx ...") |
|
|
|
|
|
|
|
|
|
query = IsoTpParallelQuery(sendcan, logcan, bus, [(addr, sub_addr)], [com_cont_req], [COM_CONT_RESPONSE], debug=debug) |
|
|
|
|
query = IsoTpParallelQuery(can_send, logcan, bus, [(addr, sub_addr)], [com_cont_req], [COM_CONT_RESPONSE], debug=debug) |
|
|
|
|
query.get_data(0) |
|
|
|
|
|
|
|
|
|
carlog.warning("ecu disabled") |
|
|
|
|