IsoTpParallelQuery: extend timeouts when receiving consecutive frames (#27762)

* change to rx_in_progress

* bump panda

* bump panda
pull/214/head
Shane Smiskol 3 years ago committed by GitHub
parent 1ee4f41d5a
commit a0f33658f2
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
  1. 2
      panda
  2. 6
      selfdrive/car/isotp_parallel_query.py

@ -1 +1 @@
Subproject commit a12c0a795678373d946b644b43d9402b72e502a9 Subproject commit 8efbcf041c1b6da1764bb56f822609fd4bb0758f

@ -105,13 +105,14 @@ class IsoTpParallelQuery:
for tx_addr, msg in msgs.items(): for tx_addr, msg in msgs.items():
try: try:
dat, updated = msg.recv() dat, rx_in_progress = msg.recv()
except Exception: except Exception:
cloudlog.exception(f"Error processing UDS response: {tx_addr}") cloudlog.exception(f"Error processing UDS response: {tx_addr}")
request_done[tx_addr] = True request_done[tx_addr] = True
continue continue
if updated: # Extend timeout for each consecutive ISO-TP frame to avoid timing out on long responses
if rx_in_progress:
response_timeouts[tx_addr] = time.monotonic() + timeout response_timeouts[tx_addr] = time.monotonic() + timeout
if not dat: if not dat:
@ -123,6 +124,7 @@ class IsoTpParallelQuery:
if response_valid: if response_valid:
if counter + 1 < len(self.request): if counter + 1 < len(self.request):
response_timeouts[tx_addr] = time.monotonic() + timeout
msg.send(self.request[counter + 1]) msg.send(self.request[counter + 1])
request_counter[tx_addr] += 1 request_counter[tx_addr] += 1
else: else:

Loading…
Cancel
Save