mirror of
https://github.com/trezor/trezor-firmware.git
synced 2025-01-28 16:21:03 +00:00
simplify read_wire_msg a bit
This commit is contained in:
parent
f2c331d783
commit
3a69524c52
@ -39,23 +39,19 @@ def _write_report(rep):
|
|||||||
def read_wire_msg():
|
def read_wire_msg():
|
||||||
|
|
||||||
rep = yield from _read_report()
|
rep = yield from _read_report()
|
||||||
assert rep[0] == _HEADER_MAGIC, 'Incorrect report magic'
|
magic, sid, mtype, mlen = ustruct.unpack('>BLLL', rep)
|
||||||
|
assert magic == _HEADER_MAGIC, 'Incorrect report magic'
|
||||||
# Parse message header
|
|
||||||
sid, mtype, mlen = ustruct.unpack_from('>LLL', rep, 1) # Skip magic
|
|
||||||
assert mlen < _MAX_DATA_LEN, 'Message too large to read'
|
assert mlen < _MAX_DATA_LEN, 'Message too large to read'
|
||||||
|
|
||||||
mlen += 4 # Account for the checksum
|
mlen += 4 # Account for the checksum
|
||||||
data = rep[13:][:mlen] # Skip magic and header, trim to data len
|
data = rep[13:][:mlen] # Skip magic and header, trim to data len
|
||||||
buffered = bytearray(data) # Resulting message data
|
remaining = mlen - len(data)
|
||||||
remaining = mlen - len(buffered)
|
buffered = bytearray(data) if remaining > 0 else data # Avoid the copy if we don't append
|
||||||
|
|
||||||
while remaining > 0:
|
while remaining > 0:
|
||||||
rep = yield from _read_report()
|
rep = yield from _read_report()
|
||||||
assert rep[0] == _DATA_MAGIC, 'Incorrect report magic'
|
magic, rsid = ustruct.unpack('>BL', rep)
|
||||||
|
assert magic == _DATA_MAGIC, 'Incorrect report magic'
|
||||||
# Compare the session IDs
|
|
||||||
rsid = ustruct.unpack_from('>L', rep, 1)
|
|
||||||
assert rsid == sid, 'Session ID mismatch'
|
assert rsid == sid, 'Session ID mismatch'
|
||||||
|
|
||||||
data = rep[5:][:remaining] # Skip magic and session ID, trim
|
data = rep[5:][:remaining] # Skip magic and session ID, trim
|
||||||
|
Loading…
Reference in New Issue
Block a user