Skip to content

Commit

Permalink
RTT_COMMAND: Allow no down-channels
Browse files Browse the repository at this point in the history
If no down-channel can be found, the target only supports printing RTT
messages.

Before this commit, this target-configuration was only possible to do when
supplying a log file.
Then commands were ignored and only the up-channel was written to the
file.
If no log-file was supplied, we detected the missing down-channels and
returned an error, never starting the viewer_loop so no up-channel
messages were printed on stdout.

With this commit,
instead of returning an error when no down-channels are configured,
we inform the user and start the viewer_loop
with a down-channel (parameter down_chan) with value 'None'.

Inside the viewer_loop we detect the None-value of down_chan, drop the user
supplied command and continue our viewer_loop.

Signed-off-by: Laurens Miers <[email protected]>
  • Loading branch information
Laurens Miers authored and laurensmiers committed Jan 7, 2025
1 parent 5166025 commit 209f3dd
Showing 1 changed file with 12 additions and 6 deletions.
18 changes: 12 additions & 6 deletions pyocd/subcommands/rtt_cmd.py
Original file line number Diff line number Diff line change
Expand Up @@ -5,6 +5,7 @@
# Copyright (C) 2022 Johan Carlsson <[email protected]>
# Copyright (C) 2022 Samuel Dewan
# Copyright (C) 2022 Zhengji Li
# Copyright (C) 2024 Laurens Miers
# SPDX-License-Identifier: Apache-2.0
#
# Licensed under the Apache License, Version 2.0 (the "License");
Expand Down Expand Up @@ -117,12 +118,13 @@ def invoke(self) -> int:
kb = KBHit()

if self._args.log_file is None:
if len(control_block.down_channels) < 1:
LOG.error("No down channels.")
return 1
down_chan: RTTDownChannel = control_block.down_channels[self._args.down_channel_id]
down_name = down_chan.name if down_chan.name is not None else ""
LOG.info(f"Writing to down channel {self._args.down_channel_id} (\"{down_name}\")")
if control_block.down_channels:
down_chan: RTTDownChannel = control_block.down_channels[self._args.down_channel_id]
down_name = down_chan.name if down_chan.name is not None else ""
LOG.info(f"Writing to down channel {self._args.down_channel_id} (\"{down_name}\")")
else:
down_chan = None
LOG.info("No down channel, input will be ignored")

self.viewer_loop(up_chan, down_chan, kb)
else:
Expand Down Expand Up @@ -199,6 +201,10 @@ def viewer_loop(self, up_chan, down_chan, kb):
if not cmd:
continue

# If no channel, ignore command
if not down_chan:
continue

# write cmd buffer to down buffer 0 (host -> target)
bytes_out = down_chan.write(cmd)
cmd = cmd[bytes_out:]

0 comments on commit 209f3dd

Please sign in to comment.