2021-12-13 23:38:15 -05:00
|
|
|
/*
|
|
|
|
* SPDX-FileCopyrightText: 2015-2021 Espressif Systems (Shanghai) CO LTD
|
|
|
|
*
|
|
|
|
* SPDX-License-Identifier: Apache-2.0
|
|
|
|
*/
|
2020-11-26 00:38:09 -05:00
|
|
|
|
|
|
|
#include <string.h>
|
|
|
|
#include "esp_gdbstub.h"
|
|
|
|
#include "esp_gdbstub_common.h"
|
|
|
|
#include "sdkconfig.h"
|
|
|
|
#include "freertos/FreeRTOS.h"
|
|
|
|
#include "freertos/task.h"
|
|
|
|
|
|
|
|
static void init_regfile(esp_gdbstub_gdb_regfile_t *dst)
|
|
|
|
{
|
|
|
|
memset(dst, 0, sizeof(*dst));
|
|
|
|
}
|
|
|
|
|
|
|
|
void esp_gdbstub_frame_to_regfile(const esp_gdbstub_frame_t *frame, esp_gdbstub_gdb_regfile_t *dst)
|
|
|
|
{
|
|
|
|
init_regfile(dst);
|
|
|
|
dst->pc = frame->mepc;
|
|
|
|
|
|
|
|
// We omit register x0 here since it's the zero register and always hard-wired to 0.
|
|
|
|
// See The RISC-V Instruction Set Manual Volume I: Unprivileged ISA Document Version 20191213 for more details.
|
|
|
|
memcpy(&(dst->x[1]), &frame->ra, sizeof(uint32_t) * 31);
|
|
|
|
}
|
|
|
|
|
|
|
|
#ifdef CONFIG_ESP_GDBSTUB_SUPPORT_TASKS
|
|
|
|
|
|
|
|
/* Represents FreeRTOS TCB structure */
|
|
|
|
typedef struct {
|
|
|
|
uint8_t *top_of_stack;
|
|
|
|
/* Other members aren't needed */
|
|
|
|
} dummy_tcb_t;
|
|
|
|
|
|
|
|
|
|
|
|
void esp_gdbstub_tcb_to_regfile(TaskHandle_t tcb, esp_gdbstub_gdb_regfile_t *dst)
|
|
|
|
{
|
|
|
|
const dummy_tcb_t *dummy_tcb = (const dummy_tcb_t *) tcb;
|
|
|
|
|
|
|
|
const RvExcFrame *frame = (RvExcFrame *) dummy_tcb->top_of_stack;
|
|
|
|
esp_gdbstub_frame_to_regfile(frame, dst);
|
|
|
|
}
|
|
|
|
|
|
|
|
#endif // CONFIG_ESP_GDBSTUB_SUPPORT_TASKS
|
|
|
|
|
|
|
|
int esp_gdbstub_get_signal(const esp_gdbstub_frame_t *frame)
|
|
|
|
{
|
|
|
|
return 5; // SIGTRAP, see IDF-2490
|
|
|
|
}
|
2021-04-19 05:03:43 -04:00
|
|
|
|
|
|
|
void _xt_gdbstub_int(void * frame)
|
|
|
|
{
|
|
|
|
|
|
|
|
}
|