rtos->symbols[FreeRTOS_VAL_uxCurrentNumberOfTasks].address,
param->thread_count_width,
(uint8_t *)&thread_list_size);
+ LOG_DEBUG("FreeRTOS: Read uxCurrentNumberOfTasks at 0x%" PRIx64 ", value %d\r\n",
+ rtos->symbols[FreeRTOS_VAL_uxCurrentNumberOfTasks].address,
+ thread_list_size);
if (retval != ERROR_OK) {
LOG_ERROR("Could not read FreeRTOS thread count from target");
LOG_ERROR("Error reading current thread in FreeRTOS thread list");
return retval;
}
+ LOG_DEBUG("FreeRTOS: Read pxCurrentTCB at 0x%" PRIx64 ", value 0x%" PRIx64 "\r\n",
+ rtos->symbols[FreeRTOS_VAL_pxCurrentTCB].address,
+ rtos->current_thread);
if ((thread_list_size == 0) || (rtos->current_thread == 0)) {
/* Either : No RTOS threads - there is always at least the current execution though */
(uint8_t *)&max_used_priority);
if (retval != ERROR_OK)
return retval;
+ LOG_DEBUG("FreeRTOS: Read uxTopUsedPriority at 0x%" PRIx64 ", value %" PRId64 "\r\n",
+ rtos->symbols[FreeRTOS_VAL_uxTopUsedPriority].address,
+ max_used_priority);
if (max_used_priority > FREERTOS_MAX_PRIORITIES) {
LOG_ERROR("FreeRTOS maximum used priority is unreasonably big, not proceeding: %" PRId64 "",
max_used_priority);
free(list_of_lists);
return retval;
}
+ LOG_DEBUG("FreeRTOS: Read thread count for list %d at 0x%" PRIx64 ", value %" PRId64 "\r\n",
+ i, list_of_lists[i], list_thread_count);
if (list_thread_count == 0)
continue;
free(list_of_lists);
return retval;
}
+ LOG_DEBUG("FreeRTOS: Read first item for list %d at 0x%" PRIx64 ", value 0x%" PRIx64 "\r\n",
+ i, list_of_lists[i] + param->list_next_offset, list_elem_ptr);
while ((list_thread_count > 0) && (list_elem_ptr != 0) &&
(list_elem_ptr != prev_list_elem_ptr) &&
free(list_of_lists);
return retval;
}
+ LOG_DEBUG("FreeRTOS: Read Thread ID at 0x%" PRIx64 ", value 0x%" PRIx64 "\r\n",
+ list_elem_ptr + param->list_elem_content_offset,
+ rtos->thread_details[tasks_found].threadid);
/* get thread name */
return retval;
}
tmp_str[FREERTOS_THREAD_NAME_STR_SIZE-1] = '\x00';
+ LOG_DEBUG("FreeRTOS: Read Thread Name at 0x%" PRIx64 ", value \"%s\"\r\n",
+ rtos->thread_details[tasks_found].threadid + param->thread_name_offset,
+ tmp_str);
if (tmp_str[0] == '\x00')
strcpy(tmp_str, "No Name");
free(list_of_lists);
return retval;
}
+ LOG_DEBUG("FreeRTOS: Read next thread location at 0x%" PRIx64 ", value 0x%" PRIx64 "\r\n",
+ prev_list_elem_ptr + param->list_elem_next_offset,
+ list_elem_ptr);
}
}
LOG_ERROR("Error reading stack frame from FreeRTOS thread");
return retval;
}
+ LOG_DEBUG("FreeRTOS: Read stack pointer at 0x%" PRIx64 ", value 0x%" PRIx64 "\r\n",
+ thread_id + param->thread_stack_offset,
+ stack_ptr);
return rtos_generic_stack_read(rtos->target, param->stacking_info, stack_ptr, hex_reg_list);
}