|
@@ -354,7 +354,6 @@ static const char *get_feature_xml(const char *p, const char **newp,
|
|
GDBProcess *process)
|
|
GDBProcess *process)
|
|
{
|
|
{
|
|
CPUState *cpu = gdb_get_first_cpu_in_process(process);
|
|
CPUState *cpu = gdb_get_first_cpu_in_process(process);
|
|
- CPUClass *cc = CPU_GET_CLASS(cpu);
|
|
|
|
GDBRegisterState *r;
|
|
GDBRegisterState *r;
|
|
size_t len;
|
|
size_t len;
|
|
|
|
|
|
@@ -377,11 +376,11 @@ static const char *get_feature_xml(const char *p, const char **newp,
|
|
"<!DOCTYPE target SYSTEM \"gdb-target.dtd\">"
|
|
"<!DOCTYPE target SYSTEM \"gdb-target.dtd\">"
|
|
"<target>"));
|
|
"<target>"));
|
|
|
|
|
|
- if (cc->gdb_arch_name) {
|
|
|
|
|
|
+ if (cpu->cc->gdb_arch_name) {
|
|
g_ptr_array_add(
|
|
g_ptr_array_add(
|
|
xml,
|
|
xml,
|
|
g_markup_printf_escaped("<architecture>%s</architecture>",
|
|
g_markup_printf_escaped("<architecture>%s</architecture>",
|
|
- cc->gdb_arch_name(cpu)));
|
|
|
|
|
|
+ cpu->cc->gdb_arch_name(cpu)));
|
|
}
|
|
}
|
|
for (guint i = 0; i < cpu->gdb_regs->len; i++) {
|
|
for (guint i = 0; i < cpu->gdb_regs->len; i++) {
|
|
r = &g_array_index(cpu->gdb_regs, GDBRegisterState, i);
|
|
r = &g_array_index(cpu->gdb_regs, GDBRegisterState, i);
|
|
@@ -520,11 +519,10 @@ GArray *gdb_get_register_list(CPUState *cpu)
|
|
|
|
|
|
int gdb_read_register(CPUState *cpu, GByteArray *buf, int reg)
|
|
int gdb_read_register(CPUState *cpu, GByteArray *buf, int reg)
|
|
{
|
|
{
|
|
- CPUClass *cc = CPU_GET_CLASS(cpu);
|
|
|
|
GDBRegisterState *r;
|
|
GDBRegisterState *r;
|
|
|
|
|
|
- if (reg < cc->gdb_num_core_regs) {
|
|
|
|
- return cc->gdb_read_register(cpu, buf, reg);
|
|
|
|
|
|
+ if (reg < cpu->cc->gdb_num_core_regs) {
|
|
|
|
+ return cpu->cc->gdb_read_register(cpu, buf, reg);
|
|
}
|
|
}
|
|
|
|
|
|
for (guint i = 0; i < cpu->gdb_regs->len; i++) {
|
|
for (guint i = 0; i < cpu->gdb_regs->len; i++) {
|
|
@@ -538,11 +536,10 @@ int gdb_read_register(CPUState *cpu, GByteArray *buf, int reg)
|
|
|
|
|
|
static int gdb_write_register(CPUState *cpu, uint8_t *mem_buf, int reg)
|
|
static int gdb_write_register(CPUState *cpu, uint8_t *mem_buf, int reg)
|
|
{
|
|
{
|
|
- CPUClass *cc = CPU_GET_CLASS(cpu);
|
|
|
|
GDBRegisterState *r;
|
|
GDBRegisterState *r;
|
|
|
|
|
|
- if (reg < cc->gdb_num_core_regs) {
|
|
|
|
- return cc->gdb_write_register(cpu, mem_buf, reg);
|
|
|
|
|
|
+ if (reg < cpu->cc->gdb_num_core_regs) {
|
|
|
|
+ return cpu->cc->gdb_write_register(cpu, mem_buf, reg);
|
|
}
|
|
}
|
|
|
|
|
|
for (guint i = 0; i < cpu->gdb_regs->len; i++) {
|
|
for (guint i = 0; i < cpu->gdb_regs->len; i++) {
|
|
@@ -570,7 +567,7 @@ static void gdb_register_feature(CPUState *cpu, int base_reg,
|
|
|
|
|
|
void gdb_init_cpu(CPUState *cpu)
|
|
void gdb_init_cpu(CPUState *cpu)
|
|
{
|
|
{
|
|
- CPUClass *cc = CPU_GET_CLASS(cpu);
|
|
|
|
|
|
+ CPUClass *cc = cpu->cc;
|
|
const GDBFeature *feature;
|
|
const GDBFeature *feature;
|
|
|
|
|
|
cpu->gdb_regs = g_array_new(false, false, sizeof(GDBRegisterState));
|
|
cpu->gdb_regs = g_array_new(false, false, sizeof(GDBRegisterState));
|
|
@@ -1646,11 +1643,8 @@ void gdb_extend_qsupported_features(char *qflags)
|
|
|
|
|
|
static void handle_query_supported(GArray *params, void *user_ctx)
|
|
static void handle_query_supported(GArray *params, void *user_ctx)
|
|
{
|
|
{
|
|
- CPUClass *cc;
|
|
|
|
-
|
|
|
|
g_string_printf(gdbserver_state.str_buf, "PacketSize=%x", MAX_PACKET_LENGTH);
|
|
g_string_printf(gdbserver_state.str_buf, "PacketSize=%x", MAX_PACKET_LENGTH);
|
|
- cc = CPU_GET_CLASS(first_cpu);
|
|
|
|
- if (cc->gdb_core_xml_file) {
|
|
|
|
|
|
+ if (first_cpu->cc->gdb_core_xml_file) {
|
|
g_string_append(gdbserver_state.str_buf, ";qXfer:features:read+");
|
|
g_string_append(gdbserver_state.str_buf, ";qXfer:features:read+");
|
|
}
|
|
}
|
|
|
|
|
|
@@ -1697,7 +1691,6 @@ static void handle_query_supported(GArray *params, void *user_ctx)
|
|
static void handle_query_xfer_features(GArray *params, void *user_ctx)
|
|
static void handle_query_xfer_features(GArray *params, void *user_ctx)
|
|
{
|
|
{
|
|
GDBProcess *process;
|
|
GDBProcess *process;
|
|
- CPUClass *cc;
|
|
|
|
unsigned long len, total_len, addr;
|
|
unsigned long len, total_len, addr;
|
|
const char *xml;
|
|
const char *xml;
|
|
const char *p;
|
|
const char *p;
|
|
@@ -1708,8 +1701,7 @@ static void handle_query_xfer_features(GArray *params, void *user_ctx)
|
|
}
|
|
}
|
|
|
|
|
|
process = gdb_get_cpu_process(gdbserver_state.g_cpu);
|
|
process = gdb_get_cpu_process(gdbserver_state.g_cpu);
|
|
- cc = CPU_GET_CLASS(gdbserver_state.g_cpu);
|
|
|
|
- if (!cc->gdb_core_xml_file) {
|
|
|
|
|
|
+ if (!gdbserver_state.g_cpu->cc->gdb_core_xml_file) {
|
|
gdb_put_packet("");
|
|
gdb_put_packet("");
|
|
return;
|
|
return;
|
|
}
|
|
}
|