mirror of
https://github.com/trezor/trezor-firmware.git
synced 2025-01-18 19:31:04 +00:00
core: debuglink interface avoids workflow management
This will have unintended consequences if you call a wirelink function on the debulink interface. TT allows this ... and will behave badly.
This commit is contained in:
parent
bc9247e18d
commit
a9d8fd3992
@ -63,7 +63,7 @@ def _boot_apps() -> None:
|
||||
# initialize the wire codec
|
||||
wire.setup(usb.iface_wire)
|
||||
if __debug__:
|
||||
wire.setup(usb.iface_debug)
|
||||
wire.setup(usb.iface_debug, use_workflow=False)
|
||||
|
||||
_boot_apps()
|
||||
loop.run()
|
||||
|
@ -84,9 +84,9 @@ def register(wire_type: int, handler: Handler) -> None:
|
||||
workflow_handlers[wire_type] = handler
|
||||
|
||||
|
||||
def setup(iface: WireInterface) -> None:
|
||||
def setup(iface: WireInterface, use_workflow: bool = True) -> None:
|
||||
"""Initialize the wire stack on passed USB interface."""
|
||||
loop.schedule(handle_session(iface, codec_v1.SESSION_ID))
|
||||
loop.schedule(handle_session(iface, codec_v1.SESSION_ID, use_workflow))
|
||||
|
||||
|
||||
def clear() -> None:
|
||||
@ -263,7 +263,9 @@ class UnexpectedMessageError(Exception):
|
||||
self.reader = reader
|
||||
|
||||
|
||||
async def handle_session(iface: WireInterface, session_id: int) -> None:
|
||||
async def handle_session(
|
||||
iface: WireInterface, session_id: int, use_workflow: bool = True
|
||||
) -> None:
|
||||
ctx = Context(iface, session_id)
|
||||
next_reader = None # type: Optional[codec_v1.Reader]
|
||||
res_msg = None # type: Optional[protobuf.MessageType]
|
||||
@ -346,7 +348,10 @@ async def handle_session(iface: WireInterface, session_id: int) -> None:
|
||||
# communication inside, but it should eventually return a
|
||||
# response message, or raise an exception (a rather common
|
||||
# thing to do). Exceptions are handled in the code below.
|
||||
res_msg = await workflow.spawn(wf_task)
|
||||
if use_workflow:
|
||||
res_msg = await workflow.spawn(wf_task)
|
||||
else:
|
||||
res_msg = await wf_task
|
||||
|
||||
except UnexpectedMessageError as exc:
|
||||
# Workflow was trying to read a message from the wire, and
|
||||
|
Loading…
Reference in New Issue
Block a user