target/xtensa: use correct number of registers in gdbstub
System emulation should provide access to all registers, userspace emulation should only provide access to unprivileged registers. Record register flags from GDB register map definition, calculate both num_regs and num_core_regs if either is zero. Use num_regs in system emulation, num_core_regs in userspace emulation gdbstub. Signed-off-by: Max Filippov <jcmvbkbc@gmail.com>
This commit is contained in:
parent
b9317a2a69
commit
1b7b26e474
@ -310,6 +310,7 @@ typedef struct xtensa_tlb {
|
|||||||
|
|
||||||
typedef struct XtensaGdbReg {
|
typedef struct XtensaGdbReg {
|
||||||
int targno;
|
int targno;
|
||||||
|
unsigned flags;
|
||||||
int type;
|
int type;
|
||||||
int group;
|
int group;
|
||||||
unsigned size;
|
unsigned size;
|
||||||
|
@ -28,9 +28,14 @@ int xtensa_cpu_gdb_read_register(CPUState *cs, uint8_t *mem_buf, int n)
|
|||||||
XtensaCPU *cpu = XTENSA_CPU(cs);
|
XtensaCPU *cpu = XTENSA_CPU(cs);
|
||||||
CPUXtensaState *env = &cpu->env;
|
CPUXtensaState *env = &cpu->env;
|
||||||
const XtensaGdbReg *reg = env->config->gdb_regmap.reg + n;
|
const XtensaGdbReg *reg = env->config->gdb_regmap.reg + n;
|
||||||
|
#ifdef CONFIG_USER_ONLY
|
||||||
|
int num_regs = env->config->gdb_regmap.num_core_regs;
|
||||||
|
#else
|
||||||
|
int num_regs = env->config->gdb_regmap.num_regs;
|
||||||
|
#endif
|
||||||
unsigned i;
|
unsigned i;
|
||||||
|
|
||||||
if (n < 0 || n >= env->config->gdb_regmap.num_regs) {
|
if (n < 0 || n >= num_regs) {
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -81,8 +86,13 @@ int xtensa_cpu_gdb_write_register(CPUState *cs, uint8_t *mem_buf, int n)
|
|||||||
CPUXtensaState *env = &cpu->env;
|
CPUXtensaState *env = &cpu->env;
|
||||||
uint32_t tmp;
|
uint32_t tmp;
|
||||||
const XtensaGdbReg *reg = env->config->gdb_regmap.reg + n;
|
const XtensaGdbReg *reg = env->config->gdb_regmap.reg + n;
|
||||||
|
#ifdef CONFIG_USER_ONLY
|
||||||
|
int num_regs = env->config->gdb_regmap.num_core_regs;
|
||||||
|
#else
|
||||||
|
int num_regs = env->config->gdb_regmap.num_regs;
|
||||||
|
#endif
|
||||||
|
|
||||||
if (n < 0 || n >= env->config->gdb_regmap.num_regs) {
|
if (n < 0 || n >= num_regs) {
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -88,19 +88,31 @@ static void init_libisa(XtensaConfig *config)
|
|||||||
|
|
||||||
void xtensa_finalize_config(XtensaConfig *config)
|
void xtensa_finalize_config(XtensaConfig *config)
|
||||||
{
|
{
|
||||||
unsigned i, n = 0;
|
|
||||||
|
|
||||||
if (config->isa_internal) {
|
if (config->isa_internal) {
|
||||||
init_libisa(config);
|
init_libisa(config);
|
||||||
}
|
}
|
||||||
if (config->gdb_regmap.num_regs) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
for (i = 0; config->gdb_regmap.reg[i].targno >= 0; ++i) {
|
if (config->gdb_regmap.num_regs == 0 ||
|
||||||
n += (config->gdb_regmap.reg[i].type != 6);
|
config->gdb_regmap.num_core_regs == 0) {
|
||||||
|
unsigned i;
|
||||||
|
unsigned n_regs = 0;
|
||||||
|
unsigned n_core_regs = 0;
|
||||||
|
|
||||||
|
for (i = 0; config->gdb_regmap.reg[i].targno >= 0; ++i) {
|
||||||
|
if (config->gdb_regmap.reg[i].type != 6) {
|
||||||
|
++n_regs;
|
||||||
|
if ((config->gdb_regmap.reg[i].flags & 0x1) == 0) {
|
||||||
|
++n_core_regs;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if (config->gdb_regmap.num_regs == 0) {
|
||||||
|
config->gdb_regmap.num_regs = n_regs;
|
||||||
|
}
|
||||||
|
if (config->gdb_regmap.num_core_regs == 0) {
|
||||||
|
config->gdb_regmap.num_core_regs = n_core_regs;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
config->gdb_regmap.num_regs = n;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void xtensa_register_core(XtensaConfigList *node)
|
void xtensa_register_core(XtensaConfigList *node)
|
||||||
|
@ -25,9 +25,14 @@
|
|||||||
* SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
* SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#define XTREG(idx, ofs, bi, sz, al, no, flags, cp, typ, grp, name, \
|
#define XTREG(idx, ofs, bi, sz, al, no, fl, cp, typ, grp, name, \
|
||||||
a1, a2, a3, a4, a5, a6) \
|
a1, a2, a3, a4, a5, a6) { \
|
||||||
{ .targno = (no), .type = (typ), .group = (grp), .size = (sz) },
|
.targno = (no), \
|
||||||
|
.flags = (fl), \
|
||||||
|
.type = (typ), \
|
||||||
|
.group = (grp), \
|
||||||
|
.size = (sz), \
|
||||||
|
},
|
||||||
#define XTREG_END { .targno = -1 },
|
#define XTREG_END { .targno = -1 },
|
||||||
|
|
||||||
#ifndef XCHAL_HAVE_DEPBITS
|
#ifndef XCHAL_HAVE_DEPBITS
|
||||||
|
Loading…
Reference in New Issue
Block a user