mirror of
https://github.com/Motorhead1991/qemu.git
synced 2025-08-07 17:53:56 -06:00
target/microblaze: Add gdbstub xml
Mirroring the upstream gdb xml files, the two stack boundary registers are separated out. Reviewed-by: Edgar E. Iglesias <edgar@zeroasic.com> Signed-off-by: Richard Henderson <richard.henderson@linaro.org>
This commit is contained in:
parent
d7d5601c78
commit
c3bef3b4de
9 changed files with 128 additions and 15 deletions
|
@ -28,6 +28,7 @@
|
|||
#include "qemu/module.h"
|
||||
#include "hw/qdev-properties.h"
|
||||
#include "exec/exec-all.h"
|
||||
#include "exec/gdbstub.h"
|
||||
#include "fpu/softfloat-helpers.h"
|
||||
|
||||
static const struct {
|
||||
|
@ -294,6 +295,9 @@ static void mb_cpu_initfn(Object *obj)
|
|||
CPUMBState *env = &cpu->env;
|
||||
|
||||
cpu_set_cpustate_pointers(cpu);
|
||||
gdb_register_coprocessor(CPU(cpu), mb_cpu_gdb_read_stack_protect,
|
||||
mb_cpu_gdb_write_stack_protect, 2,
|
||||
"microblaze-stack-protect.xml", 0);
|
||||
|
||||
set_float_rounding_mode(float_round_nearest_even, &env->fp_status);
|
||||
|
||||
|
@ -422,7 +426,8 @@ static void mb_cpu_class_init(ObjectClass *oc, void *data)
|
|||
cc->sysemu_ops = &mb_sysemu_ops;
|
||||
#endif
|
||||
device_class_set_props(dc, mb_properties);
|
||||
cc->gdb_num_core_regs = 32 + 27;
|
||||
cc->gdb_num_core_regs = 32 + 25;
|
||||
cc->gdb_core_xml_file = "microblaze-core.xml";
|
||||
|
||||
cc->disas_set_info = mb_disas_set_info;
|
||||
cc->tcg_ops = &mb_tcg_ops;
|
||||
|
|
|
@ -367,6 +367,8 @@ hwaddr mb_cpu_get_phys_page_attrs_debug(CPUState *cpu, vaddr addr,
|
|||
MemTxAttrs *attrs);
|
||||
int mb_cpu_gdb_read_register(CPUState *cpu, GByteArray *buf, int reg);
|
||||
int mb_cpu_gdb_write_register(CPUState *cpu, uint8_t *buf, int reg);
|
||||
int mb_cpu_gdb_read_stack_protect(CPUArchState *cpu, GByteArray *buf, int reg);
|
||||
int mb_cpu_gdb_write_stack_protect(CPUArchState *cpu, uint8_t *buf, int reg);
|
||||
|
||||
static inline uint32_t mb_cpu_read_msr(const CPUMBState *env)
|
||||
{
|
||||
|
|
|
@ -39,8 +39,11 @@ enum {
|
|||
GDB_PVR0 = 32 + 6,
|
||||
GDB_PVR11 = 32 + 17,
|
||||
GDB_EDR = 32 + 18,
|
||||
GDB_SLR = 32 + 25,
|
||||
GDB_SHR = 32 + 26,
|
||||
};
|
||||
|
||||
enum {
|
||||
GDB_SP_SHL,
|
||||
GDB_SP_SHR,
|
||||
};
|
||||
|
||||
int mb_cpu_gdb_read_register(CPUState *cs, GByteArray *mem_buf, int n)
|
||||
|
@ -83,12 +86,6 @@ int mb_cpu_gdb_read_register(CPUState *cs, GByteArray *mem_buf, int n)
|
|||
case GDB_EDR:
|
||||
val = env->edr;
|
||||
break;
|
||||
case GDB_SLR:
|
||||
val = env->slr;
|
||||
break;
|
||||
case GDB_SHR:
|
||||
val = env->shr;
|
||||
break;
|
||||
default:
|
||||
/* Other SRegs aren't modeled, so report a value of 0 */
|
||||
val = 0;
|
||||
|
@ -97,6 +94,23 @@ int mb_cpu_gdb_read_register(CPUState *cs, GByteArray *mem_buf, int n)
|
|||
return gdb_get_reg32(mem_buf, val);
|
||||
}
|
||||
|
||||
int mb_cpu_gdb_read_stack_protect(CPUMBState *env, GByteArray *mem_buf, int n)
|
||||
{
|
||||
uint32_t val;
|
||||
|
||||
switch (n) {
|
||||
case GDB_SP_SHL:
|
||||
val = env->slr;
|
||||
break;
|
||||
case GDB_SP_SHR:
|
||||
val = env->shr;
|
||||
break;
|
||||
default:
|
||||
return 0;
|
||||
}
|
||||
return gdb_get_reg32(mem_buf, val);
|
||||
}
|
||||
|
||||
int mb_cpu_gdb_write_register(CPUState *cs, uint8_t *mem_buf, int n)
|
||||
{
|
||||
MicroBlazeCPU *cpu = MICROBLAZE_CPU(cs);
|
||||
|
@ -135,12 +149,21 @@ int mb_cpu_gdb_write_register(CPUState *cs, uint8_t *mem_buf, int n)
|
|||
case GDB_EDR:
|
||||
env->edr = tmp;
|
||||
break;
|
||||
case GDB_SLR:
|
||||
env->slr = tmp;
|
||||
break;
|
||||
case GDB_SHR:
|
||||
env->shr = tmp;
|
||||
break;
|
||||
}
|
||||
return 4;
|
||||
}
|
||||
|
||||
int mb_cpu_gdb_write_stack_protect(CPUMBState *env, uint8_t *mem_buf, int n)
|
||||
{
|
||||
switch (n) {
|
||||
case GDB_SP_SHL:
|
||||
env->slr = ldl_p(mem_buf);
|
||||
break;
|
||||
case GDB_SP_SHR:
|
||||
env->shr = ldl_p(mem_buf);
|
||||
break;
|
||||
default:
|
||||
return 0;
|
||||
}
|
||||
return 4;
|
||||
}
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue