Skip to content

Commit

Permalink
target-cris: Override do_interrupt for pre-v32 CPU cores
Browse files Browse the repository at this point in the history
Instead of forwarding from cris_cpu_do_interrupt() to do_interruptv10(),
override CPUClass::do_interrupt with crisv10_cpu_do_interrupt() in the
newly introduced class_init functions.

Acked-by: Edgar E. Iglesias <edgar.iglesias@gmail.com>
Signed-off-by: Andreas Färber <afaerber@suse.de>
  • Loading branch information
afaerber committed Apr 16, 2013
1 parent a7ddba5 commit b21bfee
Show file tree
Hide file tree
Showing 3 changed files with 17 additions and 6 deletions.
1 change: 1 addition & 0 deletions target-cris/cpu-qom.h
Expand Up @@ -74,5 +74,6 @@ static inline CRISCPU *cris_env_get_cpu(CPUCRISState *env)
#define ENV_OFFSET offsetof(CRISCPU, env)

void cris_cpu_do_interrupt(CPUState *cpu);
void crisv10_cpu_do_interrupt(CPUState *cpu);

#endif
8 changes: 8 additions & 0 deletions target-cris/cpu.c
Expand Up @@ -169,30 +169,38 @@ static void cris_cpu_initfn(Object *obj)

static void crisv8_cpu_class_init(ObjectClass *oc, void *data)
{
CPUClass *cc = CPU_CLASS(oc);
CRISCPUClass *ccc = CRIS_CPU_CLASS(oc);

ccc->vr = 8;
cc->do_interrupt = crisv10_cpu_do_interrupt;
}

static void crisv9_cpu_class_init(ObjectClass *oc, void *data)
{
CPUClass *cc = CPU_CLASS(oc);
CRISCPUClass *ccc = CRIS_CPU_CLASS(oc);

ccc->vr = 9;
cc->do_interrupt = crisv10_cpu_do_interrupt;
}

static void crisv10_cpu_class_init(ObjectClass *oc, void *data)
{
CPUClass *cc = CPU_CLASS(oc);
CRISCPUClass *ccc = CRIS_CPU_CLASS(oc);

ccc->vr = 10;
cc->do_interrupt = crisv10_cpu_do_interrupt;
}

static void crisv11_cpu_class_init(ObjectClass *oc, void *data)
{
CPUClass *cc = CPU_CLASS(oc);
CRISCPUClass *ccc = CRIS_CPU_CLASS(oc);

ccc->vr = 11;
cc->do_interrupt = crisv10_cpu_do_interrupt;
}

static void crisv32_cpu_class_init(ObjectClass *oc, void *data)
Expand Down
14 changes: 8 additions & 6 deletions target-cris/helper.c
Expand Up @@ -45,6 +45,11 @@ void cris_cpu_do_interrupt(CPUState *cs)
env->pregs[PR_ERP] = env->pc;
}

void crisv10_cpu_do_interrupt(CPUState *cs)
{
cris_cpu_do_interrupt(cs);
}

int cpu_cris_handle_mmu_fault(CPUCRISState * env, target_ulong address, int rw,
int mmu_idx)
{
Expand Down Expand Up @@ -109,9 +114,10 @@ int cpu_cris_handle_mmu_fault(CPUCRISState *env, target_ulong address, int rw,
return r;
}

static void do_interruptv10(CPUCRISState *env)
void crisv10_cpu_do_interrupt(CPUState *cs)
{
D(CPUState *cs = CPU(cris_env_get_cpu(env)));
CRISCPU *cpu = CRIS_CPU(cs);
CPUCRISState *env = &cpu->env;
int ex_vec = -1;

D_LOG("exception index=%d interrupt_req=%d\n",
Expand Down Expand Up @@ -171,10 +177,6 @@ void cris_cpu_do_interrupt(CPUState *cs)
CPUCRISState *env = &cpu->env;
int ex_vec = -1;

if (env->pregs[PR_VR] < 32) {
return do_interruptv10(env);
}

D_LOG("exception index=%d interrupt_req=%d\n",
env->exception_index,
cs->interrupt_request);
Expand Down

0 comments on commit b21bfee

Please sign in to comment.