hwthread: Add register validity check in get_thread_reg_list
When OpenOCD receives 'g' packet (read general registers) from GDB and target is configured as rtos=hwthread, hwthread_get_thread_reg_list is called. However, it does not check if the register valid or not. Due to this issue, OpenOCD returns invalid register values to GDB. This commit adds a validity check to hwthread_get_thread_reg_list. If the register is not valid, it tries to read the register from the target. Signed-off-by: Koudai Iwahori <koudai@google.com> Change-Id: Iad6424b62124271ec411b1dfc044b57dfc460280 Reviewed-on: https://review.openocd.org/c/openocd/+/7357 Tested-by: jenkins Reviewed-by: Antonio Borneo <borneo.antonio@gmail.com>
This commit is contained in:
parent
3ea1bfce4f
commit
a9d7428535
|
@ -255,6 +255,15 @@ static int hwthread_get_thread_reg_list(struct rtos *rtos, int64_t thread_id,
|
|||
for (int i = 0; i < reg_list_size; i++) {
|
||||
if (!reg_list[i] || reg_list[i]->exist == false || reg_list[i]->hidden)
|
||||
continue;
|
||||
if (!reg_list[i]->valid) {
|
||||
retval = reg_list[i]->type->get(reg_list[i]);
|
||||
if (retval != ERROR_OK) {
|
||||
LOG_ERROR("Couldn't get register %s.", reg_list[i]->name);
|
||||
free(reg_list);
|
||||
free(*rtos_reg_list);
|
||||
return retval;
|
||||
}
|
||||
}
|
||||
(*rtos_reg_list)[j].number = reg_list[i]->number;
|
||||
(*rtos_reg_list)[j].size = reg_list[i]->size;
|
||||
memcpy((*rtos_reg_list)[j].value, reg_list[i]->value,
|
||||
|
|
Loading…
Reference in New Issue