Skip to content

Commit

Permalink
gdbserver: context_facade: return no regs in T response in reading re…
Browse files Browse the repository at this point in the history
…gs fails. (pyocd#1282)

If reading registers for the T response fails, don't include any
register values in the T response. Unlike other gdb register read
responses, we shouldn't set the value of failed register reads to
x's since gdb dislikes x's in a T response.
  • Loading branch information
flit committed Dec 30, 2021
1 parent 76e144e commit 81b72f0
Showing 1 changed file with 8 additions and 9 deletions.
17 changes: 8 additions & 9 deletions pyocd/gdbserver/context_facade.py
Original file line number Diff line number Diff line change
Expand Up @@ -211,8 +211,8 @@ def get_signal_value(self):
return signal

def _get_reg_index_value_pairs(self, reg_list):
"""! @brief Return register values as pairs.
"""! @brief Return register values as pairs for the T response.
Returns a string like NN:MMMMMMMM;NN:MMMMMMMM;...
for the T response string. NN is the index of the
register to follow MMMMMMMM is the value of the register.
Expand All @@ -221,16 +221,15 @@ def _get_reg_index_value_pairs(self, reg_list):
try:
reg_values = self._context.read_core_registers_raw(reg_list)
except exceptions.CoreRegisterAccessError:
reg_values = [None] * len(reg_list)
# If we cannot read registers, return an empty string. We mustn't return 'x's like the other
# register read methods do, because gdb terribly dislikes 'x's in a T response.
return result

for reg_name, reg_value in zip(reg_list, reg_values):
reg = self._context.core.core_registers.by_name[reg_name]
# Return x's if the register read failed.
if reg_value is None:
encoded_reg = "xx" * round_up_div(reg.bitsize, 8)
else:
encoded_reg = conversion.uint_to_hex_le(reg_value, reg.bitsize)
result += six.b(conversion.byte_to_hex2(reg.gdb_regnum) + ':' + encoded_reg + ';')
assert reg_value is not None
encoded_reg = conversion.uint_to_hex_le(reg_value, reg.bitsize)
result += (conversion.byte_to_hex2(reg.gdb_regnum) + ':' + encoded_reg + ';').encode()
return result

def get_memory_map_xml(self):
Expand Down

0 comments on commit 81b72f0

Please sign in to comment.