Skip to content

Commit

Permalink
target/lm32: Use env_cpu, env_archcpu
Browse files Browse the repository at this point in the history
Cleanup in the boilerplate that each target must define.
Replace lm32_env_get_cpu with env_archcpu.  The combination
CPU(lm32_env_get_cpu) should have used ENV_GET_CPU to begin;
use env_cpu now.

Reviewed-by: Alistair Francis <[email protected]>
Reviewed-by: Peter Maydell <[email protected]>
Signed-off-by: Richard Henderson <[email protected]>
  • Loading branch information
rth7680 committed Jun 10, 2019
1 parent 6aa9e42 commit 6dd40a9
Show file tree
Hide file tree
Showing 4 changed files with 10 additions and 22 deletions.
5 changes: 0 additions & 5 deletions target/lm32/cpu.h
Original file line number Diff line number Diff line change
Expand Up @@ -195,11 +195,6 @@ struct LM32CPU {
uint32_t features;
};

static inline LM32CPU *lm32_env_get_cpu(CPULM32State *env)
{
return container_of(env, LM32CPU, env);
}

#define ENV_OFFSET offsetof(LM32CPU, env)

#ifndef CONFIG_USER_ONLY
Expand Down
19 changes: 6 additions & 13 deletions target/lm32/helper.c
Original file line number Diff line number Diff line change
Expand Up @@ -58,28 +58,23 @@ hwaddr lm32_cpu_get_phys_page_debug(CPUState *cs, vaddr addr)

void lm32_breakpoint_insert(CPULM32State *env, int idx, target_ulong address)
{
LM32CPU *cpu = lm32_env_get_cpu(env);

cpu_breakpoint_insert(CPU(cpu), address, BP_CPU,
cpu_breakpoint_insert(env_cpu(env), address, BP_CPU,
&env->cpu_breakpoint[idx]);
}

void lm32_breakpoint_remove(CPULM32State *env, int idx)
{
LM32CPU *cpu = lm32_env_get_cpu(env);

if (!env->cpu_breakpoint[idx]) {
return;
}

cpu_breakpoint_remove_by_ref(CPU(cpu), env->cpu_breakpoint[idx]);
cpu_breakpoint_remove_by_ref(env_cpu(env), env->cpu_breakpoint[idx]);
env->cpu_breakpoint[idx] = NULL;
}

void lm32_watchpoint_insert(CPULM32State *env, int idx, target_ulong address,
lm32_wp_t wp_type)
{
LM32CPU *cpu = lm32_env_get_cpu(env);
int flags = 0;

switch (wp_type) {
Expand All @@ -98,26 +93,24 @@ void lm32_watchpoint_insert(CPULM32State *env, int idx, target_ulong address,
}

if (flags != 0) {
cpu_watchpoint_insert(CPU(cpu), address, 1, flags,
&env->cpu_watchpoint[idx]);
cpu_watchpoint_insert(env_cpu(env), address, 1, flags,
&env->cpu_watchpoint[idx]);
}
}

void lm32_watchpoint_remove(CPULM32State *env, int idx)
{
LM32CPU *cpu = lm32_env_get_cpu(env);

if (!env->cpu_watchpoint[idx]) {
return;
}

cpu_watchpoint_remove_by_ref(CPU(cpu), env->cpu_watchpoint[idx]);
cpu_watchpoint_remove_by_ref(env_cpu(env), env->cpu_watchpoint[idx]);
env->cpu_watchpoint[idx] = NULL;
}

static bool check_watchpoints(CPULM32State *env)
{
LM32CPU *cpu = lm32_env_get_cpu(env);
LM32CPU *cpu = env_archcpu(env);
int i;

for (i = 0; i < cpu->num_watchpoints; i++) {
Expand Down
6 changes: 3 additions & 3 deletions target/lm32/op_helper.c
Original file line number Diff line number Diff line change
Expand Up @@ -16,7 +16,7 @@
#if !defined(CONFIG_USER_ONLY)
void raise_exception(CPULM32State *env, int index)
{
CPUState *cs = CPU(lm32_env_get_cpu(env));
CPUState *cs = env_cpu(env);

cs->exception_index = index;
cpu_loop_exit(cs);
Expand All @@ -29,7 +29,7 @@ void HELPER(raise_exception)(CPULM32State *env, uint32_t index)

void HELPER(hlt)(CPULM32State *env)
{
CPUState *cs = CPU(lm32_env_get_cpu(env));
CPUState *cs = env_cpu(env);

cs->halted = 1;
cs->exception_index = EXCP_HLT;
Expand All @@ -39,7 +39,7 @@ void HELPER(hlt)(CPULM32State *env)
void HELPER(ill)(CPULM32State *env)
{
#ifndef CONFIG_USER_ONLY
CPUState *cs = CPU(lm32_env_get_cpu(env));
CPUState *cs = env_cpu(env);
fprintf(stderr, "VM paused due to illegal instruction. "
"Connect a debugger or switch to the monitor console "
"to find out more.\n");
Expand Down
2 changes: 1 addition & 1 deletion target/lm32/translate.c
Original file line number Diff line number Diff line change
Expand Up @@ -1053,7 +1053,7 @@ static inline void decode(DisasContext *dc, uint32_t ir)
void gen_intermediate_code(CPUState *cs, TranslationBlock *tb, int max_insns)
{
CPULM32State *env = cs->env_ptr;
LM32CPU *cpu = lm32_env_get_cpu(env);
LM32CPU *cpu = env_archcpu(env);
struct DisasContext ctx, *dc = &ctx;
uint32_t pc_start;
uint32_t page_start;
Expand Down

0 comments on commit 6dd40a9

Please sign in to comment.