cpu: Move breakpoints field from CPU_COMMON to CPUState
Most targets were using offsetof(CPUFooState, breakpoints) to determine how much of CPUFooState to clear on reset. Use the next field after CPU_COMMON instead, if any, or sizeof(CPUFooState) otherwise. Signed-off-by: Andreas Färber <afaerber@suse.de>
This commit is contained in:
parent
ff4700b05c
commit
f0c3c505a8
21
exec.c
21
exec.c
@ -484,7 +484,7 @@ void cpu_exec_init(CPUArchState *env)
|
|||||||
}
|
}
|
||||||
cpu->cpu_index = cpu_index;
|
cpu->cpu_index = cpu_index;
|
||||||
cpu->numa_node = 0;
|
cpu->numa_node = 0;
|
||||||
QTAILQ_INIT(&env->breakpoints);
|
QTAILQ_INIT(&cpu->breakpoints);
|
||||||
QTAILQ_INIT(&cpu->watchpoints);
|
QTAILQ_INIT(&cpu->watchpoints);
|
||||||
#ifndef CONFIG_USER_ONLY
|
#ifndef CONFIG_USER_ONLY
|
||||||
cpu->as = &address_space_memory;
|
cpu->as = &address_space_memory;
|
||||||
@ -621,6 +621,7 @@ int cpu_breakpoint_insert(CPUArchState *env, target_ulong pc, int flags,
|
|||||||
CPUBreakpoint **breakpoint)
|
CPUBreakpoint **breakpoint)
|
||||||
{
|
{
|
||||||
#if defined(TARGET_HAS_ICE)
|
#if defined(TARGET_HAS_ICE)
|
||||||
|
CPUState *cpu = ENV_GET_CPU(env);
|
||||||
CPUBreakpoint *bp;
|
CPUBreakpoint *bp;
|
||||||
|
|
||||||
bp = g_malloc(sizeof(*bp));
|
bp = g_malloc(sizeof(*bp));
|
||||||
@ -630,12 +631,12 @@ int cpu_breakpoint_insert(CPUArchState *env, target_ulong pc, int flags,
|
|||||||
|
|
||||||
/* keep all GDB-injected breakpoints in front */
|
/* keep all GDB-injected breakpoints in front */
|
||||||
if (flags & BP_GDB) {
|
if (flags & BP_GDB) {
|
||||||
QTAILQ_INSERT_HEAD(&env->breakpoints, bp, entry);
|
QTAILQ_INSERT_HEAD(&cpu->breakpoints, bp, entry);
|
||||||
} else {
|
} else {
|
||||||
QTAILQ_INSERT_TAIL(&env->breakpoints, bp, entry);
|
QTAILQ_INSERT_TAIL(&cpu->breakpoints, bp, entry);
|
||||||
}
|
}
|
||||||
|
|
||||||
breakpoint_invalidate(ENV_GET_CPU(env), pc);
|
breakpoint_invalidate(cpu, pc);
|
||||||
|
|
||||||
if (breakpoint) {
|
if (breakpoint) {
|
||||||
*breakpoint = bp;
|
*breakpoint = bp;
|
||||||
@ -650,9 +651,10 @@ int cpu_breakpoint_insert(CPUArchState *env, target_ulong pc, int flags,
|
|||||||
int cpu_breakpoint_remove(CPUArchState *env, target_ulong pc, int flags)
|
int cpu_breakpoint_remove(CPUArchState *env, target_ulong pc, int flags)
|
||||||
{
|
{
|
||||||
#if defined(TARGET_HAS_ICE)
|
#if defined(TARGET_HAS_ICE)
|
||||||
|
CPUState *cpu = ENV_GET_CPU(env);
|
||||||
CPUBreakpoint *bp;
|
CPUBreakpoint *bp;
|
||||||
|
|
||||||
QTAILQ_FOREACH(bp, &env->breakpoints, entry) {
|
QTAILQ_FOREACH(bp, &cpu->breakpoints, entry) {
|
||||||
if (bp->pc == pc && bp->flags == flags) {
|
if (bp->pc == pc && bp->flags == flags) {
|
||||||
cpu_breakpoint_remove_by_ref(env, bp);
|
cpu_breakpoint_remove_by_ref(env, bp);
|
||||||
return 0;
|
return 0;
|
||||||
@ -668,9 +670,11 @@ int cpu_breakpoint_remove(CPUArchState *env, target_ulong pc, int flags)
|
|||||||
void cpu_breakpoint_remove_by_ref(CPUArchState *env, CPUBreakpoint *breakpoint)
|
void cpu_breakpoint_remove_by_ref(CPUArchState *env, CPUBreakpoint *breakpoint)
|
||||||
{
|
{
|
||||||
#if defined(TARGET_HAS_ICE)
|
#if defined(TARGET_HAS_ICE)
|
||||||
QTAILQ_REMOVE(&env->breakpoints, breakpoint, entry);
|
CPUState *cpu = ENV_GET_CPU(env);
|
||||||
|
|
||||||
breakpoint_invalidate(ENV_GET_CPU(env), breakpoint->pc);
|
QTAILQ_REMOVE(&cpu->breakpoints, breakpoint, entry);
|
||||||
|
|
||||||
|
breakpoint_invalidate(cpu, breakpoint->pc);
|
||||||
|
|
||||||
g_free(breakpoint);
|
g_free(breakpoint);
|
||||||
#endif
|
#endif
|
||||||
@ -680,9 +684,10 @@ void cpu_breakpoint_remove_by_ref(CPUArchState *env, CPUBreakpoint *breakpoint)
|
|||||||
void cpu_breakpoint_remove_all(CPUArchState *env, int mask)
|
void cpu_breakpoint_remove_all(CPUArchState *env, int mask)
|
||||||
{
|
{
|
||||||
#if defined(TARGET_HAS_ICE)
|
#if defined(TARGET_HAS_ICE)
|
||||||
|
CPUState *cpu = ENV_GET_CPU(env);
|
||||||
CPUBreakpoint *bp, *next;
|
CPUBreakpoint *bp, *next;
|
||||||
|
|
||||||
QTAILQ_FOREACH_SAFE(bp, &env->breakpoints, entry, next) {
|
QTAILQ_FOREACH_SAFE(bp, &cpu->breakpoints, entry, next) {
|
||||||
if (bp->flags & mask)
|
if (bp->flags & mask)
|
||||||
cpu_breakpoint_remove_by_ref(env, bp);
|
cpu_breakpoint_remove_by_ref(env, bp);
|
||||||
}
|
}
|
||||||
|
@ -114,19 +114,9 @@ QEMU_BUILD_BUG_ON(sizeof(CPUTLBEntry) != (1 << CPU_TLB_ENTRY_BITS));
|
|||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
|
||||||
typedef struct CPUBreakpoint {
|
|
||||||
target_ulong pc;
|
|
||||||
int flags; /* BP_* */
|
|
||||||
QTAILQ_ENTRY(CPUBreakpoint) entry;
|
|
||||||
} CPUBreakpoint;
|
|
||||||
|
|
||||||
#define CPU_TEMP_BUF_NLONGS 128
|
#define CPU_TEMP_BUF_NLONGS 128
|
||||||
#define CPU_COMMON \
|
#define CPU_COMMON \
|
||||||
/* soft mmu support */ \
|
/* soft mmu support */ \
|
||||||
CPU_COMMON_TLB \
|
CPU_COMMON_TLB \
|
||||||
\
|
|
||||||
/* from this point: preserved by CPU reset */ \
|
|
||||||
/* ice debug support */ \
|
|
||||||
QTAILQ_HEAD(breakpoints_head, CPUBreakpoint) breakpoints; \
|
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
@ -151,6 +151,12 @@ typedef struct icount_decr_u16 {
|
|||||||
} icount_decr_u16;
|
} icount_decr_u16;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
typedef struct CPUBreakpoint {
|
||||||
|
vaddr pc;
|
||||||
|
int flags; /* BP_* */
|
||||||
|
QTAILQ_ENTRY(CPUBreakpoint) entry;
|
||||||
|
} CPUBreakpoint;
|
||||||
|
|
||||||
typedef struct CPUWatchpoint {
|
typedef struct CPUWatchpoint {
|
||||||
vaddr vaddr;
|
vaddr vaddr;
|
||||||
vaddr len_mask;
|
vaddr len_mask;
|
||||||
@ -238,6 +244,9 @@ struct CPUState {
|
|||||||
int gdb_num_g_regs;
|
int gdb_num_g_regs;
|
||||||
QTAILQ_ENTRY(CPUState) node;
|
QTAILQ_ENTRY(CPUState) node;
|
||||||
|
|
||||||
|
/* ice debug support */
|
||||||
|
QTAILQ_HEAD(breakpoints_head, CPUBreakpoint) breakpoints;
|
||||||
|
|
||||||
QTAILQ_HEAD(watchpoints_head, CPUWatchpoint) watchpoints;
|
QTAILQ_HEAD(watchpoints_head, CPUWatchpoint) watchpoints;
|
||||||
CPUWatchpoint *watchpoint_hit;
|
CPUWatchpoint *watchpoint_hit;
|
||||||
|
|
||||||
|
@ -3450,10 +3450,10 @@ CPUArchState *cpu_copy(CPUArchState *env)
|
|||||||
/* Clone all break/watchpoints.
|
/* Clone all break/watchpoints.
|
||||||
Note: Once we support ptrace with hw-debug register access, make sure
|
Note: Once we support ptrace with hw-debug register access, make sure
|
||||||
BP_CPU break/watchpoints are handled correctly on clone. */
|
BP_CPU break/watchpoints are handled correctly on clone. */
|
||||||
QTAILQ_INIT(&env->breakpoints);
|
QTAILQ_INIT(&cpu->breakpoints);
|
||||||
QTAILQ_INIT(&cpu->watchpoints);
|
QTAILQ_INIT(&cpu->watchpoints);
|
||||||
#if defined(TARGET_HAS_ICE)
|
#if defined(TARGET_HAS_ICE)
|
||||||
QTAILQ_FOREACH(bp, &env->breakpoints, entry) {
|
QTAILQ_FOREACH(bp, &cpu->breakpoints, entry) {
|
||||||
cpu_breakpoint_insert(new_env, bp->pc, bp->flags, NULL);
|
cpu_breakpoint_insert(new_env, bp->pc, bp->flags, NULL);
|
||||||
}
|
}
|
||||||
QTAILQ_FOREACH(wp, &cpu->watchpoints, entry) {
|
QTAILQ_FOREACH(wp, &cpu->watchpoints, entry) {
|
||||||
|
@ -3463,8 +3463,8 @@ static inline void gen_intermediate_code_internal(AlphaCPU *cpu,
|
|||||||
|
|
||||||
gen_tb_start();
|
gen_tb_start();
|
||||||
do {
|
do {
|
||||||
if (unlikely(!QTAILQ_EMPTY(&env->breakpoints))) {
|
if (unlikely(!QTAILQ_EMPTY(&cs->breakpoints))) {
|
||||||
QTAILQ_FOREACH(bp, &env->breakpoints, entry) {
|
QTAILQ_FOREACH(bp, &cs->breakpoints, entry) {
|
||||||
if (bp->pc == ctx.pc) {
|
if (bp->pc == ctx.pc) {
|
||||||
gen_excp(&ctx, EXCP_DEBUG, 0);
|
gen_excp(&ctx, EXCP_DEBUG, 0);
|
||||||
break;
|
break;
|
||||||
|
@ -82,7 +82,7 @@ static void arm_cpu_reset(CPUState *s)
|
|||||||
|
|
||||||
acc->parent_reset(s);
|
acc->parent_reset(s);
|
||||||
|
|
||||||
memset(env, 0, offsetof(CPUARMState, breakpoints));
|
memset(env, 0, offsetof(CPUARMState, features));
|
||||||
g_hash_table_foreach(cpu->cp_regs, cp_reg_reset, cpu);
|
g_hash_table_foreach(cpu->cp_regs, cp_reg_reset, cpu);
|
||||||
env->vfp.xregs[ARM_VFP_FPSID] = cpu->reset_fpsid;
|
env->vfp.xregs[ARM_VFP_FPSID] = cpu->reset_fpsid;
|
||||||
env->vfp.xregs[ARM_VFP_MVFR0] = cpu->mvfr0;
|
env->vfp.xregs[ARM_VFP_MVFR0] = cpu->mvfr0;
|
||||||
|
@ -9061,8 +9061,8 @@ void gen_intermediate_code_internal_a64(ARMCPU *cpu,
|
|||||||
tcg_clear_temp_count();
|
tcg_clear_temp_count();
|
||||||
|
|
||||||
do {
|
do {
|
||||||
if (unlikely(!QTAILQ_EMPTY(&env->breakpoints))) {
|
if (unlikely(!QTAILQ_EMPTY(&cs->breakpoints))) {
|
||||||
QTAILQ_FOREACH(bp, &env->breakpoints, entry) {
|
QTAILQ_FOREACH(bp, &cs->breakpoints, entry) {
|
||||||
if (bp->pc == dc->pc) {
|
if (bp->pc == dc->pc) {
|
||||||
gen_exception_insn(dc, 0, EXCP_DEBUG);
|
gen_exception_insn(dc, 0, EXCP_DEBUG);
|
||||||
/* Advance PC so that clearing the breakpoint will
|
/* Advance PC so that clearing the breakpoint will
|
||||||
|
@ -10733,8 +10733,8 @@ static inline void gen_intermediate_code_internal(ARMCPU *cpu,
|
|||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
if (unlikely(!QTAILQ_EMPTY(&env->breakpoints))) {
|
if (unlikely(!QTAILQ_EMPTY(&cs->breakpoints))) {
|
||||||
QTAILQ_FOREACH(bp, &env->breakpoints, entry) {
|
QTAILQ_FOREACH(bp, &cs->breakpoints, entry) {
|
||||||
if (bp->pc == dc->pc) {
|
if (bp->pc == dc->pc) {
|
||||||
gen_exception_insn(dc, 0, EXCP_DEBUG);
|
gen_exception_insn(dc, 0, EXCP_DEBUG);
|
||||||
/* Advance PC so that clearing the breakpoint will
|
/* Advance PC so that clearing the breakpoint will
|
||||||
|
@ -49,7 +49,7 @@ static void cris_cpu_reset(CPUState *s)
|
|||||||
ccc->parent_reset(s);
|
ccc->parent_reset(s);
|
||||||
|
|
||||||
vr = env->pregs[PR_VR];
|
vr = env->pregs[PR_VR];
|
||||||
memset(env, 0, offsetof(CPUCRISState, breakpoints));
|
memset(env, 0, offsetof(CPUCRISState, load_info));
|
||||||
env->pregs[PR_VR] = vr;
|
env->pregs[PR_VR] = vr;
|
||||||
tlb_flush(env, 1);
|
tlb_flush(env, 1);
|
||||||
|
|
||||||
|
@ -171,8 +171,8 @@ typedef struct CPUCRISState {
|
|||||||
|
|
||||||
CPU_COMMON
|
CPU_COMMON
|
||||||
|
|
||||||
/* Members after CPU_COMMON are preserved across resets. */
|
/* Members from load_info on are preserved across resets. */
|
||||||
void *load_info;
|
void *load_info;
|
||||||
} CPUCRISState;
|
} CPUCRISState;
|
||||||
|
|
||||||
#include "cpu-qom.h"
|
#include "cpu-qom.h"
|
||||||
|
@ -3089,10 +3089,11 @@ static unsigned int crisv32_decoder(CPUCRISState *env, DisasContext *dc)
|
|||||||
|
|
||||||
static void check_breakpoint(CPUCRISState *env, DisasContext *dc)
|
static void check_breakpoint(CPUCRISState *env, DisasContext *dc)
|
||||||
{
|
{
|
||||||
|
CPUState *cs = CPU(cris_env_get_cpu(env));
|
||||||
CPUBreakpoint *bp;
|
CPUBreakpoint *bp;
|
||||||
|
|
||||||
if (unlikely(!QTAILQ_EMPTY(&env->breakpoints))) {
|
if (unlikely(!QTAILQ_EMPTY(&cs->breakpoints))) {
|
||||||
QTAILQ_FOREACH(bp, &env->breakpoints, entry) {
|
QTAILQ_FOREACH(bp, &cs->breakpoints, entry) {
|
||||||
if (bp->pc == dc->pc) {
|
if (bp->pc == dc->pc) {
|
||||||
cris_evaluate_flags(dc);
|
cris_evaluate_flags(dc);
|
||||||
tcg_gen_movi_tl(env_pc, dc->pc);
|
tcg_gen_movi_tl(env_pc, dc->pc);
|
||||||
|
@ -2410,7 +2410,7 @@ static void x86_cpu_reset(CPUState *s)
|
|||||||
xcc->parent_reset(s);
|
xcc->parent_reset(s);
|
||||||
|
|
||||||
|
|
||||||
memset(env, 0, offsetof(CPUX86State, breakpoints));
|
memset(env, 0, offsetof(CPUX86State, pat));
|
||||||
|
|
||||||
tlb_flush(env, 1);
|
tlb_flush(env, 1);
|
||||||
|
|
||||||
|
@ -875,7 +875,7 @@ typedef struct CPUX86State {
|
|||||||
target_ulong exception_next_eip;
|
target_ulong exception_next_eip;
|
||||||
target_ulong dr[8]; /* debug registers */
|
target_ulong dr[8]; /* debug registers */
|
||||||
union {
|
union {
|
||||||
CPUBreakpoint *cpu_breakpoint[4];
|
struct CPUBreakpoint *cpu_breakpoint[4];
|
||||||
struct CPUWatchpoint *cpu_watchpoint[4];
|
struct CPUWatchpoint *cpu_watchpoint[4];
|
||||||
}; /* break/watchpoints for dr[0..3] */
|
}; /* break/watchpoints for dr[0..3] */
|
||||||
uint32_t smbase;
|
uint32_t smbase;
|
||||||
@ -887,6 +887,7 @@ typedef struct CPUX86State {
|
|||||||
|
|
||||||
CPU_COMMON
|
CPU_COMMON
|
||||||
|
|
||||||
|
/* Fields from here on are preserved across CPU reset. */
|
||||||
uint64_t pat;
|
uint64_t pat;
|
||||||
|
|
||||||
/* processor features (e.g. for CPUID insn) */
|
/* processor features (e.g. for CPUID insn) */
|
||||||
|
@ -1101,7 +1101,7 @@ void breakpoint_handler(CPUX86State *env)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
QTAILQ_FOREACH(bp, &env->breakpoints, entry)
|
QTAILQ_FOREACH(bp, &cs->breakpoints, entry) {
|
||||||
if (bp->pc == env->eip) {
|
if (bp->pc == env->eip) {
|
||||||
if (bp->flags & BP_CPU) {
|
if (bp->flags & BP_CPU) {
|
||||||
check_hw_breakpoints(env, true);
|
check_hw_breakpoints(env, true);
|
||||||
@ -1109,6 +1109,7 @@ void breakpoint_handler(CPUX86State *env)
|
|||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -7965,8 +7965,8 @@ static inline void gen_intermediate_code_internal(X86CPU *cpu,
|
|||||||
|
|
||||||
gen_tb_start();
|
gen_tb_start();
|
||||||
for(;;) {
|
for(;;) {
|
||||||
if (unlikely(!QTAILQ_EMPTY(&env->breakpoints))) {
|
if (unlikely(!QTAILQ_EMPTY(&cs->breakpoints))) {
|
||||||
QTAILQ_FOREACH(bp, &env->breakpoints, entry) {
|
QTAILQ_FOREACH(bp, &cs->breakpoints, entry) {
|
||||||
if (bp->pc == pc_ptr &&
|
if (bp->pc == pc_ptr &&
|
||||||
!((bp->flags & BP_CPU) && (tb->flags & HF_RF_MASK))) {
|
!((bp->flags & BP_CPU) && (tb->flags & HF_RF_MASK))) {
|
||||||
gen_debug(dc, pc_ptr - dc->cs_base);
|
gen_debug(dc, pc_ptr - dc->cs_base);
|
||||||
|
@ -125,7 +125,7 @@ static void lm32_cpu_reset(CPUState *s)
|
|||||||
lcc->parent_reset(s);
|
lcc->parent_reset(s);
|
||||||
|
|
||||||
/* reset cpu state */
|
/* reset cpu state */
|
||||||
memset(env, 0, offsetof(CPULM32State, breakpoints));
|
memset(env, 0, offsetof(CPULM32State, eba));
|
||||||
|
|
||||||
lm32_cpu_init_cfg_reg(cpu);
|
lm32_cpu_init_cfg_reg(cpu);
|
||||||
tlb_flush(env, 1);
|
tlb_flush(env, 1);
|
||||||
|
@ -166,11 +166,12 @@ struct CPULM32State {
|
|||||||
uint32_t bp[4]; /* breakpoints */
|
uint32_t bp[4]; /* breakpoints */
|
||||||
uint32_t wp[4]; /* watchpoints */
|
uint32_t wp[4]; /* watchpoints */
|
||||||
|
|
||||||
CPUBreakpoint * cpu_breakpoint[4];
|
struct CPUBreakpoint *cpu_breakpoint[4];
|
||||||
struct CPUWatchpoint *cpu_watchpoint[4];
|
struct CPUWatchpoint *cpu_watchpoint[4];
|
||||||
|
|
||||||
CPU_COMMON
|
CPU_COMMON
|
||||||
|
|
||||||
|
/* Fields from here on are preserved across CPU reset. */
|
||||||
uint32_t eba; /* exception base address */
|
uint32_t eba; /* exception base address */
|
||||||
uint32_t deba; /* debug exception base address */
|
uint32_t deba; /* debug exception base address */
|
||||||
|
|
||||||
|
@ -131,7 +131,7 @@ void lm32_debug_excp_handler(CPULM32State *env)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
QTAILQ_FOREACH(bp, &env->breakpoints, entry) {
|
QTAILQ_FOREACH(bp, &cs->breakpoints, entry) {
|
||||||
if (bp->pc == env->pc) {
|
if (bp->pc == env->pc) {
|
||||||
if (bp->flags & BP_CPU) {
|
if (bp->flags & BP_CPU) {
|
||||||
raise_exception(env, EXCP_BREAKPOINT);
|
raise_exception(env, EXCP_BREAKPOINT);
|
||||||
|
@ -1037,10 +1037,11 @@ static inline void decode(DisasContext *dc, uint32_t ir)
|
|||||||
|
|
||||||
static void check_breakpoint(CPULM32State *env, DisasContext *dc)
|
static void check_breakpoint(CPULM32State *env, DisasContext *dc)
|
||||||
{
|
{
|
||||||
|
CPUState *cs = CPU(lm32_env_get_cpu(env));
|
||||||
CPUBreakpoint *bp;
|
CPUBreakpoint *bp;
|
||||||
|
|
||||||
if (unlikely(!QTAILQ_EMPTY(&env->breakpoints))) {
|
if (unlikely(!QTAILQ_EMPTY(&cs->breakpoints))) {
|
||||||
QTAILQ_FOREACH(bp, &env->breakpoints, entry) {
|
QTAILQ_FOREACH(bp, &cs->breakpoints, entry) {
|
||||||
if (bp->pc == dc->pc) {
|
if (bp->pc == dc->pc) {
|
||||||
tcg_gen_movi_tl(cpu_pc, dc->pc);
|
tcg_gen_movi_tl(cpu_pc, dc->pc);
|
||||||
t_gen_raise_exception(dc, EXCP_DEBUG);
|
t_gen_raise_exception(dc, EXCP_DEBUG);
|
||||||
|
@ -49,7 +49,7 @@ static void m68k_cpu_reset(CPUState *s)
|
|||||||
|
|
||||||
mcc->parent_reset(s);
|
mcc->parent_reset(s);
|
||||||
|
|
||||||
memset(env, 0, offsetof(CPUM68KState, breakpoints));
|
memset(env, 0, offsetof(CPUM68KState, features));
|
||||||
#if !defined(CONFIG_USER_ONLY)
|
#if !defined(CONFIG_USER_ONLY)
|
||||||
env->sr = 0x2700;
|
env->sr = 0x2700;
|
||||||
#endif
|
#endif
|
||||||
|
@ -110,6 +110,7 @@ typedef struct CPUM68KState {
|
|||||||
|
|
||||||
CPU_COMMON
|
CPU_COMMON
|
||||||
|
|
||||||
|
/* Fields from here on are preserved across CPU reset. */
|
||||||
uint32_t features;
|
uint32_t features;
|
||||||
} CPUM68KState;
|
} CPUM68KState;
|
||||||
|
|
||||||
|
@ -3003,8 +3003,8 @@ gen_intermediate_code_internal(M68kCPU *cpu, TranslationBlock *tb,
|
|||||||
do {
|
do {
|
||||||
pc_offset = dc->pc - pc_start;
|
pc_offset = dc->pc - pc_start;
|
||||||
gen_throws_exception = NULL;
|
gen_throws_exception = NULL;
|
||||||
if (unlikely(!QTAILQ_EMPTY(&env->breakpoints))) {
|
if (unlikely(!QTAILQ_EMPTY(&cs->breakpoints))) {
|
||||||
QTAILQ_FOREACH(bp, &env->breakpoints, entry) {
|
QTAILQ_FOREACH(bp, &cs->breakpoints, entry) {
|
||||||
if (bp->pc == dc->pc) {
|
if (bp->pc == dc->pc) {
|
||||||
gen_exception(dc, dc->pc, EXCP_DEBUG);
|
gen_exception(dc, dc->pc, EXCP_DEBUG);
|
||||||
dc->is_jmp = DISAS_JUMP;
|
dc->is_jmp = DISAS_JUMP;
|
||||||
|
@ -63,7 +63,7 @@ static void mb_cpu_reset(CPUState *s)
|
|||||||
|
|
||||||
mcc->parent_reset(s);
|
mcc->parent_reset(s);
|
||||||
|
|
||||||
memset(env, 0, offsetof(CPUMBState, breakpoints));
|
memset(env, 0, sizeof(CPUMBState));
|
||||||
env->res_addr = RES_ADDR_NONE;
|
env->res_addr = RES_ADDR_NONE;
|
||||||
tlb_flush(env, 1);
|
tlb_flush(env, 1);
|
||||||
|
|
||||||
|
@ -1660,10 +1660,11 @@ static inline void decode(DisasContext *dc, uint32_t ir)
|
|||||||
|
|
||||||
static void check_breakpoint(CPUMBState *env, DisasContext *dc)
|
static void check_breakpoint(CPUMBState *env, DisasContext *dc)
|
||||||
{
|
{
|
||||||
|
CPUState *cs = CPU(mb_env_get_cpu(env));
|
||||||
CPUBreakpoint *bp;
|
CPUBreakpoint *bp;
|
||||||
|
|
||||||
if (unlikely(!QTAILQ_EMPTY(&env->breakpoints))) {
|
if (unlikely(!QTAILQ_EMPTY(&cs->breakpoints))) {
|
||||||
QTAILQ_FOREACH(bp, &env->breakpoints, entry) {
|
QTAILQ_FOREACH(bp, &cs->breakpoints, entry) {
|
||||||
if (bp->pc == dc->pc) {
|
if (bp->pc == dc->pc) {
|
||||||
t_gen_raise_exception(dc, EXCP_DEBUG);
|
t_gen_raise_exception(dc, EXCP_DEBUG);
|
||||||
dc->is_jmp = DISAS_UPDATE;
|
dc->is_jmp = DISAS_UPDATE;
|
||||||
|
@ -83,7 +83,7 @@ static void mips_cpu_reset(CPUState *s)
|
|||||||
|
|
||||||
mcc->parent_reset(s);
|
mcc->parent_reset(s);
|
||||||
|
|
||||||
memset(env, 0, offsetof(CPUMIPSState, breakpoints));
|
memset(env, 0, offsetof(CPUMIPSState, mvp));
|
||||||
tlb_flush(env, 1);
|
tlb_flush(env, 1);
|
||||||
|
|
||||||
cpu_state_reset(env);
|
cpu_state_reset(env);
|
||||||
|
@ -482,6 +482,7 @@ struct CPUMIPSState {
|
|||||||
|
|
||||||
CPU_COMMON
|
CPU_COMMON
|
||||||
|
|
||||||
|
/* Fields from here on are preserved across CPU reset. */
|
||||||
CPUMIPSMVPContext *mvp;
|
CPUMIPSMVPContext *mvp;
|
||||||
#if !defined(CONFIG_USER_ONLY)
|
#if !defined(CONFIG_USER_ONLY)
|
||||||
CPUMIPSTLBContext *tlb;
|
CPUMIPSTLBContext *tlb;
|
||||||
|
@ -15613,8 +15613,8 @@ gen_intermediate_code_internal(MIPSCPU *cpu, TranslationBlock *tb,
|
|||||||
LOG_DISAS("\ntb %p idx %d hflags %04x\n", tb, ctx.mem_idx, ctx.hflags);
|
LOG_DISAS("\ntb %p idx %d hflags %04x\n", tb, ctx.mem_idx, ctx.hflags);
|
||||||
gen_tb_start();
|
gen_tb_start();
|
||||||
while (ctx.bstate == BS_NONE) {
|
while (ctx.bstate == BS_NONE) {
|
||||||
if (unlikely(!QTAILQ_EMPTY(&env->breakpoints))) {
|
if (unlikely(!QTAILQ_EMPTY(&cs->breakpoints))) {
|
||||||
QTAILQ_FOREACH(bp, &env->breakpoints, entry) {
|
QTAILQ_FOREACH(bp, &cs->breakpoints, entry) {
|
||||||
if (bp->pc == ctx.pc) {
|
if (bp->pc == ctx.pc) {
|
||||||
save_cpu_state(&ctx, 1);
|
save_cpu_state(&ctx, 1);
|
||||||
ctx.bstate = BS_BRANCH;
|
ctx.bstate = BS_BRANCH;
|
||||||
|
@ -42,7 +42,7 @@ static void moxie_cpu_reset(CPUState *s)
|
|||||||
|
|
||||||
mcc->parent_reset(s);
|
mcc->parent_reset(s);
|
||||||
|
|
||||||
memset(env, 0, offsetof(CPUMoxieState, breakpoints));
|
memset(env, 0, sizeof(CPUMoxieState));
|
||||||
env->pc = 0x1000;
|
env->pc = 0x1000;
|
||||||
|
|
||||||
tlb_flush(env, 1);
|
tlb_flush(env, 1);
|
||||||
|
@ -845,8 +845,8 @@ gen_intermediate_code_internal(MoxieCPU *cpu, TranslationBlock *tb,
|
|||||||
|
|
||||||
gen_tb_start();
|
gen_tb_start();
|
||||||
do {
|
do {
|
||||||
if (unlikely(!QTAILQ_EMPTY(&env->breakpoints))) {
|
if (unlikely(!QTAILQ_EMPTY(&cs->breakpoints))) {
|
||||||
QTAILQ_FOREACH(bp, &env->breakpoints, entry) {
|
QTAILQ_FOREACH(bp, &cs->breakpoints, entry) {
|
||||||
if (ctx.pc == bp->pc) {
|
if (ctx.pc == bp->pc) {
|
||||||
tcg_gen_movi_i32(cpu_pc, ctx.pc);
|
tcg_gen_movi_i32(cpu_pc, ctx.pc);
|
||||||
gen_helper_debug(cpu_env);
|
gen_helper_debug(cpu_env);
|
||||||
|
@ -41,7 +41,11 @@ static void openrisc_cpu_reset(CPUState *s)
|
|||||||
|
|
||||||
occ->parent_reset(s);
|
occ->parent_reset(s);
|
||||||
|
|
||||||
memset(&cpu->env, 0, offsetof(CPUOpenRISCState, breakpoints));
|
#ifndef CONFIG_USER_ONLY
|
||||||
|
memset(&cpu->env, 0, offsetof(CPUOpenRISCState, tlb));
|
||||||
|
#else
|
||||||
|
memset(&cpu->env, 0, offsetof(CPUOpenRISCState, irq));
|
||||||
|
#endif
|
||||||
|
|
||||||
tlb_flush(&cpu->env, 1);
|
tlb_flush(&cpu->env, 1);
|
||||||
/*tb_flush(&cpu->env); FIXME: Do we need it? */
|
/*tb_flush(&cpu->env); FIXME: Do we need it? */
|
||||||
|
@ -304,6 +304,7 @@ typedef struct CPUOpenRISCState {
|
|||||||
|
|
||||||
CPU_COMMON
|
CPU_COMMON
|
||||||
|
|
||||||
|
/* Fields from here on are preserved across CPU reset. */
|
||||||
#ifndef CONFIG_USER_ONLY
|
#ifndef CONFIG_USER_ONLY
|
||||||
CPUOpenRISCTLBContext * tlb;
|
CPUOpenRISCTLBContext * tlb;
|
||||||
|
|
||||||
|
@ -1619,10 +1619,11 @@ static void disas_openrisc_insn(DisasContext *dc, OpenRISCCPU *cpu)
|
|||||||
|
|
||||||
static void check_breakpoint(OpenRISCCPU *cpu, DisasContext *dc)
|
static void check_breakpoint(OpenRISCCPU *cpu, DisasContext *dc)
|
||||||
{
|
{
|
||||||
|
CPUState *cs = CPU(cpu);
|
||||||
CPUBreakpoint *bp;
|
CPUBreakpoint *bp;
|
||||||
|
|
||||||
if (unlikely(!QTAILQ_EMPTY(&cpu->env.breakpoints))) {
|
if (unlikely(!QTAILQ_EMPTY(&cs->breakpoints))) {
|
||||||
QTAILQ_FOREACH(bp, &cpu->env.breakpoints, entry) {
|
QTAILQ_FOREACH(bp, &cs->breakpoints, entry) {
|
||||||
if (bp->pc == dc->pc) {
|
if (bp->pc == dc->pc) {
|
||||||
tcg_gen_movi_tl(cpu_pc, dc->pc);
|
tcg_gen_movi_tl(cpu_pc, dc->pc);
|
||||||
gen_exception(dc, EXCP_DEBUG);
|
gen_exception(dc, EXCP_DEBUG);
|
||||||
|
@ -11377,8 +11377,8 @@ static inline void gen_intermediate_code_internal(PowerPCCPU *cpu,
|
|||||||
/* Set env in case of segfault during code fetch */
|
/* Set env in case of segfault during code fetch */
|
||||||
while (ctx.exception == POWERPC_EXCP_NONE
|
while (ctx.exception == POWERPC_EXCP_NONE
|
||||||
&& tcg_ctx.gen_opc_ptr < gen_opc_end) {
|
&& tcg_ctx.gen_opc_ptr < gen_opc_end) {
|
||||||
if (unlikely(!QTAILQ_EMPTY(&env->breakpoints))) {
|
if (unlikely(!QTAILQ_EMPTY(&cs->breakpoints))) {
|
||||||
QTAILQ_FOREACH(bp, &env->breakpoints, entry) {
|
QTAILQ_FOREACH(bp, &cs->breakpoints, entry) {
|
||||||
if (bp->pc == ctx.nip) {
|
if (bp->pc == ctx.nip) {
|
||||||
gen_debug_exception(ctxp);
|
gen_debug_exception(ctxp);
|
||||||
break;
|
break;
|
||||||
|
@ -109,7 +109,7 @@ static void s390_cpu_initial_reset(CPUState *s)
|
|||||||
|
|
||||||
s390_cpu_reset(s);
|
s390_cpu_reset(s);
|
||||||
/* initial reset does not touch regs,fregs and aregs */
|
/* initial reset does not touch regs,fregs and aregs */
|
||||||
memset(&env->fpc, 0, offsetof(CPUS390XState, breakpoints) -
|
memset(&env->fpc, 0, offsetof(CPUS390XState, cpu_num) -
|
||||||
offsetof(CPUS390XState, fpc));
|
offsetof(CPUS390XState, fpc));
|
||||||
|
|
||||||
/* architectured initial values for CR 0 and 14 */
|
/* architectured initial values for CR 0 and 14 */
|
||||||
@ -139,7 +139,7 @@ static void s390_cpu_full_reset(CPUState *s)
|
|||||||
|
|
||||||
scc->parent_reset(s);
|
scc->parent_reset(s);
|
||||||
|
|
||||||
memset(env, 0, offsetof(CPUS390XState, breakpoints));
|
memset(env, 0, offsetof(CPUS390XState, cpu_num));
|
||||||
|
|
||||||
/* architectured initial values for CR 0 and 14 */
|
/* architectured initial values for CR 0 and 14 */
|
||||||
env->cregs[0] = CR0_RESET;
|
env->cregs[0] = CR0_RESET;
|
||||||
|
@ -4795,8 +4795,8 @@ static inline void gen_intermediate_code_internal(S390CPU *cpu,
|
|||||||
}
|
}
|
||||||
|
|
||||||
status = NO_EXIT;
|
status = NO_EXIT;
|
||||||
if (unlikely(!QTAILQ_EMPTY(&env->breakpoints))) {
|
if (unlikely(!QTAILQ_EMPTY(&cs->breakpoints))) {
|
||||||
QTAILQ_FOREACH(bp, &env->breakpoints, entry) {
|
QTAILQ_FOREACH(bp, &cs->breakpoints, entry) {
|
||||||
if (bp->pc == dc.pc) {
|
if (bp->pc == dc.pc) {
|
||||||
status = EXIT_PC_STALE;
|
status = EXIT_PC_STALE;
|
||||||
do_debug = true;
|
do_debug = true;
|
||||||
|
@ -53,7 +53,7 @@ static void superh_cpu_reset(CPUState *s)
|
|||||||
|
|
||||||
scc->parent_reset(s);
|
scc->parent_reset(s);
|
||||||
|
|
||||||
memset(env, 0, offsetof(CPUSH4State, breakpoints));
|
memset(env, 0, offsetof(CPUSH4State, id));
|
||||||
tlb_flush(env, 1);
|
tlb_flush(env, 1);
|
||||||
|
|
||||||
env->pc = 0xA0000000;
|
env->pc = 0xA0000000;
|
||||||
|
@ -175,6 +175,7 @@ typedef struct CPUSH4State {
|
|||||||
|
|
||||||
CPU_COMMON
|
CPU_COMMON
|
||||||
|
|
||||||
|
/* Fields from here on are preserved over CPU reset. */
|
||||||
int id; /* CPU model */
|
int id; /* CPU model */
|
||||||
|
|
||||||
/* The features that we should emulate. See sh_features above. */
|
/* The features that we should emulate. See sh_features above. */
|
||||||
|
@ -1889,8 +1889,8 @@ gen_intermediate_code_internal(SuperHCPU *cpu, TranslationBlock *tb,
|
|||||||
max_insns = CF_COUNT_MASK;
|
max_insns = CF_COUNT_MASK;
|
||||||
gen_tb_start();
|
gen_tb_start();
|
||||||
while (ctx.bstate == BS_NONE && tcg_ctx.gen_opc_ptr < gen_opc_end) {
|
while (ctx.bstate == BS_NONE && tcg_ctx.gen_opc_ptr < gen_opc_end) {
|
||||||
if (unlikely(!QTAILQ_EMPTY(&env->breakpoints))) {
|
if (unlikely(!QTAILQ_EMPTY(&cs->breakpoints))) {
|
||||||
QTAILQ_FOREACH(bp, &env->breakpoints, entry) {
|
QTAILQ_FOREACH(bp, &cs->breakpoints, entry) {
|
||||||
if (ctx.pc == bp->pc) {
|
if (ctx.pc == bp->pc) {
|
||||||
/* We have hit a breakpoint - make sure PC is up-to-date */
|
/* We have hit a breakpoint - make sure PC is up-to-date */
|
||||||
tcg_gen_movi_i32(cpu_pc, ctx.pc);
|
tcg_gen_movi_i32(cpu_pc, ctx.pc);
|
||||||
|
@ -33,7 +33,7 @@ static void sparc_cpu_reset(CPUState *s)
|
|||||||
|
|
||||||
scc->parent_reset(s);
|
scc->parent_reset(s);
|
||||||
|
|
||||||
memset(env, 0, offsetof(CPUSPARCState, breakpoints));
|
memset(env, 0, offsetof(CPUSPARCState, version));
|
||||||
tlb_flush(env, 1);
|
tlb_flush(env, 1);
|
||||||
env->cwp = 0;
|
env->cwp = 0;
|
||||||
#ifndef TARGET_SPARC64
|
#ifndef TARGET_SPARC64
|
||||||
|
@ -423,6 +423,7 @@ struct CPUSPARCState {
|
|||||||
|
|
||||||
CPU_COMMON
|
CPU_COMMON
|
||||||
|
|
||||||
|
/* Fields from here on are preserved across CPU reset. */
|
||||||
target_ulong version;
|
target_ulong version;
|
||||||
uint32_t nwindows;
|
uint32_t nwindows;
|
||||||
|
|
||||||
|
@ -5270,8 +5270,8 @@ static inline void gen_intermediate_code_internal(SPARCCPU *cpu,
|
|||||||
max_insns = CF_COUNT_MASK;
|
max_insns = CF_COUNT_MASK;
|
||||||
gen_tb_start();
|
gen_tb_start();
|
||||||
do {
|
do {
|
||||||
if (unlikely(!QTAILQ_EMPTY(&env->breakpoints))) {
|
if (unlikely(!QTAILQ_EMPTY(&cs->breakpoints))) {
|
||||||
QTAILQ_FOREACH(bp, &env->breakpoints, entry) {
|
QTAILQ_FOREACH(bp, &cs->breakpoints, entry) {
|
||||||
if (bp->pc == dc->pc) {
|
if (bp->pc == dc->pc) {
|
||||||
if (dc->pc != pc_start)
|
if (dc->pc != pc_start)
|
||||||
save_state(dc);
|
save_state(dc);
|
||||||
|
@ -1922,8 +1922,8 @@ static inline void gen_intermediate_code_internal(UniCore32CPU *cpu,
|
|||||||
|
|
||||||
gen_tb_start();
|
gen_tb_start();
|
||||||
do {
|
do {
|
||||||
if (unlikely(!QTAILQ_EMPTY(&env->breakpoints))) {
|
if (unlikely(!QTAILQ_EMPTY(&cs->breakpoints))) {
|
||||||
QTAILQ_FOREACH(bp, &env->breakpoints, entry) {
|
QTAILQ_FOREACH(bp, &cs->breakpoints, entry) {
|
||||||
if (bp->pc == dc->pc) {
|
if (bp->pc == dc->pc) {
|
||||||
gen_set_pc_im(dc->pc);
|
gen_set_pc_im(dc->pc);
|
||||||
gen_exception(EXCP_DEBUG);
|
gen_exception(EXCP_DEBUG);
|
||||||
|
@ -2948,10 +2948,11 @@ invalid_opcode:
|
|||||||
|
|
||||||
static void check_breakpoint(CPUXtensaState *env, DisasContext *dc)
|
static void check_breakpoint(CPUXtensaState *env, DisasContext *dc)
|
||||||
{
|
{
|
||||||
|
CPUState *cs = CPU(xtensa_env_get_cpu(env));
|
||||||
CPUBreakpoint *bp;
|
CPUBreakpoint *bp;
|
||||||
|
|
||||||
if (unlikely(!QTAILQ_EMPTY(&env->breakpoints))) {
|
if (unlikely(!QTAILQ_EMPTY(&cs->breakpoints))) {
|
||||||
QTAILQ_FOREACH(bp, &env->breakpoints, entry) {
|
QTAILQ_FOREACH(bp, &cs->breakpoints, entry) {
|
||||||
if (bp->pc == dc->pc) {
|
if (bp->pc == dc->pc) {
|
||||||
tcg_gen_movi_i32(cpu_pc, dc->pc);
|
tcg_gen_movi_i32(cpu_pc, dc->pc);
|
||||||
gen_exception(dc, EXCP_DEBUG);
|
gen_exception(dc, EXCP_DEBUG);
|
||||||
|
Loading…
Reference in New Issue
Block a user