gdbstub: rename cpu_index -> cpu_gdb_index
This is to make it clear the index is purely a gdbstub function and should not be confused with the value of cpu->cpu_index. At the same time we move the function from the header to gdbstub itself which will help with later changes. Signed-off-by: Alex Bennée <alex.bennee@linaro.org> Reviewed-by: Greg Kurz <groug@kaod.org> Reviewed-by: Claudio Imbrenda <imbrenda@linux.vnet.ibm.com> Reviewed-by: Philippe Mathieu-Daudé <f4bug@amsat.org> Message-Id: <20170712105216.747-3-alex.bennee@linaro.org> Signed-off-by: Paolo Bonzini <pbonzini@redhat.com>
This commit is contained in:
parent
118e226884
commit
d2a6c8570b
26
gdbstub.c
26
gdbstub.c
@ -56,6 +56,20 @@ static inline int target_memory_rw_debug(CPUState *cpu, target_ulong addr,
|
|||||||
return cpu_memory_rw_debug(cpu, addr, buf, len, is_write);
|
return cpu_memory_rw_debug(cpu, addr, buf, len, is_write);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/* Return the GDB index for a given vCPU state.
|
||||||
|
*
|
||||||
|
* For user mode this is simply the thread id. In system mode GDB
|
||||||
|
* numbers CPUs from 1 as 0 is reserved as an "any cpu" index.
|
||||||
|
*/
|
||||||
|
static inline int cpu_gdb_index(CPUState *cpu)
|
||||||
|
{
|
||||||
|
#if defined(CONFIG_USER_ONLY)
|
||||||
|
return cpu->host_tid;
|
||||||
|
#else
|
||||||
|
return cpu->cpu_index + 1;
|
||||||
|
#endif
|
||||||
|
}
|
||||||
|
|
||||||
enum {
|
enum {
|
||||||
GDB_SIGNAL_0 = 0,
|
GDB_SIGNAL_0 = 0,
|
||||||
GDB_SIGNAL_INT = 2,
|
GDB_SIGNAL_INT = 2,
|
||||||
@ -838,7 +852,7 @@ static CPUState *find_cpu(uint32_t thread_id)
|
|||||||
CPUState *cpu;
|
CPUState *cpu;
|
||||||
|
|
||||||
CPU_FOREACH(cpu) {
|
CPU_FOREACH(cpu) {
|
||||||
if (cpu_index(cpu) == thread_id) {
|
if (cpu_gdb_index(cpu) == thread_id) {
|
||||||
return cpu;
|
return cpu;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -926,7 +940,7 @@ static int gdb_handle_vcont(GDBState *s, const char *p)
|
|||||||
idx = tmp;
|
idx = tmp;
|
||||||
/* 0 means any thread, so we pick the first valid CPU */
|
/* 0 means any thread, so we pick the first valid CPU */
|
||||||
if (!idx) {
|
if (!idx) {
|
||||||
idx = cpu_index(first_cpu);
|
idx = cpu_gdb_index(first_cpu);
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
@ -976,7 +990,7 @@ static int gdb_handle_packet(GDBState *s, const char *line_buf)
|
|||||||
case '?':
|
case '?':
|
||||||
/* TODO: Make this return the correct value for user-mode. */
|
/* TODO: Make this return the correct value for user-mode. */
|
||||||
snprintf(buf, sizeof(buf), "T%02xthread:%02x;", GDB_SIGNAL_TRAP,
|
snprintf(buf, sizeof(buf), "T%02xthread:%02x;", GDB_SIGNAL_TRAP,
|
||||||
cpu_index(s->c_cpu));
|
cpu_gdb_index(s->c_cpu));
|
||||||
put_packet(s, buf);
|
put_packet(s, buf);
|
||||||
/* Remove all the breakpoints when this query is issued,
|
/* Remove all the breakpoints when this query is issued,
|
||||||
* because gdb is doing and initial connect and the state
|
* because gdb is doing and initial connect and the state
|
||||||
@ -1244,7 +1258,7 @@ static int gdb_handle_packet(GDBState *s, const char *line_buf)
|
|||||||
} else if (strcmp(p,"sThreadInfo") == 0) {
|
} else if (strcmp(p,"sThreadInfo") == 0) {
|
||||||
report_cpuinfo:
|
report_cpuinfo:
|
||||||
if (s->query_cpu) {
|
if (s->query_cpu) {
|
||||||
snprintf(buf, sizeof(buf), "m%x", cpu_index(s->query_cpu));
|
snprintf(buf, sizeof(buf), "m%x", cpu_gdb_index(s->query_cpu));
|
||||||
put_packet(s, buf);
|
put_packet(s, buf);
|
||||||
s->query_cpu = CPU_NEXT(s->query_cpu);
|
s->query_cpu = CPU_NEXT(s->query_cpu);
|
||||||
} else
|
} else
|
||||||
@ -1401,7 +1415,7 @@ static void gdb_vm_state_change(void *opaque, int running, RunState state)
|
|||||||
}
|
}
|
||||||
snprintf(buf, sizeof(buf),
|
snprintf(buf, sizeof(buf),
|
||||||
"T%02xthread:%02x;%swatch:" TARGET_FMT_lx ";",
|
"T%02xthread:%02x;%swatch:" TARGET_FMT_lx ";",
|
||||||
GDB_SIGNAL_TRAP, cpu_index(cpu), type,
|
GDB_SIGNAL_TRAP, cpu_gdb_index(cpu), type,
|
||||||
(target_ulong)cpu->watchpoint_hit->vaddr);
|
(target_ulong)cpu->watchpoint_hit->vaddr);
|
||||||
cpu->watchpoint_hit = NULL;
|
cpu->watchpoint_hit = NULL;
|
||||||
goto send_packet;
|
goto send_packet;
|
||||||
@ -1435,7 +1449,7 @@ static void gdb_vm_state_change(void *opaque, int running, RunState state)
|
|||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
gdb_set_stop_cpu(cpu);
|
gdb_set_stop_cpu(cpu);
|
||||||
snprintf(buf, sizeof(buf), "T%02xthread:%02x;", ret, cpu_index(cpu));
|
snprintf(buf, sizeof(buf), "T%02xthread:%02x;", ret, cpu_gdb_index(cpu));
|
||||||
|
|
||||||
send_packet:
|
send_packet:
|
||||||
put_packet(s, buf);
|
put_packet(s, buf);
|
||||||
|
@ -58,15 +58,6 @@ void gdb_register_coprocessor(CPUState *cpu,
|
|||||||
gdb_reg_cb get_reg, gdb_reg_cb set_reg,
|
gdb_reg_cb get_reg, gdb_reg_cb set_reg,
|
||||||
int num_regs, const char *xml, int g_pos);
|
int num_regs, const char *xml, int g_pos);
|
||||||
|
|
||||||
static inline int cpu_index(CPUState *cpu)
|
|
||||||
{
|
|
||||||
#if defined(CONFIG_USER_ONLY)
|
|
||||||
return cpu->host_tid;
|
|
||||||
#else
|
|
||||||
return cpu->cpu_index + 1;
|
|
||||||
#endif
|
|
||||||
}
|
|
||||||
|
|
||||||
/* The GDB remote protocol transfers values in target byte order. This means
|
/* The GDB remote protocol transfers values in target byte order. This means
|
||||||
* we can use the raw memory access routines to access the value buffer.
|
* we can use the raw memory access routines to access the value buffer.
|
||||||
* Conveniently, these also handle the case where the buffer is mis-aligned.
|
* Conveniently, these also handle the case where the buffer is mis-aligned.
|
||||||
|
Loading…
x
Reference in New Issue
Block a user