exec: Change cpu_abort() argument to CPUState
Signed-off-by: Andreas Färber <afaerber@suse.de>
This commit is contained in:
parent
bb0e627a84
commit
a47dddd734
2
cputlb.c
2
cputlb.c
@ -322,7 +322,7 @@ tb_page_addr_t get_page_addr_code(CPUArchState *env1, target_ulong addr)
|
|||||||
if (cc->do_unassigned_access) {
|
if (cc->do_unassigned_access) {
|
||||||
cc->do_unassigned_access(cpu, addr, false, true, 0, 4);
|
cc->do_unassigned_access(cpu, addr, false, true, 0, 4);
|
||||||
} else {
|
} else {
|
||||||
cpu_abort(env1, "Trying to execute code outside RAM or ROM at 0x"
|
cpu_abort(cpu, "Trying to execute code outside RAM or ROM at 0x"
|
||||||
TARGET_FMT_lx "\n", addr);
|
TARGET_FMT_lx "\n", addr);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
3
exec.c
3
exec.c
@ -709,9 +709,8 @@ void cpu_single_step(CPUState *cpu, int enabled)
|
|||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
void cpu_abort(CPUArchState *env, const char *fmt, ...)
|
void cpu_abort(CPUState *cpu, const char *fmt, ...)
|
||||||
{
|
{
|
||||||
CPUState *cpu = ENV_GET_CPU(env);
|
|
||||||
va_list ap;
|
va_list ap;
|
||||||
va_list ap2;
|
va_list ap2;
|
||||||
|
|
||||||
|
@ -360,9 +360,6 @@ int page_check_range(target_ulong start, target_ulong len, int flags);
|
|||||||
|
|
||||||
CPUArchState *cpu_copy(CPUArchState *env);
|
CPUArchState *cpu_copy(CPUArchState *env);
|
||||||
|
|
||||||
void QEMU_NORETURN cpu_abort(CPUArchState *env, const char *fmt, ...)
|
|
||||||
GCC_FMT_ATTR(2, 3);
|
|
||||||
|
|
||||||
/* Flags for use in ENV->INTERRUPT_PENDING.
|
/* Flags for use in ENV->INTERRUPT_PENDING.
|
||||||
|
|
||||||
The numbers assigned here are non-sequential in order to preserve
|
The numbers assigned here are non-sequential in order to preserve
|
||||||
|
@ -617,6 +617,9 @@ int cpu_watchpoint_remove(CPUState *cpu, vaddr addr,
|
|||||||
void cpu_watchpoint_remove_by_ref(CPUState *cpu, CPUWatchpoint *watchpoint);
|
void cpu_watchpoint_remove_by_ref(CPUState *cpu, CPUWatchpoint *watchpoint);
|
||||||
void cpu_watchpoint_remove_all(CPUState *cpu, int mask);
|
void cpu_watchpoint_remove_all(CPUState *cpu, int mask);
|
||||||
|
|
||||||
|
void QEMU_NORETURN cpu_abort(CPUState *cpu, const char *fmt, ...)
|
||||||
|
GCC_FMT_ATTR(2, 3);
|
||||||
|
|
||||||
#ifdef CONFIG_SOFTMMU
|
#ifdef CONFIG_SOFTMMU
|
||||||
extern const struct VMStateDescription vmstate_cpu_common;
|
extern const struct VMStateDescription vmstate_cpu_common;
|
||||||
#else
|
#else
|
||||||
|
@ -98,6 +98,7 @@ static int translate_openflags(int flags)
|
|||||||
#define ARG(x) tswap32(args[x])
|
#define ARG(x) tswap32(args[x])
|
||||||
void do_m68k_simcall(CPUM68KState *env, int nr)
|
void do_m68k_simcall(CPUM68KState *env, int nr)
|
||||||
{
|
{
|
||||||
|
M68kCPU *cpu = m68k_env_get_cpu(env);
|
||||||
uint32_t *args;
|
uint32_t *args;
|
||||||
|
|
||||||
args = (uint32_t *)(unsigned long)(env->aregs[7] + 4);
|
args = (uint32_t *)(unsigned long)(env->aregs[7] + 4);
|
||||||
@ -165,6 +166,6 @@ void do_m68k_simcall(CPUM68KState *env, int nr)
|
|||||||
check_err(env, lseek(ARG(0), (int32_t)ARG(1), ARG(2)));
|
check_err(env, lseek(ARG(0), (int32_t)ARG(1), ARG(2)));
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
cpu_abort(env, "Unsupported m68k sim syscall %d\n", nr);
|
cpu_abort(CPU(cpu), "Unsupported m68k sim syscall %d\n", nr);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -1577,11 +1577,11 @@ void cpu_loop(CPUPPCState *env)
|
|||||||
/* Just go on */
|
/* Just go on */
|
||||||
break;
|
break;
|
||||||
case POWERPC_EXCP_CRITICAL: /* Critical input */
|
case POWERPC_EXCP_CRITICAL: /* Critical input */
|
||||||
cpu_abort(env, "Critical interrupt while in user mode. "
|
cpu_abort(cs, "Critical interrupt while in user mode. "
|
||||||
"Aborting\n");
|
"Aborting\n");
|
||||||
break;
|
break;
|
||||||
case POWERPC_EXCP_MCHECK: /* Machine check exception */
|
case POWERPC_EXCP_MCHECK: /* Machine check exception */
|
||||||
cpu_abort(env, "Machine check exception while in user mode. "
|
cpu_abort(cs, "Machine check exception while in user mode. "
|
||||||
"Aborting\n");
|
"Aborting\n");
|
||||||
break;
|
break;
|
||||||
case POWERPC_EXCP_DSI: /* Data storage exception */
|
case POWERPC_EXCP_DSI: /* Data storage exception */
|
||||||
@ -1645,7 +1645,7 @@ void cpu_loop(CPUPPCState *env)
|
|||||||
queue_signal(env, info.si_signo, &info);
|
queue_signal(env, info.si_signo, &info);
|
||||||
break;
|
break;
|
||||||
case POWERPC_EXCP_EXTERNAL: /* External input */
|
case POWERPC_EXCP_EXTERNAL: /* External input */
|
||||||
cpu_abort(env, "External interrupt while in user mode. "
|
cpu_abort(cs, "External interrupt while in user mode. "
|
||||||
"Aborting\n");
|
"Aborting\n");
|
||||||
break;
|
break;
|
||||||
case POWERPC_EXCP_ALIGN: /* Alignment exception */
|
case POWERPC_EXCP_ALIGN: /* Alignment exception */
|
||||||
@ -1739,11 +1739,11 @@ void cpu_loop(CPUPPCState *env)
|
|||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case POWERPC_EXCP_TRAP:
|
case POWERPC_EXCP_TRAP:
|
||||||
cpu_abort(env, "Tried to call a TRAP\n");
|
cpu_abort(cs, "Tried to call a TRAP\n");
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
/* Should not happen ! */
|
/* Should not happen ! */
|
||||||
cpu_abort(env, "Unknown program exception (%02x)\n",
|
cpu_abort(cs, "Unknown program exception (%02x)\n",
|
||||||
env->error_code);
|
env->error_code);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
@ -1759,7 +1759,7 @@ void cpu_loop(CPUPPCState *env)
|
|||||||
queue_signal(env, info.si_signo, &info);
|
queue_signal(env, info.si_signo, &info);
|
||||||
break;
|
break;
|
||||||
case POWERPC_EXCP_SYSCALL: /* System call exception */
|
case POWERPC_EXCP_SYSCALL: /* System call exception */
|
||||||
cpu_abort(env, "Syscall exception while in user mode. "
|
cpu_abort(cs, "Syscall exception while in user mode. "
|
||||||
"Aborting\n");
|
"Aborting\n");
|
||||||
break;
|
break;
|
||||||
case POWERPC_EXCP_APU: /* Auxiliary processor unavailable */
|
case POWERPC_EXCP_APU: /* Auxiliary processor unavailable */
|
||||||
@ -1771,23 +1771,23 @@ void cpu_loop(CPUPPCState *env)
|
|||||||
queue_signal(env, info.si_signo, &info);
|
queue_signal(env, info.si_signo, &info);
|
||||||
break;
|
break;
|
||||||
case POWERPC_EXCP_DECR: /* Decrementer exception */
|
case POWERPC_EXCP_DECR: /* Decrementer exception */
|
||||||
cpu_abort(env, "Decrementer interrupt while in user mode. "
|
cpu_abort(cs, "Decrementer interrupt while in user mode. "
|
||||||
"Aborting\n");
|
"Aborting\n");
|
||||||
break;
|
break;
|
||||||
case POWERPC_EXCP_FIT: /* Fixed-interval timer interrupt */
|
case POWERPC_EXCP_FIT: /* Fixed-interval timer interrupt */
|
||||||
cpu_abort(env, "Fix interval timer interrupt while in user mode. "
|
cpu_abort(cs, "Fix interval timer interrupt while in user mode. "
|
||||||
"Aborting\n");
|
"Aborting\n");
|
||||||
break;
|
break;
|
||||||
case POWERPC_EXCP_WDT: /* Watchdog timer interrupt */
|
case POWERPC_EXCP_WDT: /* Watchdog timer interrupt */
|
||||||
cpu_abort(env, "Watchdog timer interrupt while in user mode. "
|
cpu_abort(cs, "Watchdog timer interrupt while in user mode. "
|
||||||
"Aborting\n");
|
"Aborting\n");
|
||||||
break;
|
break;
|
||||||
case POWERPC_EXCP_DTLB: /* Data TLB error */
|
case POWERPC_EXCP_DTLB: /* Data TLB error */
|
||||||
cpu_abort(env, "Data TLB exception while in user mode. "
|
cpu_abort(cs, "Data TLB exception while in user mode. "
|
||||||
"Aborting\n");
|
"Aborting\n");
|
||||||
break;
|
break;
|
||||||
case POWERPC_EXCP_ITLB: /* Instruction TLB error */
|
case POWERPC_EXCP_ITLB: /* Instruction TLB error */
|
||||||
cpu_abort(env, "Instruction TLB exception while in user mode. "
|
cpu_abort(cs, "Instruction TLB exception while in user mode. "
|
||||||
"Aborting\n");
|
"Aborting\n");
|
||||||
break;
|
break;
|
||||||
case POWERPC_EXCP_SPEU: /* SPE/embedded floating-point unavail. */
|
case POWERPC_EXCP_SPEU: /* SPE/embedded floating-point unavail. */
|
||||||
@ -1799,37 +1799,37 @@ void cpu_loop(CPUPPCState *env)
|
|||||||
queue_signal(env, info.si_signo, &info);
|
queue_signal(env, info.si_signo, &info);
|
||||||
break;
|
break;
|
||||||
case POWERPC_EXCP_EFPDI: /* Embedded floating-point data IRQ */
|
case POWERPC_EXCP_EFPDI: /* Embedded floating-point data IRQ */
|
||||||
cpu_abort(env, "Embedded floating-point data IRQ not handled\n");
|
cpu_abort(cs, "Embedded floating-point data IRQ not handled\n");
|
||||||
break;
|
break;
|
||||||
case POWERPC_EXCP_EFPRI: /* Embedded floating-point round IRQ */
|
case POWERPC_EXCP_EFPRI: /* Embedded floating-point round IRQ */
|
||||||
cpu_abort(env, "Embedded floating-point round IRQ not handled\n");
|
cpu_abort(cs, "Embedded floating-point round IRQ not handled\n");
|
||||||
break;
|
break;
|
||||||
case POWERPC_EXCP_EPERFM: /* Embedded performance monitor IRQ */
|
case POWERPC_EXCP_EPERFM: /* Embedded performance monitor IRQ */
|
||||||
cpu_abort(env, "Performance monitor exception not handled\n");
|
cpu_abort(cs, "Performance monitor exception not handled\n");
|
||||||
break;
|
break;
|
||||||
case POWERPC_EXCP_DOORI: /* Embedded doorbell interrupt */
|
case POWERPC_EXCP_DOORI: /* Embedded doorbell interrupt */
|
||||||
cpu_abort(env, "Doorbell interrupt while in user mode. "
|
cpu_abort(cs, "Doorbell interrupt while in user mode. "
|
||||||
"Aborting\n");
|
"Aborting\n");
|
||||||
break;
|
break;
|
||||||
case POWERPC_EXCP_DOORCI: /* Embedded doorbell critical interrupt */
|
case POWERPC_EXCP_DOORCI: /* Embedded doorbell critical interrupt */
|
||||||
cpu_abort(env, "Doorbell critical interrupt while in user mode. "
|
cpu_abort(cs, "Doorbell critical interrupt while in user mode. "
|
||||||
"Aborting\n");
|
"Aborting\n");
|
||||||
break;
|
break;
|
||||||
case POWERPC_EXCP_RESET: /* System reset exception */
|
case POWERPC_EXCP_RESET: /* System reset exception */
|
||||||
cpu_abort(env, "Reset interrupt while in user mode. "
|
cpu_abort(cs, "Reset interrupt while in user mode. "
|
||||||
"Aborting\n");
|
"Aborting\n");
|
||||||
break;
|
break;
|
||||||
case POWERPC_EXCP_DSEG: /* Data segment exception */
|
case POWERPC_EXCP_DSEG: /* Data segment exception */
|
||||||
cpu_abort(env, "Data segment exception while in user mode. "
|
cpu_abort(cs, "Data segment exception while in user mode. "
|
||||||
"Aborting\n");
|
"Aborting\n");
|
||||||
break;
|
break;
|
||||||
case POWERPC_EXCP_ISEG: /* Instruction segment exception */
|
case POWERPC_EXCP_ISEG: /* Instruction segment exception */
|
||||||
cpu_abort(env, "Instruction segment exception "
|
cpu_abort(cs, "Instruction segment exception "
|
||||||
"while in user mode. Aborting\n");
|
"while in user mode. Aborting\n");
|
||||||
break;
|
break;
|
||||||
/* PowerPC 64 with hypervisor mode support */
|
/* PowerPC 64 with hypervisor mode support */
|
||||||
case POWERPC_EXCP_HDECR: /* Hypervisor decrementer exception */
|
case POWERPC_EXCP_HDECR: /* Hypervisor decrementer exception */
|
||||||
cpu_abort(env, "Hypervisor decrementer interrupt "
|
cpu_abort(cs, "Hypervisor decrementer interrupt "
|
||||||
"while in user mode. Aborting\n");
|
"while in user mode. Aborting\n");
|
||||||
break;
|
break;
|
||||||
case POWERPC_EXCP_TRACE: /* Trace exception */
|
case POWERPC_EXCP_TRACE: /* Trace exception */
|
||||||
@ -1839,19 +1839,19 @@ void cpu_loop(CPUPPCState *env)
|
|||||||
break;
|
break;
|
||||||
/* PowerPC 64 with hypervisor mode support */
|
/* PowerPC 64 with hypervisor mode support */
|
||||||
case POWERPC_EXCP_HDSI: /* Hypervisor data storage exception */
|
case POWERPC_EXCP_HDSI: /* Hypervisor data storage exception */
|
||||||
cpu_abort(env, "Hypervisor data storage exception "
|
cpu_abort(cs, "Hypervisor data storage exception "
|
||||||
"while in user mode. Aborting\n");
|
"while in user mode. Aborting\n");
|
||||||
break;
|
break;
|
||||||
case POWERPC_EXCP_HISI: /* Hypervisor instruction storage excp */
|
case POWERPC_EXCP_HISI: /* Hypervisor instruction storage excp */
|
||||||
cpu_abort(env, "Hypervisor instruction storage exception "
|
cpu_abort(cs, "Hypervisor instruction storage exception "
|
||||||
"while in user mode. Aborting\n");
|
"while in user mode. Aborting\n");
|
||||||
break;
|
break;
|
||||||
case POWERPC_EXCP_HDSEG: /* Hypervisor data segment exception */
|
case POWERPC_EXCP_HDSEG: /* Hypervisor data segment exception */
|
||||||
cpu_abort(env, "Hypervisor data segment exception "
|
cpu_abort(cs, "Hypervisor data segment exception "
|
||||||
"while in user mode. Aborting\n");
|
"while in user mode. Aborting\n");
|
||||||
break;
|
break;
|
||||||
case POWERPC_EXCP_HISEG: /* Hypervisor instruction segment excp */
|
case POWERPC_EXCP_HISEG: /* Hypervisor instruction segment excp */
|
||||||
cpu_abort(env, "Hypervisor instruction segment exception "
|
cpu_abort(cs, "Hypervisor instruction segment exception "
|
||||||
"while in user mode. Aborting\n");
|
"while in user mode. Aborting\n");
|
||||||
break;
|
break;
|
||||||
case POWERPC_EXCP_VPU: /* Vector unavailable exception */
|
case POWERPC_EXCP_VPU: /* Vector unavailable exception */
|
||||||
@ -1863,58 +1863,58 @@ void cpu_loop(CPUPPCState *env)
|
|||||||
queue_signal(env, info.si_signo, &info);
|
queue_signal(env, info.si_signo, &info);
|
||||||
break;
|
break;
|
||||||
case POWERPC_EXCP_PIT: /* Programmable interval timer IRQ */
|
case POWERPC_EXCP_PIT: /* Programmable interval timer IRQ */
|
||||||
cpu_abort(env, "Programmable interval timer interrupt "
|
cpu_abort(cs, "Programmable interval timer interrupt "
|
||||||
"while in user mode. Aborting\n");
|
"while in user mode. Aborting\n");
|
||||||
break;
|
break;
|
||||||
case POWERPC_EXCP_IO: /* IO error exception */
|
case POWERPC_EXCP_IO: /* IO error exception */
|
||||||
cpu_abort(env, "IO error exception while in user mode. "
|
cpu_abort(cs, "IO error exception while in user mode. "
|
||||||
"Aborting\n");
|
"Aborting\n");
|
||||||
break;
|
break;
|
||||||
case POWERPC_EXCP_RUNM: /* Run mode exception */
|
case POWERPC_EXCP_RUNM: /* Run mode exception */
|
||||||
cpu_abort(env, "Run mode exception while in user mode. "
|
cpu_abort(cs, "Run mode exception while in user mode. "
|
||||||
"Aborting\n");
|
"Aborting\n");
|
||||||
break;
|
break;
|
||||||
case POWERPC_EXCP_EMUL: /* Emulation trap exception */
|
case POWERPC_EXCP_EMUL: /* Emulation trap exception */
|
||||||
cpu_abort(env, "Emulation trap exception not handled\n");
|
cpu_abort(cs, "Emulation trap exception not handled\n");
|
||||||
break;
|
break;
|
||||||
case POWERPC_EXCP_IFTLB: /* Instruction fetch TLB error */
|
case POWERPC_EXCP_IFTLB: /* Instruction fetch TLB error */
|
||||||
cpu_abort(env, "Instruction fetch TLB exception "
|
cpu_abort(cs, "Instruction fetch TLB exception "
|
||||||
"while in user-mode. Aborting");
|
"while in user-mode. Aborting");
|
||||||
break;
|
break;
|
||||||
case POWERPC_EXCP_DLTLB: /* Data load TLB miss */
|
case POWERPC_EXCP_DLTLB: /* Data load TLB miss */
|
||||||
cpu_abort(env, "Data load TLB exception while in user-mode. "
|
cpu_abort(cs, "Data load TLB exception while in user-mode. "
|
||||||
"Aborting");
|
"Aborting");
|
||||||
break;
|
break;
|
||||||
case POWERPC_EXCP_DSTLB: /* Data store TLB miss */
|
case POWERPC_EXCP_DSTLB: /* Data store TLB miss */
|
||||||
cpu_abort(env, "Data store TLB exception while in user-mode. "
|
cpu_abort(cs, "Data store TLB exception while in user-mode. "
|
||||||
"Aborting");
|
"Aborting");
|
||||||
break;
|
break;
|
||||||
case POWERPC_EXCP_FPA: /* Floating-point assist exception */
|
case POWERPC_EXCP_FPA: /* Floating-point assist exception */
|
||||||
cpu_abort(env, "Floating-point assist exception not handled\n");
|
cpu_abort(cs, "Floating-point assist exception not handled\n");
|
||||||
break;
|
break;
|
||||||
case POWERPC_EXCP_IABR: /* Instruction address breakpoint */
|
case POWERPC_EXCP_IABR: /* Instruction address breakpoint */
|
||||||
cpu_abort(env, "Instruction address breakpoint exception "
|
cpu_abort(cs, "Instruction address breakpoint exception "
|
||||||
"not handled\n");
|
"not handled\n");
|
||||||
break;
|
break;
|
||||||
case POWERPC_EXCP_SMI: /* System management interrupt */
|
case POWERPC_EXCP_SMI: /* System management interrupt */
|
||||||
cpu_abort(env, "System management interrupt while in user mode. "
|
cpu_abort(cs, "System management interrupt while in user mode. "
|
||||||
"Aborting\n");
|
"Aborting\n");
|
||||||
break;
|
break;
|
||||||
case POWERPC_EXCP_THERM: /* Thermal interrupt */
|
case POWERPC_EXCP_THERM: /* Thermal interrupt */
|
||||||
cpu_abort(env, "Thermal interrupt interrupt while in user mode. "
|
cpu_abort(cs, "Thermal interrupt interrupt while in user mode. "
|
||||||
"Aborting\n");
|
"Aborting\n");
|
||||||
break;
|
break;
|
||||||
case POWERPC_EXCP_PERFM: /* Embedded performance monitor IRQ */
|
case POWERPC_EXCP_PERFM: /* Embedded performance monitor IRQ */
|
||||||
cpu_abort(env, "Performance monitor exception not handled\n");
|
cpu_abort(cs, "Performance monitor exception not handled\n");
|
||||||
break;
|
break;
|
||||||
case POWERPC_EXCP_VPUA: /* Vector assist exception */
|
case POWERPC_EXCP_VPUA: /* Vector assist exception */
|
||||||
cpu_abort(env, "Vector assist exception not handled\n");
|
cpu_abort(cs, "Vector assist exception not handled\n");
|
||||||
break;
|
break;
|
||||||
case POWERPC_EXCP_SOFTP: /* Soft patch exception */
|
case POWERPC_EXCP_SOFTP: /* Soft patch exception */
|
||||||
cpu_abort(env, "Soft patch exception not handled\n");
|
cpu_abort(cs, "Soft patch exception not handled\n");
|
||||||
break;
|
break;
|
||||||
case POWERPC_EXCP_MAINT: /* Maintenance exception */
|
case POWERPC_EXCP_MAINT: /* Maintenance exception */
|
||||||
cpu_abort(env, "Maintenance exception while in user mode. "
|
cpu_abort(cs, "Maintenance exception while in user mode. "
|
||||||
"Aborting\n");
|
"Aborting\n");
|
||||||
break;
|
break;
|
||||||
case POWERPC_EXCP_STOP: /* stop translation */
|
case POWERPC_EXCP_STOP: /* stop translation */
|
||||||
@ -1970,7 +1970,7 @@ void cpu_loop(CPUPPCState *env)
|
|||||||
/* just indicate that signals should be handled asap */
|
/* just indicate that signals should be handled asap */
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
cpu_abort(env, "Unknown exception 0x%d. Aborting\n", trapnr);
|
cpu_abort(cs, "Unknown exception 0x%d. Aborting\n", trapnr);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
process_pending_signals(env);
|
process_pending_signals(env);
|
||||||
|
@ -452,7 +452,7 @@ void alpha_cpu_do_interrupt(CPUState *cs)
|
|||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
cpu_abort(env, "Unhandled CPU exception");
|
cpu_abort(cs, "Unhandled CPU exception");
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Remember where the exception happened. Emulate real hardware in
|
/* Remember where the exception happened. Emulate real hardware in
|
||||||
|
@ -2671,29 +2671,40 @@ int arm_cpu_handle_mmu_fault(CPUState *cs, vaddr address, int rw,
|
|||||||
/* These should probably raise undefined insn exceptions. */
|
/* These should probably raise undefined insn exceptions. */
|
||||||
void HELPER(v7m_msr)(CPUARMState *env, uint32_t reg, uint32_t val)
|
void HELPER(v7m_msr)(CPUARMState *env, uint32_t reg, uint32_t val)
|
||||||
{
|
{
|
||||||
cpu_abort(env, "v7m_mrs %d\n", reg);
|
ARMCPU *cpu = arm_env_get_cpu(env);
|
||||||
|
|
||||||
|
cpu_abort(CPU(cpu), "v7m_msr %d\n", reg);
|
||||||
}
|
}
|
||||||
|
|
||||||
uint32_t HELPER(v7m_mrs)(CPUARMState *env, uint32_t reg)
|
uint32_t HELPER(v7m_mrs)(CPUARMState *env, uint32_t reg)
|
||||||
{
|
{
|
||||||
cpu_abort(env, "v7m_mrs %d\n", reg);
|
ARMCPU *cpu = arm_env_get_cpu(env);
|
||||||
|
|
||||||
|
cpu_abort(CPU(cpu), "v7m_mrs %d\n", reg);
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
void switch_mode(CPUARMState *env, int mode)
|
void switch_mode(CPUARMState *env, int mode)
|
||||||
{
|
{
|
||||||
if (mode != ARM_CPU_MODE_USR)
|
ARMCPU *cpu = arm_env_get_cpu(env);
|
||||||
cpu_abort(env, "Tried to switch out of user mode\n");
|
|
||||||
|
if (mode != ARM_CPU_MODE_USR) {
|
||||||
|
cpu_abort(CPU(cpu), "Tried to switch out of user mode\n");
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void HELPER(set_r13_banked)(CPUARMState *env, uint32_t mode, uint32_t val)
|
void HELPER(set_r13_banked)(CPUARMState *env, uint32_t mode, uint32_t val)
|
||||||
{
|
{
|
||||||
cpu_abort(env, "banked r13 write\n");
|
ARMCPU *cpu = arm_env_get_cpu(env);
|
||||||
|
|
||||||
|
cpu_abort(CPU(cpu), "banked r13 write\n");
|
||||||
}
|
}
|
||||||
|
|
||||||
uint32_t HELPER(get_r13_banked)(CPUARMState *env, uint32_t mode)
|
uint32_t HELPER(get_r13_banked)(CPUARMState *env, uint32_t mode)
|
||||||
{
|
{
|
||||||
cpu_abort(env, "banked r13 read\n");
|
ARMCPU *cpu = arm_env_get_cpu(env);
|
||||||
|
|
||||||
|
cpu_abort(CPU(cpu), "banked r13 read\n");
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -2892,7 +2903,7 @@ void arm_v7m_cpu_do_interrupt(CPUState *cs)
|
|||||||
do_v7m_exception_exit(env);
|
do_v7m_exception_exit(env);
|
||||||
return;
|
return;
|
||||||
default:
|
default:
|
||||||
cpu_abort(env, "Unhandled exception 0x%x\n", cs->exception_index);
|
cpu_abort(cs, "Unhandled exception 0x%x\n", cs->exception_index);
|
||||||
return; /* Never happens. Keep compiler happy. */
|
return; /* Never happens. Keep compiler happy. */
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -3017,7 +3028,7 @@ void arm_cpu_do_interrupt(CPUState *cs)
|
|||||||
offset = 4;
|
offset = 4;
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
cpu_abort(env, "Unhandled exception 0x%x\n", cs->exception_index);
|
cpu_abort(cs, "Unhandled exception 0x%x\n", cs->exception_index);
|
||||||
return; /* Never happens. Keep compiler happy. */
|
return; /* Never happens. Keep compiler happy. */
|
||||||
}
|
}
|
||||||
/* High vectors. */
|
/* High vectors. */
|
||||||
@ -3695,6 +3706,8 @@ uint32_t HELPER(get_r13_banked)(CPUARMState *env, uint32_t mode)
|
|||||||
|
|
||||||
uint32_t HELPER(v7m_mrs)(CPUARMState *env, uint32_t reg)
|
uint32_t HELPER(v7m_mrs)(CPUARMState *env, uint32_t reg)
|
||||||
{
|
{
|
||||||
|
ARMCPU *cpu = arm_env_get_cpu(env);
|
||||||
|
|
||||||
switch (reg) {
|
switch (reg) {
|
||||||
case 0: /* APSR */
|
case 0: /* APSR */
|
||||||
return xpsr_read(env) & 0xf8000000;
|
return xpsr_read(env) & 0xf8000000;
|
||||||
@ -3725,13 +3738,15 @@ uint32_t HELPER(v7m_mrs)(CPUARMState *env, uint32_t reg)
|
|||||||
return env->v7m.control;
|
return env->v7m.control;
|
||||||
default:
|
default:
|
||||||
/* ??? For debugging only. */
|
/* ??? For debugging only. */
|
||||||
cpu_abort(env, "Unimplemented system register read (%d)\n", reg);
|
cpu_abort(CPU(cpu), "Unimplemented system register read (%d)\n", reg);
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void HELPER(v7m_msr)(CPUARMState *env, uint32_t reg, uint32_t val)
|
void HELPER(v7m_msr)(CPUARMState *env, uint32_t reg, uint32_t val)
|
||||||
{
|
{
|
||||||
|
ARMCPU *cpu = arm_env_get_cpu(env);
|
||||||
|
|
||||||
switch (reg) {
|
switch (reg) {
|
||||||
case 0: /* APSR */
|
case 0: /* APSR */
|
||||||
xpsr_write(env, val, 0xf8000000);
|
xpsr_write(env, val, 0xf8000000);
|
||||||
@ -3794,7 +3809,7 @@ void HELPER(v7m_msr)(CPUARMState *env, uint32_t reg, uint32_t val)
|
|||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
/* ??? For debugging only. */
|
/* ??? For debugging only. */
|
||||||
cpu_abort(env, "Unimplemented system register write (%d)\n", reg);
|
cpu_abort(CPU(cpu), "Unimplemented system register write (%d)\n", reg);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -10803,7 +10803,7 @@ static inline void gen_intermediate_code_internal(ARMCPU *cpu,
|
|||||||
if (dc->condjmp) {
|
if (dc->condjmp) {
|
||||||
/* FIXME: This can theoretically happen with self-modifying
|
/* FIXME: This can theoretically happen with self-modifying
|
||||||
code. */
|
code. */
|
||||||
cpu_abort(env, "IO on conditional branch instruction");
|
cpu_abort(cs, "IO on conditional branch instruction");
|
||||||
}
|
}
|
||||||
gen_io_end();
|
gen_io_end();
|
||||||
}
|
}
|
||||||
|
@ -89,7 +89,7 @@ int cris_cpu_handle_mmu_fault(CPUState *cs, vaddr address, int rw,
|
|||||||
rw, mmu_idx, 0);
|
rw, mmu_idx, 0);
|
||||||
if (miss) {
|
if (miss) {
|
||||||
if (cs->exception_index == EXCP_BUSFAULT) {
|
if (cs->exception_index == EXCP_BUSFAULT) {
|
||||||
cpu_abort(env,
|
cpu_abort(cs,
|
||||||
"CRIS: Illegal recursive bus fault."
|
"CRIS: Illegal recursive bus fault."
|
||||||
"addr=%" VADDR_PRIx " rw=%d\n",
|
"addr=%" VADDR_PRIx " rw=%d\n",
|
||||||
address, rw);
|
address, rw);
|
||||||
@ -130,7 +130,7 @@ void crisv10_cpu_do_interrupt(CPUState *cs)
|
|||||||
|
|
||||||
if (env->dslot) {
|
if (env->dslot) {
|
||||||
/* CRISv10 never takes interrupts while in a delay-slot. */
|
/* CRISv10 never takes interrupts while in a delay-slot. */
|
||||||
cpu_abort(env, "CRIS: Interrupt on delay-slot\n");
|
cpu_abort(cs, "CRIS: Interrupt on delay-slot\n");
|
||||||
}
|
}
|
||||||
|
|
||||||
assert(!(env->pregs[PR_CCS] & PFIX_FLAG));
|
assert(!(env->pregs[PR_CCS] & PFIX_FLAG));
|
||||||
@ -150,7 +150,7 @@ void crisv10_cpu_do_interrupt(CPUState *cs)
|
|||||||
break;
|
break;
|
||||||
|
|
||||||
case EXCP_BUSFAULT:
|
case EXCP_BUSFAULT:
|
||||||
cpu_abort(env, "Unhandled busfault");
|
cpu_abort(cs, "Unhandled busfault");
|
||||||
break;
|
break;
|
||||||
|
|
||||||
default:
|
default:
|
||||||
|
@ -129,7 +129,7 @@ static void gen_BUG(DisasContext *dc, const char *file, int line)
|
|||||||
{
|
{
|
||||||
printf("BUG: pc=%x %s %d\n", dc->pc, file, line);
|
printf("BUG: pc=%x %s %d\n", dc->pc, file, line);
|
||||||
qemu_log("BUG: pc=%x %s %d\n", dc->pc, file, line);
|
qemu_log("BUG: pc=%x %s %d\n", dc->pc, file, line);
|
||||||
cpu_abort(dc->env, "%s:%d\n", file, line);
|
cpu_abort(CPU(cris_env_get_cpu(dc->env)), "%s:%d\n", file, line);
|
||||||
}
|
}
|
||||||
|
|
||||||
static const char *regnames[] =
|
static const char *regnames[] =
|
||||||
@ -272,7 +272,7 @@ static int cris_fetch(CPUCRISState *env, DisasContext *dc, uint32_t addr,
|
|||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
default:
|
default:
|
||||||
cpu_abort(dc->env, "Invalid fetch size %d\n", size);
|
cpu_abort(CPU(cris_env_get_cpu(dc->env)), "Invalid fetch size %d\n", size);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
return r;
|
return r;
|
||||||
|
@ -340,7 +340,7 @@ static unsigned int dec10_quick_imm(DisasContext *dc)
|
|||||||
default:
|
default:
|
||||||
LOG_DIS("pc=%x mode=%x quickimm %d r%d r%d\n",
|
LOG_DIS("pc=%x mode=%x quickimm %d r%d r%d\n",
|
||||||
dc->pc, dc->mode, dc->opcode, dc->src, dc->dst);
|
dc->pc, dc->mode, dc->opcode, dc->src, dc->dst);
|
||||||
cpu_abort(dc->env, "Unhandled quickimm\n");
|
cpu_abort(CPU(cris_env_get_cpu(dc->env)), "Unhandled quickimm\n");
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
return 2;
|
return 2;
|
||||||
@ -651,7 +651,7 @@ static unsigned int dec10_reg(DisasContext *dc)
|
|||||||
case 2: tmp = 1; break;
|
case 2: tmp = 1; break;
|
||||||
case 1: tmp = 0; break;
|
case 1: tmp = 0; break;
|
||||||
default:
|
default:
|
||||||
cpu_abort(dc->env, "Unhandled BIAP");
|
cpu_abort(CPU(cris_env_get_cpu(dc->env)), "Unhandled BIAP");
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -669,7 +669,7 @@ static unsigned int dec10_reg(DisasContext *dc)
|
|||||||
default:
|
default:
|
||||||
LOG_DIS("pc=%x reg %d r%d r%d\n", dc->pc,
|
LOG_DIS("pc=%x reg %d r%d r%d\n", dc->pc,
|
||||||
dc->opcode, dc->src, dc->dst);
|
dc->opcode, dc->src, dc->dst);
|
||||||
cpu_abort(dc->env, "Unhandled opcode");
|
cpu_abort(CPU(cris_env_get_cpu(dc->env)), "Unhandled opcode");
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
@ -745,7 +745,7 @@ static unsigned int dec10_reg(DisasContext *dc)
|
|||||||
default:
|
default:
|
||||||
LOG_DIS("pc=%x reg %d r%d r%d\n", dc->pc,
|
LOG_DIS("pc=%x reg %d r%d r%d\n", dc->pc,
|
||||||
dc->opcode, dc->src, dc->dst);
|
dc->opcode, dc->src, dc->dst);
|
||||||
cpu_abort(dc->env, "Unhandled opcode");
|
cpu_abort(CPU(cris_env_get_cpu(dc->env)), "Unhandled opcode");
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -1105,7 +1105,7 @@ static unsigned int dec10_ind(CPUCRISState *env, DisasContext *dc)
|
|||||||
default:
|
default:
|
||||||
LOG_DIS("pc=%x var-ind.%d %d r%d r%d\n",
|
LOG_DIS("pc=%x var-ind.%d %d r%d r%d\n",
|
||||||
dc->pc, size, dc->opcode, dc->src, dc->dst);
|
dc->pc, size, dc->opcode, dc->src, dc->dst);
|
||||||
cpu_abort(dc->env, "Unhandled opcode");
|
cpu_abort(CPU(cris_env_get_cpu(dc->env)), "Unhandled opcode");
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
return insn_len;
|
return insn_len;
|
||||||
@ -1198,7 +1198,7 @@ static unsigned int dec10_ind(CPUCRISState *env, DisasContext *dc)
|
|||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
LOG_DIS("ERROR pc=%x opcode=%d\n", dc->pc, dc->opcode);
|
LOG_DIS("ERROR pc=%x opcode=%d\n", dc->pc, dc->opcode);
|
||||||
cpu_abort(dc->env, "Unhandled opcode");
|
cpu_abort(CPU(cris_env_get_cpu(dc->env)), "Unhandled opcode");
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -95,6 +95,7 @@ static inline void load_seg_vm(CPUX86State *env, int seg, int selector)
|
|||||||
static inline void get_ss_esp_from_tss(CPUX86State *env, uint32_t *ss_ptr,
|
static inline void get_ss_esp_from_tss(CPUX86State *env, uint32_t *ss_ptr,
|
||||||
uint32_t *esp_ptr, int dpl)
|
uint32_t *esp_ptr, int dpl)
|
||||||
{
|
{
|
||||||
|
X86CPU *cpu = x86_env_get_cpu(env);
|
||||||
int type, index, shift;
|
int type, index, shift;
|
||||||
|
|
||||||
#if 0
|
#if 0
|
||||||
@ -112,11 +113,11 @@ static inline void get_ss_esp_from_tss(CPUX86State *env, uint32_t *ss_ptr,
|
|||||||
#endif
|
#endif
|
||||||
|
|
||||||
if (!(env->tr.flags & DESC_P_MASK)) {
|
if (!(env->tr.flags & DESC_P_MASK)) {
|
||||||
cpu_abort(env, "invalid tss");
|
cpu_abort(CPU(cpu), "invalid tss");
|
||||||
}
|
}
|
||||||
type = (env->tr.flags >> DESC_TYPE_SHIFT) & 0xf;
|
type = (env->tr.flags >> DESC_TYPE_SHIFT) & 0xf;
|
||||||
if ((type & 7) != 1) {
|
if ((type & 7) != 1) {
|
||||||
cpu_abort(env, "invalid tss type");
|
cpu_abort(CPU(cpu), "invalid tss type");
|
||||||
}
|
}
|
||||||
shift = type >> 3;
|
shift = type >> 3;
|
||||||
index = (dpl * 4 + 2) << shift;
|
index = (dpl * 4 + 2) << shift;
|
||||||
@ -782,6 +783,7 @@ static void do_interrupt_protected(CPUX86State *env, int intno, int is_int,
|
|||||||
|
|
||||||
static inline target_ulong get_rsp_from_tss(CPUX86State *env, int level)
|
static inline target_ulong get_rsp_from_tss(CPUX86State *env, int level)
|
||||||
{
|
{
|
||||||
|
X86CPU *cpu = x86_env_get_cpu(env);
|
||||||
int index;
|
int index;
|
||||||
|
|
||||||
#if 0
|
#if 0
|
||||||
@ -790,7 +792,7 @@ static inline target_ulong get_rsp_from_tss(CPUX86State *env, int level)
|
|||||||
#endif
|
#endif
|
||||||
|
|
||||||
if (!(env->tr.flags & DESC_P_MASK)) {
|
if (!(env->tr.flags & DESC_P_MASK)) {
|
||||||
cpu_abort(env, "invalid tss");
|
cpu_abort(CPU(cpu), "invalid tss");
|
||||||
}
|
}
|
||||||
index = 8 * level + 4;
|
index = 8 * level + 4;
|
||||||
if ((index + 7) > env->tr.limit) {
|
if ((index + 7) > env->tr.limit) {
|
||||||
|
@ -185,7 +185,7 @@ void lm32_cpu_do_interrupt(CPUState *cs)
|
|||||||
log_cpu_state_mask(CPU_LOG_INT, cs, 0);
|
log_cpu_state_mask(CPU_LOG_INT, cs, 0);
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
cpu_abort(env, "unhandled exception type=%d\n",
|
cpu_abort(cs, "unhandled exception type=%d\n",
|
||||||
cs->exception_index);
|
cs->exception_index);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
@ -132,6 +132,7 @@ void m68k_cpu_init_gdb(M68kCPU *cpu)
|
|||||||
|
|
||||||
void cpu_m68k_flush_flags(CPUM68KState *env, int cc_op)
|
void cpu_m68k_flush_flags(CPUM68KState *env, int cc_op)
|
||||||
{
|
{
|
||||||
|
M68kCPU *cpu = m68k_env_get_cpu(env);
|
||||||
int flags;
|
int flags;
|
||||||
uint32_t src;
|
uint32_t src;
|
||||||
uint32_t dest;
|
uint32_t dest;
|
||||||
@ -204,7 +205,7 @@ void cpu_m68k_flush_flags(CPUM68KState *env, int cc_op)
|
|||||||
flags |= CCF_C;
|
flags |= CCF_C;
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
cpu_abort(env, "Bad CC_OP %d", cc_op);
|
cpu_abort(CPU(cpu), "Bad CC_OP %d", cc_op);
|
||||||
}
|
}
|
||||||
env->cc_op = CC_OP_FLAGS;
|
env->cc_op = CC_OP_FLAGS;
|
||||||
env->cc_dest = flags;
|
env->cc_dest = flags;
|
||||||
@ -212,6 +213,8 @@ void cpu_m68k_flush_flags(CPUM68KState *env, int cc_op)
|
|||||||
|
|
||||||
void HELPER(movec)(CPUM68KState *env, uint32_t reg, uint32_t val)
|
void HELPER(movec)(CPUM68KState *env, uint32_t reg, uint32_t val)
|
||||||
{
|
{
|
||||||
|
M68kCPU *cpu = m68k_env_get_cpu(env);
|
||||||
|
|
||||||
switch (reg) {
|
switch (reg) {
|
||||||
case 0x02: /* CACR */
|
case 0x02: /* CACR */
|
||||||
env->cacr = val;
|
env->cacr = val;
|
||||||
@ -225,7 +228,7 @@ void HELPER(movec)(CPUM68KState *env, uint32_t reg, uint32_t val)
|
|||||||
break;
|
break;
|
||||||
/* TODO: Implement control registers. */
|
/* TODO: Implement control registers. */
|
||||||
default:
|
default:
|
||||||
cpu_abort(env, "Unimplemented control register write 0x%x = 0x%x\n",
|
cpu_abort(CPU(cpu), "Unimplemented control register write 0x%x = 0x%x\n",
|
||||||
reg, val);
|
reg, val);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -461,7 +461,7 @@ void do_m68k_semihosting(CPUM68KState *env, int nr)
|
|||||||
#endif
|
#endif
|
||||||
return;
|
return;
|
||||||
default:
|
default:
|
||||||
cpu_abort(env, "Unsupported semihosting syscall %d\n", nr);
|
cpu_abort(CPU(m68k_env_get_cpu(env)), "Unsupported semihosting syscall %d\n", nr);
|
||||||
result = 0;
|
result = 0;
|
||||||
}
|
}
|
||||||
failed:
|
failed:
|
||||||
|
@ -881,8 +881,10 @@ DISAS_INSN(undef_fpu)
|
|||||||
|
|
||||||
DISAS_INSN(undef)
|
DISAS_INSN(undef)
|
||||||
{
|
{
|
||||||
|
M68kCPU *cpu = m68k_env_get_cpu(env);
|
||||||
|
|
||||||
gen_exception(s, s->pc - 2, EXCP_UNSUPPORTED);
|
gen_exception(s, s->pc - 2, EXCP_UNSUPPORTED);
|
||||||
cpu_abort(env, "Illegal instruction: %04x @ %08x", insn, s->pc - 2);
|
cpu_abort(CPU(cpu), "Illegal instruction: %04x @ %08x", insn, s->pc - 2);
|
||||||
}
|
}
|
||||||
|
|
||||||
DISAS_INSN(mulw)
|
DISAS_INSN(mulw)
|
||||||
@ -2082,12 +2084,14 @@ DISAS_INSN(wddata)
|
|||||||
|
|
||||||
DISAS_INSN(wdebug)
|
DISAS_INSN(wdebug)
|
||||||
{
|
{
|
||||||
|
M68kCPU *cpu = m68k_env_get_cpu(env);
|
||||||
|
|
||||||
if (IS_USER(s)) {
|
if (IS_USER(s)) {
|
||||||
gen_exception(s, s->pc - 2, EXCP_PRIVILEGE);
|
gen_exception(s, s->pc - 2, EXCP_PRIVILEGE);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
/* TODO: Implement wdebug. */
|
/* TODO: Implement wdebug. */
|
||||||
cpu_abort(env, "WDEBUG not implemented");
|
cpu_abort(CPU(cpu), "WDEBUG not implemented");
|
||||||
}
|
}
|
||||||
|
|
||||||
DISAS_INSN(trap)
|
DISAS_INSN(trap)
|
||||||
@ -2461,14 +2465,18 @@ DISAS_INSN(fbcc)
|
|||||||
|
|
||||||
DISAS_INSN(frestore)
|
DISAS_INSN(frestore)
|
||||||
{
|
{
|
||||||
|
M68kCPU *cpu = m68k_env_get_cpu(env);
|
||||||
|
|
||||||
/* TODO: Implement frestore. */
|
/* TODO: Implement frestore. */
|
||||||
cpu_abort(env, "FRESTORE not implemented");
|
cpu_abort(CPU(cpu), "FRESTORE not implemented");
|
||||||
}
|
}
|
||||||
|
|
||||||
DISAS_INSN(fsave)
|
DISAS_INSN(fsave)
|
||||||
{
|
{
|
||||||
|
M68kCPU *cpu = m68k_env_get_cpu(env);
|
||||||
|
|
||||||
/* TODO: Implement fsave. */
|
/* TODO: Implement fsave. */
|
||||||
cpu_abort(env, "FSAVE not implemented");
|
cpu_abort(CPU(cpu), "FSAVE not implemented");
|
||||||
}
|
}
|
||||||
|
|
||||||
static inline TCGv gen_mac_extract_word(DisasContext *s, TCGv val, int upper)
|
static inline TCGv gen_mac_extract_word(DisasContext *s, TCGv val, int upper)
|
||||||
|
@ -98,7 +98,7 @@ int mb_cpu_handle_mmu_fault(CPUState *cs, vaddr address, int rw,
|
|||||||
}
|
}
|
||||||
|
|
||||||
if (cs->exception_index == EXCP_MMU) {
|
if (cs->exception_index == EXCP_MMU) {
|
||||||
cpu_abort(env, "recursive faults\n");
|
cpu_abort(cs, "recursive faults\n");
|
||||||
}
|
}
|
||||||
|
|
||||||
/* TLB miss. */
|
/* TLB miss. */
|
||||||
@ -259,7 +259,7 @@ void mb_cpu_do_interrupt(CPUState *cs)
|
|||||||
env->sregs[SR_PC] = env->btarget;
|
env->sregs[SR_PC] = env->btarget;
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
cpu_abort(env, "unhandled exception type=%d\n",
|
cpu_abort(cs, "unhandled exception type=%d\n",
|
||||||
cs->exception_index);
|
cs->exception_index);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
@ -370,7 +370,7 @@ static void dec_pattern(DisasContext *dc)
|
|||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
cpu_abort(dc->env,
|
cpu_abort(CPU(mb_env_get_cpu(dc->env)),
|
||||||
"unsupported pattern insn opcode=%x\n", dc->opcode);
|
"unsupported pattern insn opcode=%x\n", dc->opcode);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
@ -441,6 +441,8 @@ static inline void msr_write(DisasContext *dc, TCGv v)
|
|||||||
|
|
||||||
static void dec_msr(DisasContext *dc)
|
static void dec_msr(DisasContext *dc)
|
||||||
{
|
{
|
||||||
|
MicroBlazeCPU *cpu = mb_env_get_cpu(dc->env);
|
||||||
|
CPUState *cs = CPU(cpu);
|
||||||
TCGv t0, t1;
|
TCGv t0, t1;
|
||||||
unsigned int sr, to, rn;
|
unsigned int sr, to, rn;
|
||||||
int mem_index = cpu_mmu_index(dc->env);
|
int mem_index = cpu_mmu_index(dc->env);
|
||||||
@ -537,7 +539,7 @@ static void dec_msr(DisasContext *dc)
|
|||||||
tcg_gen_st_tl(cpu_R[dc->ra], cpu_env, offsetof(CPUMBState, shr));
|
tcg_gen_st_tl(cpu_R[dc->ra], cpu_env, offsetof(CPUMBState, shr));
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
cpu_abort(dc->env, "unknown mts reg %x\n", sr);
|
cpu_abort(CPU(mb_env_get_cpu(dc->env)), "unknown mts reg %x\n", sr);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
@ -586,7 +588,7 @@ static void dec_msr(DisasContext *dc)
|
|||||||
cpu_env, offsetof(CPUMBState, pvr.regs[rn]));
|
cpu_env, offsetof(CPUMBState, pvr.regs[rn]));
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
cpu_abort(dc->env, "unknown mfs reg %x\n", sr);
|
cpu_abort(cs, "unknown mfs reg %x\n", sr);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -684,7 +686,7 @@ static void dec_mul(DisasContext *dc)
|
|||||||
t_gen_mulu(d[0], cpu_R[dc->rd], cpu_R[dc->ra], cpu_R[dc->rb]);
|
t_gen_mulu(d[0], cpu_R[dc->rd], cpu_R[dc->ra], cpu_R[dc->rb]);
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
cpu_abort(dc->env, "unknown MUL insn %x\n", subcode);
|
cpu_abort(CPU(mb_env_get_cpu(dc->env)), "unknown MUL insn %x\n", subcode);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
done:
|
done:
|
||||||
@ -752,6 +754,8 @@ static void dec_barrel(DisasContext *dc)
|
|||||||
|
|
||||||
static void dec_bit(DisasContext *dc)
|
static void dec_bit(DisasContext *dc)
|
||||||
{
|
{
|
||||||
|
MicroBlazeCPU *cpu = mb_env_get_cpu(dc->env);
|
||||||
|
CPUState *cs = CPU(cpu);
|
||||||
TCGv t0;
|
TCGv t0;
|
||||||
unsigned int op;
|
unsigned int op;
|
||||||
int mem_index = cpu_mmu_index(dc->env);
|
int mem_index = cpu_mmu_index(dc->env);
|
||||||
@ -839,7 +843,7 @@ static void dec_bit(DisasContext *dc)
|
|||||||
tcg_gen_rotri_i32(cpu_R[dc->rd], cpu_R[dc->ra], 16);
|
tcg_gen_rotri_i32(cpu_R[dc->rd], cpu_R[dc->ra], 16);
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
cpu_abort(dc->env, "unknown bit oc=%x op=%x rd=%d ra=%d rb=%d\n",
|
cpu_abort(cs, "unknown bit oc=%x op=%x rd=%d ra=%d rb=%d\n",
|
||||||
dc->pc, op, dc->rd, dc->ra, dc->rb);
|
dc->pc, op, dc->rd, dc->ra, dc->rb);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
@ -991,7 +995,7 @@ static void dec_load(DisasContext *dc)
|
|||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
cpu_abort(dc->env, "Invalid reverse size\n");
|
cpu_abort(CPU(mb_env_get_cpu(dc->env)), "Invalid reverse size\n");
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -1142,7 +1146,7 @@ static void dec_store(DisasContext *dc)
|
|||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
cpu_abort(dc->env, "Invalid reverse size\n");
|
cpu_abort(CPU(mb_env_get_cpu(dc->env)), "Invalid reverse size\n");
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -1193,7 +1197,7 @@ static inline void eval_cc(DisasContext *dc, unsigned int cc,
|
|||||||
tcg_gen_setcond_tl(TCG_COND_GT, d, a, b);
|
tcg_gen_setcond_tl(TCG_COND_GT, d, a, b);
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
cpu_abort(dc->env, "Unknown condition code %x.\n", cc);
|
cpu_abort(CPU(mb_env_get_cpu(dc->env)), "Unknown condition code %x.\n", cc);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -1637,8 +1641,9 @@ static inline void decode(DisasContext *dc, uint32_t ir)
|
|||||||
|
|
||||||
LOG_DIS("nr_nops=%d\t", dc->nr_nops);
|
LOG_DIS("nr_nops=%d\t", dc->nr_nops);
|
||||||
dc->nr_nops++;
|
dc->nr_nops++;
|
||||||
if (dc->nr_nops > 4)
|
if (dc->nr_nops > 4) {
|
||||||
cpu_abort(dc->env, "fetching nop sequence\n");
|
cpu_abort(CPU(mb_env_get_cpu(dc->env)), "fetching nop sequence\n");
|
||||||
|
}
|
||||||
}
|
}
|
||||||
/* bit 2 seems to indicate insn type. */
|
/* bit 2 seems to indicate insn type. */
|
||||||
dc->type_b = ir & (1 << 29);
|
dc->type_b = ir & (1 << 29);
|
||||||
@ -1709,8 +1714,9 @@ gen_intermediate_code_internal(MicroBlazeCPU *cpu, TranslationBlock *tb,
|
|||||||
dc->abort_at_next_insn = 0;
|
dc->abort_at_next_insn = 0;
|
||||||
dc->nr_nops = 0;
|
dc->nr_nops = 0;
|
||||||
|
|
||||||
if (pc_start & 3)
|
if (pc_start & 3) {
|
||||||
cpu_abort(env, "Microblaze: unaligned PC=%x\n", pc_start);
|
cpu_abort(cs, "Microblaze: unaligned PC=%x\n", pc_start);
|
||||||
|
}
|
||||||
|
|
||||||
if (qemu_loglevel_mask(CPU_LOG_TB_IN_ASM)) {
|
if (qemu_loglevel_mask(CPU_LOG_TB_IN_ASM)) {
|
||||||
#if !SIM_COMPAT
|
#if !SIM_COMPAT
|
||||||
|
@ -1344,6 +1344,7 @@ void helper_mtc0_compare(CPUMIPSState *env, target_ulong arg1)
|
|||||||
|
|
||||||
void helper_mtc0_status(CPUMIPSState *env, target_ulong arg1)
|
void helper_mtc0_status(CPUMIPSState *env, target_ulong arg1)
|
||||||
{
|
{
|
||||||
|
MIPSCPU *cpu = mips_env_get_cpu(env);
|
||||||
uint32_t val, old;
|
uint32_t val, old;
|
||||||
uint32_t mask = env->CP0_Status_rw_bitmask;
|
uint32_t mask = env->CP0_Status_rw_bitmask;
|
||||||
|
|
||||||
@ -1365,7 +1366,9 @@ void helper_mtc0_status(CPUMIPSState *env, target_ulong arg1)
|
|||||||
case MIPS_HFLAG_UM: qemu_log(", UM\n"); break;
|
case MIPS_HFLAG_UM: qemu_log(", UM\n"); break;
|
||||||
case MIPS_HFLAG_SM: qemu_log(", SM\n"); break;
|
case MIPS_HFLAG_SM: qemu_log(", SM\n"); break;
|
||||||
case MIPS_HFLAG_KM: qemu_log("\n"); break;
|
case MIPS_HFLAG_KM: qemu_log("\n"); break;
|
||||||
default: cpu_abort(env, "Invalid MMU mode!\n"); break;
|
default:
|
||||||
|
cpu_abort(CPU(cpu), "Invalid MMU mode!\n");
|
||||||
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -1985,6 +1988,8 @@ static void debug_pre_eret(CPUMIPSState *env)
|
|||||||
|
|
||||||
static void debug_post_eret(CPUMIPSState *env)
|
static void debug_post_eret(CPUMIPSState *env)
|
||||||
{
|
{
|
||||||
|
MIPSCPU *cpu = mips_env_get_cpu(env);
|
||||||
|
|
||||||
if (qemu_loglevel_mask(CPU_LOG_EXEC)) {
|
if (qemu_loglevel_mask(CPU_LOG_EXEC)) {
|
||||||
qemu_log(" => PC " TARGET_FMT_lx " EPC " TARGET_FMT_lx,
|
qemu_log(" => PC " TARGET_FMT_lx " EPC " TARGET_FMT_lx,
|
||||||
env->active_tc.PC, env->CP0_EPC);
|
env->active_tc.PC, env->CP0_EPC);
|
||||||
@ -1996,7 +2001,9 @@ static void debug_post_eret(CPUMIPSState *env)
|
|||||||
case MIPS_HFLAG_UM: qemu_log(", UM\n"); break;
|
case MIPS_HFLAG_UM: qemu_log(", UM\n"); break;
|
||||||
case MIPS_HFLAG_SM: qemu_log(", SM\n"); break;
|
case MIPS_HFLAG_SM: qemu_log(", SM\n"); break;
|
||||||
case MIPS_HFLAG_KM: qemu_log("\n"); break;
|
case MIPS_HFLAG_KM: qemu_log("\n"); break;
|
||||||
default: cpu_abort(env, "Invalid MMU mode!\n"); break;
|
default:
|
||||||
|
cpu_abort(CPU(cpu), "Invalid MMU mode!\n");
|
||||||
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -629,6 +629,8 @@ static void r4k_mmu_init (CPUMIPSState *env, const mips_def_t *def)
|
|||||||
|
|
||||||
static void mmu_init (CPUMIPSState *env, const mips_def_t *def)
|
static void mmu_init (CPUMIPSState *env, const mips_def_t *def)
|
||||||
{
|
{
|
||||||
|
MIPSCPU *cpu = mips_env_get_cpu(env);
|
||||||
|
|
||||||
env->tlb = g_malloc0(sizeof(CPUMIPSTLBContext));
|
env->tlb = g_malloc0(sizeof(CPUMIPSTLBContext));
|
||||||
|
|
||||||
switch (def->mmu_type) {
|
switch (def->mmu_type) {
|
||||||
@ -645,7 +647,7 @@ static void mmu_init (CPUMIPSState *env, const mips_def_t *def)
|
|||||||
case MMU_TYPE_R6000:
|
case MMU_TYPE_R6000:
|
||||||
case MMU_TYPE_R8000:
|
case MMU_TYPE_R8000:
|
||||||
default:
|
default:
|
||||||
cpu_abort(env, "MMU type not supported\n");
|
cpu_abort(CPU(cpu), "MMU type not supported\n");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
#endif /* CONFIG_USER_ONLY */
|
#endif /* CONFIG_USER_ONLY */
|
||||||
|
@ -57,7 +57,7 @@ void openrisc_cpu_do_interrupt(CPUState *cs)
|
|||||||
if (cs->exception_index > 0 && cs->exception_index < EXCP_NR) {
|
if (cs->exception_index > 0 && cs->exception_index < EXCP_NR) {
|
||||||
env->pc = (cs->exception_index << 8);
|
env->pc = (cs->exception_index << 8);
|
||||||
} else {
|
} else {
|
||||||
cpu_abort(env, "Unhandled exception 0x%x\n", cs->exception_index);
|
cpu_abort(cs, "Unhandled exception 0x%x\n", cs->exception_index);
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
@ -2100,7 +2100,7 @@ static inline int booke206_tlbm_to_tlbn(CPUPPCState *env, ppcmas_tlb_t *tlbm)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
cpu_abort(env, "Unknown TLBe: %d\n", id);
|
cpu_abort(CPU(ppc_env_get_cpu(env)), "Unknown TLBe: %d\n", id);
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -242,7 +242,7 @@ static inline void powerpc_excp(PowerPCCPU *cpu, int excp_model, int excp)
|
|||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
/* Should never occur */
|
/* Should never occur */
|
||||||
cpu_abort(env, "Invalid program exception %d. Aborting\n",
|
cpu_abort(cs, "Invalid program exception %d. Aborting\n",
|
||||||
env->error_code);
|
env->error_code);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
@ -302,26 +302,26 @@ static inline void powerpc_excp(PowerPCCPU *cpu, int excp_model, int excp)
|
|||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
/* XXX: TODO */
|
/* XXX: TODO */
|
||||||
cpu_abort(env, "Debug exception is not implemented yet !\n");
|
cpu_abort(cs, "Debug exception is not implemented yet !\n");
|
||||||
goto store_next;
|
goto store_next;
|
||||||
case POWERPC_EXCP_SPEU: /* SPE/embedded floating-point unavailable */
|
case POWERPC_EXCP_SPEU: /* SPE/embedded floating-point unavailable */
|
||||||
env->spr[SPR_BOOKE_ESR] = ESR_SPV;
|
env->spr[SPR_BOOKE_ESR] = ESR_SPV;
|
||||||
goto store_current;
|
goto store_current;
|
||||||
case POWERPC_EXCP_EFPDI: /* Embedded floating-point data interrupt */
|
case POWERPC_EXCP_EFPDI: /* Embedded floating-point data interrupt */
|
||||||
/* XXX: TODO */
|
/* XXX: TODO */
|
||||||
cpu_abort(env, "Embedded floating point data exception "
|
cpu_abort(cs, "Embedded floating point data exception "
|
||||||
"is not implemented yet !\n");
|
"is not implemented yet !\n");
|
||||||
env->spr[SPR_BOOKE_ESR] = ESR_SPV;
|
env->spr[SPR_BOOKE_ESR] = ESR_SPV;
|
||||||
goto store_next;
|
goto store_next;
|
||||||
case POWERPC_EXCP_EFPRI: /* Embedded floating-point round interrupt */
|
case POWERPC_EXCP_EFPRI: /* Embedded floating-point round interrupt */
|
||||||
/* XXX: TODO */
|
/* XXX: TODO */
|
||||||
cpu_abort(env, "Embedded floating point round exception "
|
cpu_abort(cs, "Embedded floating point round exception "
|
||||||
"is not implemented yet !\n");
|
"is not implemented yet !\n");
|
||||||
env->spr[SPR_BOOKE_ESR] = ESR_SPV;
|
env->spr[SPR_BOOKE_ESR] = ESR_SPV;
|
||||||
goto store_next;
|
goto store_next;
|
||||||
case POWERPC_EXCP_EPERFM: /* Embedded performance monitor interrupt */
|
case POWERPC_EXCP_EPERFM: /* Embedded performance monitor interrupt */
|
||||||
/* XXX: TODO */
|
/* XXX: TODO */
|
||||||
cpu_abort(env,
|
cpu_abort(cs,
|
||||||
"Performance counter exception is not implemented yet !\n");
|
"Performance counter exception is not implemented yet !\n");
|
||||||
goto store_next;
|
goto store_next;
|
||||||
case POWERPC_EXCP_DOORI: /* Embedded doorbell interrupt */
|
case POWERPC_EXCP_DOORI: /* Embedded doorbell interrupt */
|
||||||
@ -403,15 +403,15 @@ static inline void powerpc_excp(PowerPCCPU *cpu, int excp_model, int excp)
|
|||||||
goto store_next;
|
goto store_next;
|
||||||
case POWERPC_EXCP_IO: /* IO error exception */
|
case POWERPC_EXCP_IO: /* IO error exception */
|
||||||
/* XXX: TODO */
|
/* XXX: TODO */
|
||||||
cpu_abort(env, "601 IO error exception is not implemented yet !\n");
|
cpu_abort(cs, "601 IO error exception is not implemented yet !\n");
|
||||||
goto store_next;
|
goto store_next;
|
||||||
case POWERPC_EXCP_RUNM: /* Run mode exception */
|
case POWERPC_EXCP_RUNM: /* Run mode exception */
|
||||||
/* XXX: TODO */
|
/* XXX: TODO */
|
||||||
cpu_abort(env, "601 run mode exception is not implemented yet !\n");
|
cpu_abort(cs, "601 run mode exception is not implemented yet !\n");
|
||||||
goto store_next;
|
goto store_next;
|
||||||
case POWERPC_EXCP_EMUL: /* Emulation trap exception */
|
case POWERPC_EXCP_EMUL: /* Emulation trap exception */
|
||||||
/* XXX: TODO */
|
/* XXX: TODO */
|
||||||
cpu_abort(env, "602 emulation trap exception "
|
cpu_abort(cs, "602 emulation trap exception "
|
||||||
"is not implemented yet !\n");
|
"is not implemented yet !\n");
|
||||||
goto store_next;
|
goto store_next;
|
||||||
case POWERPC_EXCP_IFTLB: /* Instruction fetch TLB error */
|
case POWERPC_EXCP_IFTLB: /* Instruction fetch TLB error */
|
||||||
@ -429,7 +429,7 @@ static inline void powerpc_excp(PowerPCCPU *cpu, int excp_model, int excp)
|
|||||||
case POWERPC_EXCP_74xx:
|
case POWERPC_EXCP_74xx:
|
||||||
goto tlb_miss_74xx;
|
goto tlb_miss_74xx;
|
||||||
default:
|
default:
|
||||||
cpu_abort(env, "Invalid instruction TLB miss exception\n");
|
cpu_abort(cs, "Invalid instruction TLB miss exception\n");
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
@ -448,7 +448,7 @@ static inline void powerpc_excp(PowerPCCPU *cpu, int excp_model, int excp)
|
|||||||
case POWERPC_EXCP_74xx:
|
case POWERPC_EXCP_74xx:
|
||||||
goto tlb_miss_74xx;
|
goto tlb_miss_74xx;
|
||||||
default:
|
default:
|
||||||
cpu_abort(env, "Invalid data load TLB miss exception\n");
|
cpu_abort(cs, "Invalid data load TLB miss exception\n");
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
@ -534,30 +534,30 @@ static inline void powerpc_excp(PowerPCCPU *cpu, int excp_model, int excp)
|
|||||||
msr |= env->error_code; /* key bit */
|
msr |= env->error_code; /* key bit */
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
cpu_abort(env, "Invalid data store TLB miss exception\n");
|
cpu_abort(cs, "Invalid data store TLB miss exception\n");
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
goto store_next;
|
goto store_next;
|
||||||
case POWERPC_EXCP_FPA: /* Floating-point assist exception */
|
case POWERPC_EXCP_FPA: /* Floating-point assist exception */
|
||||||
/* XXX: TODO */
|
/* XXX: TODO */
|
||||||
cpu_abort(env, "Floating point assist exception "
|
cpu_abort(cs, "Floating point assist exception "
|
||||||
"is not implemented yet !\n");
|
"is not implemented yet !\n");
|
||||||
goto store_next;
|
goto store_next;
|
||||||
case POWERPC_EXCP_DABR: /* Data address breakpoint */
|
case POWERPC_EXCP_DABR: /* Data address breakpoint */
|
||||||
/* XXX: TODO */
|
/* XXX: TODO */
|
||||||
cpu_abort(env, "DABR exception is not implemented yet !\n");
|
cpu_abort(cs, "DABR exception is not implemented yet !\n");
|
||||||
goto store_next;
|
goto store_next;
|
||||||
case POWERPC_EXCP_IABR: /* Instruction address breakpoint */
|
case POWERPC_EXCP_IABR: /* Instruction address breakpoint */
|
||||||
/* XXX: TODO */
|
/* XXX: TODO */
|
||||||
cpu_abort(env, "IABR exception is not implemented yet !\n");
|
cpu_abort(cs, "IABR exception is not implemented yet !\n");
|
||||||
goto store_next;
|
goto store_next;
|
||||||
case POWERPC_EXCP_SMI: /* System management interrupt */
|
case POWERPC_EXCP_SMI: /* System management interrupt */
|
||||||
/* XXX: TODO */
|
/* XXX: TODO */
|
||||||
cpu_abort(env, "SMI exception is not implemented yet !\n");
|
cpu_abort(cs, "SMI exception is not implemented yet !\n");
|
||||||
goto store_next;
|
goto store_next;
|
||||||
case POWERPC_EXCP_THERM: /* Thermal interrupt */
|
case POWERPC_EXCP_THERM: /* Thermal interrupt */
|
||||||
/* XXX: TODO */
|
/* XXX: TODO */
|
||||||
cpu_abort(env, "Thermal management exception "
|
cpu_abort(cs, "Thermal management exception "
|
||||||
"is not implemented yet !\n");
|
"is not implemented yet !\n");
|
||||||
goto store_next;
|
goto store_next;
|
||||||
case POWERPC_EXCP_PERFM: /* Embedded performance monitor interrupt */
|
case POWERPC_EXCP_PERFM: /* Embedded performance monitor interrupt */
|
||||||
@ -565,36 +565,36 @@ static inline void powerpc_excp(PowerPCCPU *cpu, int excp_model, int excp)
|
|||||||
new_msr |= (target_ulong)MSR_HVB;
|
new_msr |= (target_ulong)MSR_HVB;
|
||||||
}
|
}
|
||||||
/* XXX: TODO */
|
/* XXX: TODO */
|
||||||
cpu_abort(env,
|
cpu_abort(cs,
|
||||||
"Performance counter exception is not implemented yet !\n");
|
"Performance counter exception is not implemented yet !\n");
|
||||||
goto store_next;
|
goto store_next;
|
||||||
case POWERPC_EXCP_VPUA: /* Vector assist exception */
|
case POWERPC_EXCP_VPUA: /* Vector assist exception */
|
||||||
/* XXX: TODO */
|
/* XXX: TODO */
|
||||||
cpu_abort(env, "VPU assist exception is not implemented yet !\n");
|
cpu_abort(cs, "VPU assist exception is not implemented yet !\n");
|
||||||
goto store_next;
|
goto store_next;
|
||||||
case POWERPC_EXCP_SOFTP: /* Soft patch exception */
|
case POWERPC_EXCP_SOFTP: /* Soft patch exception */
|
||||||
/* XXX: TODO */
|
/* XXX: TODO */
|
||||||
cpu_abort(env,
|
cpu_abort(cs,
|
||||||
"970 soft-patch exception is not implemented yet !\n");
|
"970 soft-patch exception is not implemented yet !\n");
|
||||||
goto store_next;
|
goto store_next;
|
||||||
case POWERPC_EXCP_MAINT: /* Maintenance exception */
|
case POWERPC_EXCP_MAINT: /* Maintenance exception */
|
||||||
/* XXX: TODO */
|
/* XXX: TODO */
|
||||||
cpu_abort(env,
|
cpu_abort(cs,
|
||||||
"970 maintenance exception is not implemented yet !\n");
|
"970 maintenance exception is not implemented yet !\n");
|
||||||
goto store_next;
|
goto store_next;
|
||||||
case POWERPC_EXCP_MEXTBR: /* Maskable external breakpoint */
|
case POWERPC_EXCP_MEXTBR: /* Maskable external breakpoint */
|
||||||
/* XXX: TODO */
|
/* XXX: TODO */
|
||||||
cpu_abort(env, "Maskable external exception "
|
cpu_abort(cs, "Maskable external exception "
|
||||||
"is not implemented yet !\n");
|
"is not implemented yet !\n");
|
||||||
goto store_next;
|
goto store_next;
|
||||||
case POWERPC_EXCP_NMEXTBR: /* Non maskable external breakpoint */
|
case POWERPC_EXCP_NMEXTBR: /* Non maskable external breakpoint */
|
||||||
/* XXX: TODO */
|
/* XXX: TODO */
|
||||||
cpu_abort(env, "Non maskable external exception "
|
cpu_abort(cs, "Non maskable external exception "
|
||||||
"is not implemented yet !\n");
|
"is not implemented yet !\n");
|
||||||
goto store_next;
|
goto store_next;
|
||||||
default:
|
default:
|
||||||
excp_invalid:
|
excp_invalid:
|
||||||
cpu_abort(env, "Invalid PowerPC exception %d. Aborting\n", excp);
|
cpu_abort(cs, "Invalid PowerPC exception %d. Aborting\n", excp);
|
||||||
break;
|
break;
|
||||||
store_current:
|
store_current:
|
||||||
/* save current instruction location */
|
/* save current instruction location */
|
||||||
@ -636,7 +636,7 @@ static inline void powerpc_excp(PowerPCCPU *cpu, int excp_model, int excp)
|
|||||||
/* Jump to handler */
|
/* Jump to handler */
|
||||||
vector = env->excp_vectors[excp];
|
vector = env->excp_vectors[excp];
|
||||||
if (vector == (target_ulong)-1ULL) {
|
if (vector == (target_ulong)-1ULL) {
|
||||||
cpu_abort(env, "Raised an exception without defined vector %d\n",
|
cpu_abort(cs, "Raised an exception without defined vector %d\n",
|
||||||
excp);
|
excp);
|
||||||
}
|
}
|
||||||
vector |= env->excp_prefix;
|
vector |= env->excp_prefix;
|
||||||
|
@ -1504,7 +1504,6 @@ int kvmppc_get_hypercall(CPUPPCState *env, uint8_t *buf, int buf_len)
|
|||||||
|
|
||||||
void kvmppc_set_papr(PowerPCCPU *cpu)
|
void kvmppc_set_papr(PowerPCCPU *cpu)
|
||||||
{
|
{
|
||||||
CPUPPCState *env = &cpu->env;
|
|
||||||
CPUState *cs = CPU(cpu);
|
CPUState *cs = CPU(cpu);
|
||||||
struct kvm_enable_cap cap = {};
|
struct kvm_enable_cap cap = {};
|
||||||
int ret;
|
int ret;
|
||||||
@ -1513,7 +1512,7 @@ void kvmppc_set_papr(PowerPCCPU *cpu)
|
|||||||
ret = kvm_vcpu_ioctl(cs, KVM_ENABLE_CAP, &cap);
|
ret = kvm_vcpu_ioctl(cs, KVM_ENABLE_CAP, &cap);
|
||||||
|
|
||||||
if (ret) {
|
if (ret) {
|
||||||
cpu_abort(env, "This KVM version does not support PAPR\n");
|
cpu_abort(cs, "This KVM version does not support PAPR\n");
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Update the capability flag so we sync the right information
|
/* Update the capability flag so we sync the right information
|
||||||
@ -1523,7 +1522,6 @@ void kvmppc_set_papr(PowerPCCPU *cpu)
|
|||||||
|
|
||||||
void kvmppc_set_mpic_proxy(PowerPCCPU *cpu, int mpic_proxy)
|
void kvmppc_set_mpic_proxy(PowerPCCPU *cpu, int mpic_proxy)
|
||||||
{
|
{
|
||||||
CPUPPCState *env = &cpu->env;
|
|
||||||
CPUState *cs = CPU(cpu);
|
CPUState *cs = CPU(cpu);
|
||||||
struct kvm_enable_cap cap = {};
|
struct kvm_enable_cap cap = {};
|
||||||
int ret;
|
int ret;
|
||||||
@ -1533,7 +1531,7 @@ void kvmppc_set_mpic_proxy(PowerPCCPU *cpu, int mpic_proxy)
|
|||||||
ret = kvm_vcpu_ioctl(cs, KVM_ENABLE_CAP, &cap);
|
ret = kvm_vcpu_ioctl(cs, KVM_ENABLE_CAP, &cap);
|
||||||
|
|
||||||
if (ret && mpic_proxy) {
|
if (ret && mpic_proxy) {
|
||||||
cpu_abort(env, "This KVM version does not support EPR\n");
|
cpu_abort(cs, "This KVM version does not support EPR\n");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -746,9 +746,11 @@ static int mmu40x_get_physical_address(CPUPPCState *env, mmu_ctx_t *ctx,
|
|||||||
|
|
||||||
void store_40x_sler(CPUPPCState *env, uint32_t val)
|
void store_40x_sler(CPUPPCState *env, uint32_t val)
|
||||||
{
|
{
|
||||||
|
PowerPCCPU *cpu = ppc_env_get_cpu(env);
|
||||||
|
|
||||||
/* XXX: TO BE FIXED */
|
/* XXX: TO BE FIXED */
|
||||||
if (val != 0x00000000) {
|
if (val != 0x00000000) {
|
||||||
cpu_abort(env, "Little-endian regions are not supported by now\n");
|
cpu_abort(CPU(cpu), "Little-endian regions are not supported by now\n");
|
||||||
}
|
}
|
||||||
env->spr[SPR_405_SLER] = val;
|
env->spr[SPR_405_SLER] = val;
|
||||||
}
|
}
|
||||||
@ -1344,6 +1346,7 @@ static inline int check_physical(CPUPPCState *env, mmu_ctx_t *ctx,
|
|||||||
static int get_physical_address(CPUPPCState *env, mmu_ctx_t *ctx,
|
static int get_physical_address(CPUPPCState *env, mmu_ctx_t *ctx,
|
||||||
target_ulong eaddr, int rw, int access_type)
|
target_ulong eaddr, int rw, int access_type)
|
||||||
{
|
{
|
||||||
|
PowerPCCPU *cpu = ppc_env_get_cpu(env);
|
||||||
int ret = -1;
|
int ret = -1;
|
||||||
bool real_mode = (access_type == ACCESS_CODE && msr_ir == 0)
|
bool real_mode = (access_type == ACCESS_CODE && msr_ir == 0)
|
||||||
|| (access_type != ACCESS_CODE && msr_dr == 0);
|
|| (access_type != ACCESS_CODE && msr_dr == 0);
|
||||||
@ -1388,17 +1391,17 @@ static int get_physical_address(CPUPPCState *env, mmu_ctx_t *ctx,
|
|||||||
break;
|
break;
|
||||||
case POWERPC_MMU_MPC8xx:
|
case POWERPC_MMU_MPC8xx:
|
||||||
/* XXX: TODO */
|
/* XXX: TODO */
|
||||||
cpu_abort(env, "MPC8xx MMU model is not implemented\n");
|
cpu_abort(CPU(cpu), "MPC8xx MMU model is not implemented\n");
|
||||||
break;
|
break;
|
||||||
case POWERPC_MMU_REAL:
|
case POWERPC_MMU_REAL:
|
||||||
if (real_mode) {
|
if (real_mode) {
|
||||||
ret = check_physical(env, ctx, eaddr, rw);
|
ret = check_physical(env, ctx, eaddr, rw);
|
||||||
} else {
|
} else {
|
||||||
cpu_abort(env, "PowerPC in real mode do not do any translation\n");
|
cpu_abort(CPU(cpu), "PowerPC in real mode do not do any translation\n");
|
||||||
}
|
}
|
||||||
return -1;
|
return -1;
|
||||||
default:
|
default:
|
||||||
cpu_abort(env, "Unknown or invalid MMU model\n");
|
cpu_abort(CPU(cpu), "Unknown or invalid MMU model\n");
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
#if 0
|
#if 0
|
||||||
@ -1543,14 +1546,14 @@ static int cpu_ppc_handle_mmu_fault(CPUPPCState *env, target_ulong address,
|
|||||||
return -1;
|
return -1;
|
||||||
case POWERPC_MMU_MPC8xx:
|
case POWERPC_MMU_MPC8xx:
|
||||||
/* XXX: TODO */
|
/* XXX: TODO */
|
||||||
cpu_abort(env, "MPC8xx MMU model is not implemented\n");
|
cpu_abort(cs, "MPC8xx MMU model is not implemented\n");
|
||||||
break;
|
break;
|
||||||
case POWERPC_MMU_REAL:
|
case POWERPC_MMU_REAL:
|
||||||
cpu_abort(env, "PowerPC in real mode should never raise "
|
cpu_abort(cs, "PowerPC in real mode should never raise "
|
||||||
"any MMU exceptions\n");
|
"any MMU exceptions\n");
|
||||||
return -1;
|
return -1;
|
||||||
default:
|
default:
|
||||||
cpu_abort(env, "Unknown or invalid MMU model\n");
|
cpu_abort(cs, "Unknown or invalid MMU model\n");
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
@ -1623,7 +1626,7 @@ static int cpu_ppc_handle_mmu_fault(CPUPPCState *env, target_ulong address,
|
|||||||
break;
|
break;
|
||||||
case POWERPC_MMU_MPC8xx:
|
case POWERPC_MMU_MPC8xx:
|
||||||
/* XXX: TODO */
|
/* XXX: TODO */
|
||||||
cpu_abort(env, "MPC8xx MMU model is not implemented\n");
|
cpu_abort(cs, "MPC8xx MMU model is not implemented\n");
|
||||||
break;
|
break;
|
||||||
case POWERPC_MMU_BOOKE206:
|
case POWERPC_MMU_BOOKE206:
|
||||||
booke206_update_mas_tlb_miss(env, address, rw);
|
booke206_update_mas_tlb_miss(env, address, rw);
|
||||||
@ -1635,11 +1638,11 @@ static int cpu_ppc_handle_mmu_fault(CPUPPCState *env, target_ulong address,
|
|||||||
env->spr[SPR_BOOKE_ESR] = rw ? ESR_ST : 0;
|
env->spr[SPR_BOOKE_ESR] = rw ? ESR_ST : 0;
|
||||||
return -1;
|
return -1;
|
||||||
case POWERPC_MMU_REAL:
|
case POWERPC_MMU_REAL:
|
||||||
cpu_abort(env, "PowerPC in real mode should never raise "
|
cpu_abort(cs, "PowerPC in real mode should never raise "
|
||||||
"any MMU exceptions\n");
|
"any MMU exceptions\n");
|
||||||
return -1;
|
return -1;
|
||||||
default:
|
default:
|
||||||
cpu_abort(env, "Unknown or invalid MMU model\n");
|
cpu_abort(cs, "Unknown or invalid MMU model\n");
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
@ -1893,6 +1896,8 @@ void helper_store_601_batl(CPUPPCState *env, uint32_t nr, target_ulong value)
|
|||||||
/* TLB management */
|
/* TLB management */
|
||||||
void ppc_tlb_invalidate_all(CPUPPCState *env)
|
void ppc_tlb_invalidate_all(CPUPPCState *env)
|
||||||
{
|
{
|
||||||
|
PowerPCCPU *cpu = ppc_env_get_cpu(env);
|
||||||
|
|
||||||
switch (env->mmu_model) {
|
switch (env->mmu_model) {
|
||||||
case POWERPC_MMU_SOFT_6xx:
|
case POWERPC_MMU_SOFT_6xx:
|
||||||
case POWERPC_MMU_SOFT_74xx:
|
case POWERPC_MMU_SOFT_74xx:
|
||||||
@ -1903,11 +1908,11 @@ void ppc_tlb_invalidate_all(CPUPPCState *env)
|
|||||||
ppc4xx_tlb_invalidate_all(env);
|
ppc4xx_tlb_invalidate_all(env);
|
||||||
break;
|
break;
|
||||||
case POWERPC_MMU_REAL:
|
case POWERPC_MMU_REAL:
|
||||||
cpu_abort(env, "No TLB for PowerPC 4xx in real mode\n");
|
cpu_abort(CPU(cpu), "No TLB for PowerPC 4xx in real mode\n");
|
||||||
break;
|
break;
|
||||||
case POWERPC_MMU_MPC8xx:
|
case POWERPC_MMU_MPC8xx:
|
||||||
/* XXX: TODO */
|
/* XXX: TODO */
|
||||||
cpu_abort(env, "MPC8xx MMU model is not implemented\n");
|
cpu_abort(CPU(cpu), "MPC8xx MMU model is not implemented\n");
|
||||||
break;
|
break;
|
||||||
case POWERPC_MMU_BOOKE:
|
case POWERPC_MMU_BOOKE:
|
||||||
tlb_flush(env, 1);
|
tlb_flush(env, 1);
|
||||||
@ -1927,7 +1932,7 @@ void ppc_tlb_invalidate_all(CPUPPCState *env)
|
|||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
/* XXX: TODO */
|
/* XXX: TODO */
|
||||||
cpu_abort(env, "Unknown MMU model\n");
|
cpu_abort(CPU(cpu), "Unknown MMU model\n");
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -1935,6 +1940,8 @@ void ppc_tlb_invalidate_all(CPUPPCState *env)
|
|||||||
void ppc_tlb_invalidate_one(CPUPPCState *env, target_ulong addr)
|
void ppc_tlb_invalidate_one(CPUPPCState *env, target_ulong addr)
|
||||||
{
|
{
|
||||||
#if !defined(FLUSH_ALL_TLBS)
|
#if !defined(FLUSH_ALL_TLBS)
|
||||||
|
PowerPCCPU *cpu = ppc_env_get_cpu(env);
|
||||||
|
|
||||||
addr &= TARGET_PAGE_MASK;
|
addr &= TARGET_PAGE_MASK;
|
||||||
switch (env->mmu_model) {
|
switch (env->mmu_model) {
|
||||||
case POWERPC_MMU_SOFT_6xx:
|
case POWERPC_MMU_SOFT_6xx:
|
||||||
@ -1949,19 +1956,19 @@ void ppc_tlb_invalidate_one(CPUPPCState *env, target_ulong addr)
|
|||||||
ppc4xx_tlb_invalidate_virt(env, addr, env->spr[SPR_40x_PID]);
|
ppc4xx_tlb_invalidate_virt(env, addr, env->spr[SPR_40x_PID]);
|
||||||
break;
|
break;
|
||||||
case POWERPC_MMU_REAL:
|
case POWERPC_MMU_REAL:
|
||||||
cpu_abort(env, "No TLB for PowerPC 4xx in real mode\n");
|
cpu_abort(CPU(cpu), "No TLB for PowerPC 4xx in real mode\n");
|
||||||
break;
|
break;
|
||||||
case POWERPC_MMU_MPC8xx:
|
case POWERPC_MMU_MPC8xx:
|
||||||
/* XXX: TODO */
|
/* XXX: TODO */
|
||||||
cpu_abort(env, "MPC8xx MMU model is not implemented\n");
|
cpu_abort(CPU(cpu), "MPC8xx MMU model is not implemented\n");
|
||||||
break;
|
break;
|
||||||
case POWERPC_MMU_BOOKE:
|
case POWERPC_MMU_BOOKE:
|
||||||
/* XXX: TODO */
|
/* XXX: TODO */
|
||||||
cpu_abort(env, "BookE MMU model is not implemented\n");
|
cpu_abort(CPU(cpu), "BookE MMU model is not implemented\n");
|
||||||
break;
|
break;
|
||||||
case POWERPC_MMU_BOOKE206:
|
case POWERPC_MMU_BOOKE206:
|
||||||
/* XXX: TODO */
|
/* XXX: TODO */
|
||||||
cpu_abort(env, "BookE 2.06 MMU model is not implemented\n");
|
cpu_abort(CPU(cpu), "BookE 2.06 MMU model is not implemented\n");
|
||||||
break;
|
break;
|
||||||
case POWERPC_MMU_32B:
|
case POWERPC_MMU_32B:
|
||||||
case POWERPC_MMU_601:
|
case POWERPC_MMU_601:
|
||||||
@ -2002,7 +2009,7 @@ void ppc_tlb_invalidate_one(CPUPPCState *env, target_ulong addr)
|
|||||||
#endif /* defined(TARGET_PPC64) */
|
#endif /* defined(TARGET_PPC64) */
|
||||||
default:
|
default:
|
||||||
/* XXX: TODO */
|
/* XXX: TODO */
|
||||||
cpu_abort(env, "Unknown MMU model\n");
|
cpu_abort(CPU(cpu), "Unknown MMU model\n");
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
#else
|
#else
|
||||||
@ -2317,6 +2324,7 @@ target_ulong helper_4xx_tlbre_lo(CPUPPCState *env, target_ulong entry)
|
|||||||
void helper_4xx_tlbwe_hi(CPUPPCState *env, target_ulong entry,
|
void helper_4xx_tlbwe_hi(CPUPPCState *env, target_ulong entry,
|
||||||
target_ulong val)
|
target_ulong val)
|
||||||
{
|
{
|
||||||
|
PowerPCCPU *cpu = ppc_env_get_cpu(env);
|
||||||
ppcemb_tlb_t *tlb;
|
ppcemb_tlb_t *tlb;
|
||||||
target_ulong page, end;
|
target_ulong page, end;
|
||||||
|
|
||||||
@ -2340,7 +2348,7 @@ void helper_4xx_tlbwe_hi(CPUPPCState *env, target_ulong entry,
|
|||||||
* of the ppc or ppc64 one
|
* of the ppc or ppc64 one
|
||||||
*/
|
*/
|
||||||
if ((val & PPC4XX_TLBHI_V) && tlb->size < TARGET_PAGE_SIZE) {
|
if ((val & PPC4XX_TLBHI_V) && tlb->size < TARGET_PAGE_SIZE) {
|
||||||
cpu_abort(env, "TLB size " TARGET_FMT_lu " < %u "
|
cpu_abort(CPU(cpu), "TLB size " TARGET_FMT_lu " < %u "
|
||||||
"are not supported (%d)\n",
|
"are not supported (%d)\n",
|
||||||
tlb->size, TARGET_PAGE_SIZE, (int)((val >> 7) & 0x7));
|
tlb->size, TARGET_PAGE_SIZE, (int)((val >> 7) & 0x7));
|
||||||
}
|
}
|
||||||
@ -2349,7 +2357,7 @@ void helper_4xx_tlbwe_hi(CPUPPCState *env, target_ulong entry,
|
|||||||
tlb->prot |= PAGE_VALID;
|
tlb->prot |= PAGE_VALID;
|
||||||
if (val & PPC4XX_TLBHI_E) {
|
if (val & PPC4XX_TLBHI_E) {
|
||||||
/* XXX: TO BE FIXED */
|
/* XXX: TO BE FIXED */
|
||||||
cpu_abort(env,
|
cpu_abort(CPU(cpu),
|
||||||
"Little-endian TLB entries are not supported by now\n");
|
"Little-endian TLB entries are not supported by now\n");
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
@ -2545,6 +2553,7 @@ target_ulong helper_440_tlbsx(CPUPPCState *env, target_ulong address)
|
|||||||
|
|
||||||
static ppcmas_tlb_t *booke206_cur_tlb(CPUPPCState *env)
|
static ppcmas_tlb_t *booke206_cur_tlb(CPUPPCState *env)
|
||||||
{
|
{
|
||||||
|
PowerPCCPU *cpu = ppc_env_get_cpu(env);
|
||||||
uint32_t tlbncfg = 0;
|
uint32_t tlbncfg = 0;
|
||||||
int esel = (env->spr[SPR_BOOKE_MAS0] & MAS0_ESEL_MASK) >> MAS0_ESEL_SHIFT;
|
int esel = (env->spr[SPR_BOOKE_MAS0] & MAS0_ESEL_MASK) >> MAS0_ESEL_SHIFT;
|
||||||
int ea = (env->spr[SPR_BOOKE_MAS2] & MAS2_EPN_MASK);
|
int ea = (env->spr[SPR_BOOKE_MAS2] & MAS2_EPN_MASK);
|
||||||
@ -2554,7 +2563,7 @@ static ppcmas_tlb_t *booke206_cur_tlb(CPUPPCState *env)
|
|||||||
tlbncfg = env->spr[SPR_BOOKE_TLB0CFG + tlb];
|
tlbncfg = env->spr[SPR_BOOKE_TLB0CFG + tlb];
|
||||||
|
|
||||||
if ((tlbncfg & TLBnCFG_HES) && (env->spr[SPR_BOOKE_MAS0] & MAS0_HES)) {
|
if ((tlbncfg & TLBnCFG_HES) && (env->spr[SPR_BOOKE_MAS0] & MAS0_HES)) {
|
||||||
cpu_abort(env, "we don't support HES yet\n");
|
cpu_abort(CPU(cpu), "we don't support HES yet\n");
|
||||||
}
|
}
|
||||||
|
|
||||||
return booke206_get_tlbm(env, tlb, ea, esel);
|
return booke206_get_tlbm(env, tlb, ea, esel);
|
||||||
@ -2569,6 +2578,7 @@ void helper_booke_setpid(CPUPPCState *env, uint32_t pidn, target_ulong pid)
|
|||||||
|
|
||||||
void helper_booke206_tlbwe(CPUPPCState *env)
|
void helper_booke206_tlbwe(CPUPPCState *env)
|
||||||
{
|
{
|
||||||
|
PowerPCCPU *cpu = ppc_env_get_cpu(env);
|
||||||
uint32_t tlbncfg, tlbn;
|
uint32_t tlbncfg, tlbn;
|
||||||
ppcmas_tlb_t *tlb;
|
ppcmas_tlb_t *tlb;
|
||||||
uint32_t size_tlb, size_ps;
|
uint32_t size_tlb, size_ps;
|
||||||
@ -2622,7 +2632,7 @@ void helper_booke206_tlbwe(CPUPPCState *env)
|
|||||||
}
|
}
|
||||||
|
|
||||||
if (msr_gs) {
|
if (msr_gs) {
|
||||||
cpu_abort(env, "missing HV implementation\n");
|
cpu_abort(CPU(cpu), "missing HV implementation\n");
|
||||||
}
|
}
|
||||||
tlb->mas7_3 = ((uint64_t)env->spr[SPR_BOOKE_MAS7] << 32) |
|
tlb->mas7_3 = ((uint64_t)env->spr[SPR_BOOKE_MAS7] << 32) |
|
||||||
env->spr[SPR_BOOKE_MAS3];
|
env->spr[SPR_BOOKE_MAS3];
|
||||||
|
@ -4432,6 +4432,7 @@ enum fsl_e500_version {
|
|||||||
|
|
||||||
static void init_proc_e500 (CPUPPCState *env, int version)
|
static void init_proc_e500 (CPUPPCState *env, int version)
|
||||||
{
|
{
|
||||||
|
PowerPCCPU *cpu = ppc_env_get_cpu(env);
|
||||||
uint32_t tlbncfg[2];
|
uint32_t tlbncfg[2];
|
||||||
uint64_t ivor_mask;
|
uint64_t ivor_mask;
|
||||||
uint64_t ivpr_mask = 0xFFFF0000ULL;
|
uint64_t ivpr_mask = 0xFFFF0000ULL;
|
||||||
@ -4490,7 +4491,7 @@ static void init_proc_e500 (CPUPPCState *env, int version)
|
|||||||
tlbncfg[1] = gen_tlbncfg(64, 1, 12, TLBnCFG_AVAIL | TLBnCFG_IPROT, 64);
|
tlbncfg[1] = gen_tlbncfg(64, 1, 12, TLBnCFG_AVAIL | TLBnCFG_IPROT, 64);
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
cpu_abort(env, "Unknown CPU: " TARGET_FMT_lx "\n", env->spr[SPR_PVR]);
|
cpu_abort(CPU(cpu), "Unknown CPU: " TARGET_FMT_lx "\n", env->spr[SPR_PVR]);
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
/* Cache sizes */
|
/* Cache sizes */
|
||||||
@ -4507,7 +4508,7 @@ static void init_proc_e500 (CPUPPCState *env, int version)
|
|||||||
l1cfg0 |= 0x1000000; /* 64 byte cache block size */
|
l1cfg0 |= 0x1000000; /* 64 byte cache block size */
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
cpu_abort(env, "Unknown CPU: " TARGET_FMT_lx "\n", env->spr[SPR_PVR]);
|
cpu_abort(CPU(cpu), "Unknown CPU: " TARGET_FMT_lx "\n", env->spr[SPR_PVR]);
|
||||||
}
|
}
|
||||||
gen_spr_BookE206(env, 0x000000DF, tlbncfg);
|
gen_spr_BookE206(env, 0x000000DF, tlbncfg);
|
||||||
/* XXX : not implemented */
|
/* XXX : not implemented */
|
||||||
|
@ -407,6 +407,7 @@ static uint32_t cc_calc_flogr(uint64_t dst)
|
|||||||
static uint32_t do_calc_cc(CPUS390XState *env, uint32_t cc_op,
|
static uint32_t do_calc_cc(CPUS390XState *env, uint32_t cc_op,
|
||||||
uint64_t src, uint64_t dst, uint64_t vr)
|
uint64_t src, uint64_t dst, uint64_t vr)
|
||||||
{
|
{
|
||||||
|
S390CPU *cpu = s390_env_get_cpu(env);
|
||||||
uint32_t r = 0;
|
uint32_t r = 0;
|
||||||
|
|
||||||
switch (cc_op) {
|
switch (cc_op) {
|
||||||
@ -524,7 +525,7 @@ static uint32_t do_calc_cc(CPUS390XState *env, uint32_t cc_op,
|
|||||||
break;
|
break;
|
||||||
|
|
||||||
default:
|
default:
|
||||||
cpu_abort(env, "Unknown CC operation: %s\n", cc_name(cc_op));
|
cpu_abort(CPU(cpu), "Unknown CC operation: %s\n", cc_name(cc_op));
|
||||||
}
|
}
|
||||||
|
|
||||||
HELPER_LOG("%s: %15s 0x%016lx 0x%016lx 0x%016lx = %d\n", __func__,
|
HELPER_LOG("%s: %15s 0x%016lx 0x%016lx 0x%016lx = %d\n", __func__,
|
||||||
|
@ -80,6 +80,8 @@ static void handle_exceptions(CPUS390XState *env, uintptr_t retaddr)
|
|||||||
|
|
||||||
static inline int float_comp_to_cc(CPUS390XState *env, int float_compare)
|
static inline int float_comp_to_cc(CPUS390XState *env, int float_compare)
|
||||||
{
|
{
|
||||||
|
S390CPU *cpu = s390_env_get_cpu(env);
|
||||||
|
|
||||||
switch (float_compare) {
|
switch (float_compare) {
|
||||||
case float_relation_equal:
|
case float_relation_equal:
|
||||||
return 0;
|
return 0;
|
||||||
@ -90,7 +92,7 @@ static inline int float_comp_to_cc(CPUS390XState *env, int float_compare)
|
|||||||
case float_relation_unordered:
|
case float_relation_unordered:
|
||||||
return 3;
|
return 3;
|
||||||
default:
|
default:
|
||||||
cpu_abort(env, "unknown return value for float compare\n");
|
cpu_abort(CPU(cpu), "unknown return value for float compare\n");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -116,6 +116,7 @@ static void trigger_pgm_exception(CPUS390XState *env, uint32_t code,
|
|||||||
|
|
||||||
static int trans_bits(CPUS390XState *env, uint64_t mode)
|
static int trans_bits(CPUS390XState *env, uint64_t mode)
|
||||||
{
|
{
|
||||||
|
S390CPU *cpu = s390_env_get_cpu(env);
|
||||||
int bits = 0;
|
int bits = 0;
|
||||||
|
|
||||||
switch (mode) {
|
switch (mode) {
|
||||||
@ -129,7 +130,7 @@ static int trans_bits(CPUS390XState *env, uint64_t mode)
|
|||||||
bits = 3;
|
bits = 3;
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
cpu_abort(env, "unknown asc mode\n");
|
cpu_abort(CPU(cpu), "unknown asc mode\n");
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -479,13 +480,14 @@ static uint64_t get_psw_mask(CPUS390XState *env)
|
|||||||
|
|
||||||
static LowCore *cpu_map_lowcore(CPUS390XState *env)
|
static LowCore *cpu_map_lowcore(CPUS390XState *env)
|
||||||
{
|
{
|
||||||
|
S390CPU *cpu = s390_env_get_cpu(env);
|
||||||
LowCore *lowcore;
|
LowCore *lowcore;
|
||||||
hwaddr len = sizeof(LowCore);
|
hwaddr len = sizeof(LowCore);
|
||||||
|
|
||||||
lowcore = cpu_physical_memory_map(env->psa, &len, 1);
|
lowcore = cpu_physical_memory_map(env->psa, &len, 1);
|
||||||
|
|
||||||
if (len < sizeof(LowCore)) {
|
if (len < sizeof(LowCore)) {
|
||||||
cpu_abort(env, "Could not map lowcore\n");
|
cpu_abort(CPU(cpu), "Could not map lowcore\n");
|
||||||
}
|
}
|
||||||
|
|
||||||
return lowcore;
|
return lowcore;
|
||||||
@ -583,16 +585,17 @@ static void do_program_interrupt(CPUS390XState *env)
|
|||||||
|
|
||||||
static void do_ext_interrupt(CPUS390XState *env)
|
static void do_ext_interrupt(CPUS390XState *env)
|
||||||
{
|
{
|
||||||
|
S390CPU *cpu = s390_env_get_cpu(env);
|
||||||
uint64_t mask, addr;
|
uint64_t mask, addr;
|
||||||
LowCore *lowcore;
|
LowCore *lowcore;
|
||||||
ExtQueue *q;
|
ExtQueue *q;
|
||||||
|
|
||||||
if (!(env->psw.mask & PSW_MASK_EXT)) {
|
if (!(env->psw.mask & PSW_MASK_EXT)) {
|
||||||
cpu_abort(env, "Ext int w/o ext mask\n");
|
cpu_abort(CPU(cpu), "Ext int w/o ext mask\n");
|
||||||
}
|
}
|
||||||
|
|
||||||
if (env->ext_index < 0 || env->ext_index > MAX_EXT_QUEUE) {
|
if (env->ext_index < 0 || env->ext_index > MAX_EXT_QUEUE) {
|
||||||
cpu_abort(env, "Ext queue overrun: %d\n", env->ext_index);
|
cpu_abort(CPU(cpu), "Ext queue overrun: %d\n", env->ext_index);
|
||||||
}
|
}
|
||||||
|
|
||||||
q = &env->ext_queue[env->ext_index];
|
q = &env->ext_queue[env->ext_index];
|
||||||
@ -622,6 +625,7 @@ static void do_ext_interrupt(CPUS390XState *env)
|
|||||||
|
|
||||||
static void do_io_interrupt(CPUS390XState *env)
|
static void do_io_interrupt(CPUS390XState *env)
|
||||||
{
|
{
|
||||||
|
S390CPU *cpu = s390_env_get_cpu(env);
|
||||||
LowCore *lowcore;
|
LowCore *lowcore;
|
||||||
IOIntQueue *q;
|
IOIntQueue *q;
|
||||||
uint8_t isc;
|
uint8_t isc;
|
||||||
@ -629,7 +633,7 @@ static void do_io_interrupt(CPUS390XState *env)
|
|||||||
int found = 0;
|
int found = 0;
|
||||||
|
|
||||||
if (!(env->psw.mask & PSW_MASK_IO)) {
|
if (!(env->psw.mask & PSW_MASK_IO)) {
|
||||||
cpu_abort(env, "I/O int w/o I/O mask\n");
|
cpu_abort(CPU(cpu), "I/O int w/o I/O mask\n");
|
||||||
}
|
}
|
||||||
|
|
||||||
for (isc = 0; isc < ARRAY_SIZE(env->io_index); isc++) {
|
for (isc = 0; isc < ARRAY_SIZE(env->io_index); isc++) {
|
||||||
@ -639,7 +643,7 @@ static void do_io_interrupt(CPUS390XState *env)
|
|||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
if (env->io_index[isc] > MAX_IO_QUEUE) {
|
if (env->io_index[isc] > MAX_IO_QUEUE) {
|
||||||
cpu_abort(env, "I/O queue overrun for isc %d: %d\n",
|
cpu_abort(CPU(cpu), "I/O queue overrun for isc %d: %d\n",
|
||||||
isc, env->io_index[isc]);
|
isc, env->io_index[isc]);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -686,24 +690,25 @@ static void do_io_interrupt(CPUS390XState *env)
|
|||||||
|
|
||||||
static void do_mchk_interrupt(CPUS390XState *env)
|
static void do_mchk_interrupt(CPUS390XState *env)
|
||||||
{
|
{
|
||||||
|
S390CPU *cpu = s390_env_get_cpu(env);
|
||||||
uint64_t mask, addr;
|
uint64_t mask, addr;
|
||||||
LowCore *lowcore;
|
LowCore *lowcore;
|
||||||
MchkQueue *q;
|
MchkQueue *q;
|
||||||
int i;
|
int i;
|
||||||
|
|
||||||
if (!(env->psw.mask & PSW_MASK_MCHECK)) {
|
if (!(env->psw.mask & PSW_MASK_MCHECK)) {
|
||||||
cpu_abort(env, "Machine check w/o mchk mask\n");
|
cpu_abort(CPU(cpu), "Machine check w/o mchk mask\n");
|
||||||
}
|
}
|
||||||
|
|
||||||
if (env->mchk_index < 0 || env->mchk_index > MAX_MCHK_QUEUE) {
|
if (env->mchk_index < 0 || env->mchk_index > MAX_MCHK_QUEUE) {
|
||||||
cpu_abort(env, "Mchk queue overrun: %d\n", env->mchk_index);
|
cpu_abort(CPU(cpu), "Mchk queue overrun: %d\n", env->mchk_index);
|
||||||
}
|
}
|
||||||
|
|
||||||
q = &env->mchk_queue[env->mchk_index];
|
q = &env->mchk_queue[env->mchk_index];
|
||||||
|
|
||||||
if (q->type != 1) {
|
if (q->type != 1) {
|
||||||
/* Don't know how to handle this... */
|
/* Don't know how to handle this... */
|
||||||
cpu_abort(env, "Unknown machine check type %d\n", q->type);
|
cpu_abort(CPU(cpu), "Unknown machine check type %d\n", q->type);
|
||||||
}
|
}
|
||||||
if (!(env->cregs[14] & (1 << 28))) {
|
if (!(env->cregs[14] & (1 << 28))) {
|
||||||
/* CRW machine checks disabled */
|
/* CRW machine checks disabled */
|
||||||
|
@ -106,9 +106,10 @@ uint64_t HELPER(divu64)(CPUS390XState *env, uint64_t ah, uint64_t al,
|
|||||||
runtime_exception(env, PGM_FIXPT_DIVIDE, GETPC());
|
runtime_exception(env, PGM_FIXPT_DIVIDE, GETPC());
|
||||||
}
|
}
|
||||||
#else
|
#else
|
||||||
|
S390CPU *cpu = s390_env_get_cpu(env);
|
||||||
/* 32-bit hosts would need special wrapper functionality - just abort if
|
/* 32-bit hosts would need special wrapper functionality - just abort if
|
||||||
we encounter such a case; it's very unlikely anyways. */
|
we encounter such a case; it's very unlikely anyways. */
|
||||||
cpu_abort(env, "128 -> 64/64 division not implemented\n");
|
cpu_abort(CPU(cpu), "128 -> 64/64 division not implemented\n");
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
return ret;
|
return ret;
|
||||||
|
@ -72,6 +72,7 @@ void tlb_fill(CPUState *cs, target_ulong addr, int is_write, int mmu_idx,
|
|||||||
static void mvc_fast_memset(CPUS390XState *env, uint32_t l, uint64_t dest,
|
static void mvc_fast_memset(CPUS390XState *env, uint32_t l, uint64_t dest,
|
||||||
uint8_t byte)
|
uint8_t byte)
|
||||||
{
|
{
|
||||||
|
S390CPU *cpu = s390_env_get_cpu(env);
|
||||||
hwaddr dest_phys;
|
hwaddr dest_phys;
|
||||||
hwaddr len = l;
|
hwaddr len = l;
|
||||||
void *dest_p;
|
void *dest_p;
|
||||||
@ -80,7 +81,7 @@ static void mvc_fast_memset(CPUS390XState *env, uint32_t l, uint64_t dest,
|
|||||||
|
|
||||||
if (mmu_translate(env, dest, 1, asc, &dest_phys, &flags)) {
|
if (mmu_translate(env, dest, 1, asc, &dest_phys, &flags)) {
|
||||||
cpu_stb_data(env, dest, byte);
|
cpu_stb_data(env, dest, byte);
|
||||||
cpu_abort(env, "should never reach here");
|
cpu_abort(CPU(cpu), "should never reach here");
|
||||||
}
|
}
|
||||||
dest_phys |= dest & ~TARGET_PAGE_MASK;
|
dest_phys |= dest & ~TARGET_PAGE_MASK;
|
||||||
|
|
||||||
@ -94,6 +95,7 @@ static void mvc_fast_memset(CPUS390XState *env, uint32_t l, uint64_t dest,
|
|||||||
static void mvc_fast_memmove(CPUS390XState *env, uint32_t l, uint64_t dest,
|
static void mvc_fast_memmove(CPUS390XState *env, uint32_t l, uint64_t dest,
|
||||||
uint64_t src)
|
uint64_t src)
|
||||||
{
|
{
|
||||||
|
S390CPU *cpu = s390_env_get_cpu(env);
|
||||||
hwaddr dest_phys;
|
hwaddr dest_phys;
|
||||||
hwaddr src_phys;
|
hwaddr src_phys;
|
||||||
hwaddr len = l;
|
hwaddr len = l;
|
||||||
@ -104,13 +106,13 @@ static void mvc_fast_memmove(CPUS390XState *env, uint32_t l, uint64_t dest,
|
|||||||
|
|
||||||
if (mmu_translate(env, dest, 1, asc, &dest_phys, &flags)) {
|
if (mmu_translate(env, dest, 1, asc, &dest_phys, &flags)) {
|
||||||
cpu_stb_data(env, dest, 0);
|
cpu_stb_data(env, dest, 0);
|
||||||
cpu_abort(env, "should never reach here");
|
cpu_abort(CPU(cpu), "should never reach here");
|
||||||
}
|
}
|
||||||
dest_phys |= dest & ~TARGET_PAGE_MASK;
|
dest_phys |= dest & ~TARGET_PAGE_MASK;
|
||||||
|
|
||||||
if (mmu_translate(env, src, 0, asc, &src_phys, &flags)) {
|
if (mmu_translate(env, src, 0, asc, &src_phys, &flags)) {
|
||||||
cpu_ldub_data(env, src);
|
cpu_ldub_data(env, src);
|
||||||
cpu_abort(env, "should never reach here");
|
cpu_abort(CPU(cpu), "should never reach here");
|
||||||
}
|
}
|
||||||
src_phys |= src & ~TARGET_PAGE_MASK;
|
src_phys |= src & ~TARGET_PAGE_MASK;
|
||||||
|
|
||||||
@ -483,6 +485,7 @@ static uint32_t helper_icm(CPUS390XState *env, uint32_t r1, uint64_t address,
|
|||||||
uint32_t HELPER(ex)(CPUS390XState *env, uint32_t cc, uint64_t v1,
|
uint32_t HELPER(ex)(CPUS390XState *env, uint32_t cc, uint64_t v1,
|
||||||
uint64_t addr, uint64_t ret)
|
uint64_t addr, uint64_t ret)
|
||||||
{
|
{
|
||||||
|
S390CPU *cpu = s390_env_get_cpu(env);
|
||||||
uint16_t insn = cpu_lduw_code(env, addr);
|
uint16_t insn = cpu_lduw_code(env, addr);
|
||||||
|
|
||||||
HELPER_LOG("%s: v1 0x%lx addr 0x%lx insn 0x%x\n", __func__, v1, addr,
|
HELPER_LOG("%s: v1 0x%lx addr 0x%lx insn 0x%x\n", __func__, v1, addr,
|
||||||
@ -534,7 +537,7 @@ uint32_t HELPER(ex)(CPUS390XState *env, uint32_t cc, uint64_t v1,
|
|||||||
cc = helper_icm(env, r1, get_address(env, 0, b2, d2), r3);
|
cc = helper_icm(env, r1, get_address(env, 0, b2, d2), r3);
|
||||||
} else {
|
} else {
|
||||||
abort:
|
abort:
|
||||||
cpu_abort(env, "EXECUTE on instruction prefix 0x%x not implemented\n",
|
cpu_abort(CPU(cpu), "EXECUTE on instruction prefix 0x%x not implemented\n",
|
||||||
insn);
|
insn);
|
||||||
}
|
}
|
||||||
return cc;
|
return cc;
|
||||||
|
@ -234,15 +234,21 @@ static void update_itlb_use(CPUSH4State * env, int itlbnb)
|
|||||||
|
|
||||||
static int itlb_replacement(CPUSH4State * env)
|
static int itlb_replacement(CPUSH4State * env)
|
||||||
{
|
{
|
||||||
if ((env->mmucr & 0xe0000000) == 0xe0000000)
|
SuperHCPU *cpu = sh_env_get_cpu(env);
|
||||||
|
|
||||||
|
if ((env->mmucr & 0xe0000000) == 0xe0000000) {
|
||||||
return 0;
|
return 0;
|
||||||
if ((env->mmucr & 0x98000000) == 0x18000000)
|
}
|
||||||
|
if ((env->mmucr & 0x98000000) == 0x18000000) {
|
||||||
return 1;
|
return 1;
|
||||||
if ((env->mmucr & 0x54000000) == 0x04000000)
|
}
|
||||||
|
if ((env->mmucr & 0x54000000) == 0x04000000) {
|
||||||
return 2;
|
return 2;
|
||||||
if ((env->mmucr & 0x2c000000) == 0x00000000)
|
}
|
||||||
|
if ((env->mmucr & 0x2c000000) == 0x00000000) {
|
||||||
return 3;
|
return 3;
|
||||||
cpu_abort(env, "Unhandled itlb_replacement");
|
}
|
||||||
|
cpu_abort(CPU(cpu), "Unhandled itlb_replacement");
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Find the corresponding entry in the right TLB
|
/* Find the corresponding entry in the right TLB
|
||||||
@ -498,7 +504,7 @@ int superh_cpu_handle_mmu_fault(CPUState *cs, vaddr address, int rw,
|
|||||||
cs->exception_index = 0x100;
|
cs->exception_index = 0x100;
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
cpu_abort(env, "Unhandled MMU fault");
|
cpu_abort(cs, "Unhandled MMU fault");
|
||||||
}
|
}
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
@ -522,6 +528,7 @@ hwaddr superh_cpu_get_phys_page_debug(CPUState *cs, vaddr addr)
|
|||||||
|
|
||||||
void cpu_load_tlb(CPUSH4State * env)
|
void cpu_load_tlb(CPUSH4State * env)
|
||||||
{
|
{
|
||||||
|
SuperHCPU *cpu = sh_env_get_cpu(env);
|
||||||
int n = cpu_mmucr_urc(env->mmucr);
|
int n = cpu_mmucr_urc(env->mmucr);
|
||||||
tlb_t * entry = &env->utlb[n];
|
tlb_t * entry = &env->utlb[n];
|
||||||
|
|
||||||
@ -551,7 +558,7 @@ void cpu_load_tlb(CPUSH4State * env)
|
|||||||
entry->size = 1024 * 1024; /* 1M */
|
entry->size = 1024 * 1024; /* 1M */
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
cpu_abort(env, "Unhandled load_tlb");
|
cpu_abort(CPU(cpu), "Unhandled load_tlb");
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
entry->sh = (uint8_t)cpu_ptel_sh(env->ptel);
|
entry->sh = (uint8_t)cpu_ptel_sh(env->ptel);
|
||||||
|
@ -58,8 +58,10 @@ void tlb_fill(CPUState *cs, target_ulong addr, int is_write, int mmu_idx,
|
|||||||
void helper_ldtlb(CPUSH4State *env)
|
void helper_ldtlb(CPUSH4State *env)
|
||||||
{
|
{
|
||||||
#ifdef CONFIG_USER_ONLY
|
#ifdef CONFIG_USER_ONLY
|
||||||
|
SuperHCPU *cpu = sh_env_get_cpu(env);
|
||||||
|
|
||||||
/* XXXXX */
|
/* XXXXX */
|
||||||
cpu_abort(env, "Unhandled ldtlb");
|
cpu_abort(CPU(cpu), "Unhandled ldtlb");
|
||||||
#else
|
#else
|
||||||
cpu_load_tlb(env);
|
cpu_load_tlb(env);
|
||||||
#endif
|
#endif
|
||||||
|
@ -109,7 +109,7 @@ void sparc_cpu_do_interrupt(CPUState *cs)
|
|||||||
env->def->features & CPU_FEATURE_TA0_SHUTDOWN) {
|
env->def->features & CPU_FEATURE_TA0_SHUTDOWN) {
|
||||||
qemu_system_shutdown_request();
|
qemu_system_shutdown_request();
|
||||||
} else {
|
} else {
|
||||||
cpu_abort(env, "Trap 0x%02x while interrupts disabled, Error state",
|
cpu_abort(cs, "Trap 0x%02x while interrupts disabled, Error state",
|
||||||
cs->exception_index);
|
cs->exception_index);
|
||||||
}
|
}
|
||||||
return;
|
return;
|
||||||
|
@ -111,7 +111,7 @@ void sparc_cpu_do_interrupt(CPUState *cs)
|
|||||||
#endif
|
#endif
|
||||||
#if !defined(CONFIG_USER_ONLY)
|
#if !defined(CONFIG_USER_ONLY)
|
||||||
if (env->tl >= env->maxtl) {
|
if (env->tl >= env->maxtl) {
|
||||||
cpu_abort(env, "Trap 0x%04x while trap level (%d) >= MAXTL (%d),"
|
cpu_abort(cs, "Trap 0x%04x while trap level (%d) >= MAXTL (%d),"
|
||||||
" Error state", cs->exception_index, env->tl, env->maxtl);
|
" Error state", cs->exception_index, env->tl, env->maxtl);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
@ -229,26 +229,22 @@ void helper_cp1_putc(target_ulong x)
|
|||||||
#ifdef CONFIG_USER_ONLY
|
#ifdef CONFIG_USER_ONLY
|
||||||
void switch_mode(CPUUniCore32State *env, int mode)
|
void switch_mode(CPUUniCore32State *env, int mode)
|
||||||
{
|
{
|
||||||
|
UniCore32CPU *cpu = uc32_env_get_cpu(env);
|
||||||
|
|
||||||
if (mode != ASR_MODE_USER) {
|
if (mode != ASR_MODE_USER) {
|
||||||
cpu_abort(env, "Tried to switch out of user mode\n");
|
cpu_abort(CPU(cpu), "Tried to switch out of user mode\n");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void uc32_cpu_do_interrupt(CPUState *cs)
|
void uc32_cpu_do_interrupt(CPUState *cs)
|
||||||
{
|
{
|
||||||
UniCore32CPU *cpu = UNICORE32_CPU(cs);
|
cpu_abort(cs, "NO interrupt in user mode\n");
|
||||||
CPUUniCore32State *env = &cpu->env;
|
|
||||||
|
|
||||||
cpu_abort(env, "NO interrupt in user mode\n");
|
|
||||||
}
|
}
|
||||||
|
|
||||||
int uc32_cpu_handle_mmu_fault(CPUState *cs, vaddr address,
|
int uc32_cpu_handle_mmu_fault(CPUState *cs, vaddr address,
|
||||||
int access_type, int mmu_idx)
|
int access_type, int mmu_idx)
|
||||||
{
|
{
|
||||||
UniCore32CPU *cpu = UNICORE32_CPU(cs);
|
cpu_abort(cs, "NO mmu fault in user mode\n");
|
||||||
CPUUniCore32State *env = &cpu->env;
|
|
||||||
|
|
||||||
cpu_abort(env, "NO mmu fault in user mode\n");
|
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
@ -33,6 +33,8 @@
|
|||||||
/* Map CPU modes onto saved register banks. */
|
/* Map CPU modes onto saved register banks. */
|
||||||
static inline int bank_number(CPUUniCore32State *env, int mode)
|
static inline int bank_number(CPUUniCore32State *env, int mode)
|
||||||
{
|
{
|
||||||
|
UniCore32CPU *cpu = uc32_env_get_cpu(env);
|
||||||
|
|
||||||
switch (mode) {
|
switch (mode) {
|
||||||
case ASR_MODE_USER:
|
case ASR_MODE_USER:
|
||||||
case ASR_MODE_SUSR:
|
case ASR_MODE_SUSR:
|
||||||
@ -46,7 +48,7 @@ static inline int bank_number(CPUUniCore32State *env, int mode)
|
|||||||
case ASR_MODE_INTR:
|
case ASR_MODE_INTR:
|
||||||
return 4;
|
return 4;
|
||||||
}
|
}
|
||||||
cpu_abort(env, "Bad mode %x\n", mode);
|
cpu_abort(CPU(cpu), "Bad mode %x\n", mode);
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -99,7 +101,7 @@ void uc32_cpu_do_interrupt(CPUState *cs)
|
|||||||
addr = 0x18;
|
addr = 0x18;
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
cpu_abort(env, "Unhandled exception 0x%x\n", cs->exception_index);
|
cpu_abort(cs, "Unhandled exception 0x%x\n", cs->exception_index);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
/* High vectors. */
|
/* High vectors. */
|
||||||
@ -121,7 +123,8 @@ static int get_phys_addr_ucv2(CPUUniCore32State *env, uint32_t address,
|
|||||||
int access_type, int is_user, uint32_t *phys_ptr, int *prot,
|
int access_type, int is_user, uint32_t *phys_ptr, int *prot,
|
||||||
target_ulong *page_size)
|
target_ulong *page_size)
|
||||||
{
|
{
|
||||||
CPUState *cs = CPU(uc32_env_get_cpu(env));
|
UniCore32CPU *cpu = uc32_env_get_cpu(env);
|
||||||
|
CPUState *cs = CPU(cpu);
|
||||||
int code;
|
int code;
|
||||||
uint32_t table;
|
uint32_t table;
|
||||||
uint32_t desc;
|
uint32_t desc;
|
||||||
@ -168,11 +171,11 @@ static int get_phys_addr_ucv2(CPUUniCore32State *env, uint32_t address,
|
|||||||
*page_size = TARGET_PAGE_SIZE;
|
*page_size = TARGET_PAGE_SIZE;
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
cpu_abort(env, "wrong page type!");
|
cpu_abort(CPU(cpu), "wrong page type!");
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
cpu_abort(env, "wrong page type!");
|
cpu_abort(CPU(cpu), "wrong page type!");
|
||||||
}
|
}
|
||||||
|
|
||||||
*phys_ptr = phys_addr;
|
*phys_ptr = phys_addr;
|
||||||
@ -268,6 +271,6 @@ hwaddr uc32_cpu_get_phys_page_debug(CPUState *cs, vaddr addr)
|
|||||||
{
|
{
|
||||||
UniCore32CPU *cpu = UNICORE32_CPU(cs);
|
UniCore32CPU *cpu = UNICORE32_CPU(cs);
|
||||||
|
|
||||||
cpu_abort(&cpu->env, "%s not supported yet\n", __func__);
|
cpu_abort(CPU(cpu), "%s not supported yet\n", __func__);
|
||||||
return addr;
|
return addr;
|
||||||
}
|
}
|
||||||
|
@ -176,7 +176,7 @@ static void store_reg(DisasContext *s, int reg, TCGv var)
|
|||||||
#define UCOP_SET_L UCOP_SET(24)
|
#define UCOP_SET_L UCOP_SET(24)
|
||||||
#define UCOP_SET_S UCOP_SET(24)
|
#define UCOP_SET_S UCOP_SET(24)
|
||||||
|
|
||||||
#define ILLEGAL cpu_abort(env, \
|
#define ILLEGAL cpu_abort(CPU(cpu), \
|
||||||
"Illegal UniCore32 instruction %x at line %d!", \
|
"Illegal UniCore32 instruction %x at line %d!", \
|
||||||
insn, __LINE__)
|
insn, __LINE__)
|
||||||
|
|
||||||
@ -184,6 +184,7 @@ static void store_reg(DisasContext *s, int reg, TCGv var)
|
|||||||
static void disas_cp0_insn(CPUUniCore32State *env, DisasContext *s,
|
static void disas_cp0_insn(CPUUniCore32State *env, DisasContext *s,
|
||||||
uint32_t insn)
|
uint32_t insn)
|
||||||
{
|
{
|
||||||
|
UniCore32CPU *cpu = uc32_env_get_cpu(env);
|
||||||
TCGv tmp, tmp2, tmp3;
|
TCGv tmp, tmp2, tmp3;
|
||||||
if ((insn & 0xfe000000) == 0xe0000000) {
|
if ((insn & 0xfe000000) == 0xe0000000) {
|
||||||
tmp2 = new_tmp();
|
tmp2 = new_tmp();
|
||||||
@ -209,6 +210,7 @@ static void disas_cp0_insn(CPUUniCore32State *env, DisasContext *s,
|
|||||||
static void disas_ocd_insn(CPUUniCore32State *env, DisasContext *s,
|
static void disas_ocd_insn(CPUUniCore32State *env, DisasContext *s,
|
||||||
uint32_t insn)
|
uint32_t insn)
|
||||||
{
|
{
|
||||||
|
UniCore32CPU *cpu = uc32_env_get_cpu(env);
|
||||||
TCGv tmp;
|
TCGv tmp;
|
||||||
|
|
||||||
if ((insn & 0xff003fff) == 0xe1000400) {
|
if ((insn & 0xff003fff) == 0xe1000400) {
|
||||||
@ -689,6 +691,7 @@ static inline long ucf64_reg_offset(int reg)
|
|||||||
/* UniCore-F64 single load/store I_offset */
|
/* UniCore-F64 single load/store I_offset */
|
||||||
static void do_ucf64_ldst_i(CPUUniCore32State *env, DisasContext *s, uint32_t insn)
|
static void do_ucf64_ldst_i(CPUUniCore32State *env, DisasContext *s, uint32_t insn)
|
||||||
{
|
{
|
||||||
|
UniCore32CPU *cpu = uc32_env_get_cpu(env);
|
||||||
int offset;
|
int offset;
|
||||||
TCGv tmp;
|
TCGv tmp;
|
||||||
TCGv addr;
|
TCGv addr;
|
||||||
@ -735,6 +738,7 @@ static void do_ucf64_ldst_i(CPUUniCore32State *env, DisasContext *s, uint32_t in
|
|||||||
/* UniCore-F64 load/store multiple words */
|
/* UniCore-F64 load/store multiple words */
|
||||||
static void do_ucf64_ldst_m(CPUUniCore32State *env, DisasContext *s, uint32_t insn)
|
static void do_ucf64_ldst_m(CPUUniCore32State *env, DisasContext *s, uint32_t insn)
|
||||||
{
|
{
|
||||||
|
UniCore32CPU *cpu = uc32_env_get_cpu(env);
|
||||||
unsigned int i;
|
unsigned int i;
|
||||||
int j, n, freg;
|
int j, n, freg;
|
||||||
TCGv tmp;
|
TCGv tmp;
|
||||||
@ -820,6 +824,7 @@ static void do_ucf64_ldst_m(CPUUniCore32State *env, DisasContext *s, uint32_t in
|
|||||||
/* UniCore-F64 mrc/mcr */
|
/* UniCore-F64 mrc/mcr */
|
||||||
static void do_ucf64_trans(CPUUniCore32State *env, DisasContext *s, uint32_t insn)
|
static void do_ucf64_trans(CPUUniCore32State *env, DisasContext *s, uint32_t insn)
|
||||||
{
|
{
|
||||||
|
UniCore32CPU *cpu = uc32_env_get_cpu(env);
|
||||||
TCGv tmp;
|
TCGv tmp;
|
||||||
|
|
||||||
if ((insn & 0xfe0003ff) == 0xe2000000) {
|
if ((insn & 0xfe0003ff) == 0xe2000000) {
|
||||||
@ -884,6 +889,8 @@ static void do_ucf64_trans(CPUUniCore32State *env, DisasContext *s, uint32_t ins
|
|||||||
/* UniCore-F64 convert instructions */
|
/* UniCore-F64 convert instructions */
|
||||||
static void do_ucf64_fcvt(CPUUniCore32State *env, DisasContext *s, uint32_t insn)
|
static void do_ucf64_fcvt(CPUUniCore32State *env, DisasContext *s, uint32_t insn)
|
||||||
{
|
{
|
||||||
|
UniCore32CPU *cpu = uc32_env_get_cpu(env);
|
||||||
|
|
||||||
if (UCOP_UCF64_FMT == 3) {
|
if (UCOP_UCF64_FMT == 3) {
|
||||||
ILLEGAL;
|
ILLEGAL;
|
||||||
}
|
}
|
||||||
@ -950,6 +957,8 @@ static void do_ucf64_fcvt(CPUUniCore32State *env, DisasContext *s, uint32_t insn
|
|||||||
/* UniCore-F64 compare instructions */
|
/* UniCore-F64 compare instructions */
|
||||||
static void do_ucf64_fcmp(CPUUniCore32State *env, DisasContext *s, uint32_t insn)
|
static void do_ucf64_fcmp(CPUUniCore32State *env, DisasContext *s, uint32_t insn)
|
||||||
{
|
{
|
||||||
|
UniCore32CPU *cpu = uc32_env_get_cpu(env);
|
||||||
|
|
||||||
if (UCOP_SET(25)) {
|
if (UCOP_SET(25)) {
|
||||||
ILLEGAL;
|
ILLEGAL;
|
||||||
}
|
}
|
||||||
@ -1028,6 +1037,8 @@ static void do_ucf64_fcmp(CPUUniCore32State *env, DisasContext *s, uint32_t insn
|
|||||||
/* UniCore-F64 data processing */
|
/* UniCore-F64 data processing */
|
||||||
static void do_ucf64_datap(CPUUniCore32State *env, DisasContext *s, uint32_t insn)
|
static void do_ucf64_datap(CPUUniCore32State *env, DisasContext *s, uint32_t insn)
|
||||||
{
|
{
|
||||||
|
UniCore32CPU *cpu = uc32_env_get_cpu(env);
|
||||||
|
|
||||||
if (UCOP_UCF64_FMT == 3) {
|
if (UCOP_UCF64_FMT == 3) {
|
||||||
ILLEGAL;
|
ILLEGAL;
|
||||||
}
|
}
|
||||||
@ -1061,6 +1072,8 @@ static void do_ucf64_datap(CPUUniCore32State *env, DisasContext *s, uint32_t ins
|
|||||||
/* Disassemble an F64 instruction */
|
/* Disassemble an F64 instruction */
|
||||||
static void disas_ucf64_insn(CPUUniCore32State *env, DisasContext *s, uint32_t insn)
|
static void disas_ucf64_insn(CPUUniCore32State *env, DisasContext *s, uint32_t insn)
|
||||||
{
|
{
|
||||||
|
UniCore32CPU *cpu = uc32_env_get_cpu(env);
|
||||||
|
|
||||||
if (!UCOP_SET(29)) {
|
if (!UCOP_SET(29)) {
|
||||||
if (UCOP_SET(26)) {
|
if (UCOP_SET(26)) {
|
||||||
do_ucf64_ldst_m(env, s, insn);
|
do_ucf64_ldst_m(env, s, insn);
|
||||||
@ -1167,6 +1180,8 @@ static void gen_exception_return(DisasContext *s, TCGv pc)
|
|||||||
static void disas_coproc_insn(CPUUniCore32State *env, DisasContext *s,
|
static void disas_coproc_insn(CPUUniCore32State *env, DisasContext *s,
|
||||||
uint32_t insn)
|
uint32_t insn)
|
||||||
{
|
{
|
||||||
|
UniCore32CPU *cpu = uc32_env_get_cpu(env);
|
||||||
|
|
||||||
switch (UCOP_CPNUM) {
|
switch (UCOP_CPNUM) {
|
||||||
#ifndef CONFIG_USER_ONLY
|
#ifndef CONFIG_USER_ONLY
|
||||||
case 0:
|
case 0:
|
||||||
@ -1181,13 +1196,14 @@ static void disas_coproc_insn(CPUUniCore32State *env, DisasContext *s,
|
|||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
/* Unknown coprocessor. */
|
/* Unknown coprocessor. */
|
||||||
cpu_abort(env, "Unknown coprocessor!");
|
cpu_abort(CPU(cpu), "Unknown coprocessor!");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/* data processing instructions */
|
/* data processing instructions */
|
||||||
static void do_datap(CPUUniCore32State *env, DisasContext *s, uint32_t insn)
|
static void do_datap(CPUUniCore32State *env, DisasContext *s, uint32_t insn)
|
||||||
{
|
{
|
||||||
|
UniCore32CPU *cpu = uc32_env_get_cpu(env);
|
||||||
TCGv tmp;
|
TCGv tmp;
|
||||||
TCGv tmp2;
|
TCGv tmp2;
|
||||||
int logic_cc;
|
int logic_cc;
|
||||||
@ -1421,6 +1437,7 @@ static void do_mult(CPUUniCore32State *env, DisasContext *s, uint32_t insn)
|
|||||||
/* miscellaneous instructions */
|
/* miscellaneous instructions */
|
||||||
static void do_misc(CPUUniCore32State *env, DisasContext *s, uint32_t insn)
|
static void do_misc(CPUUniCore32State *env, DisasContext *s, uint32_t insn)
|
||||||
{
|
{
|
||||||
|
UniCore32CPU *cpu = uc32_env_get_cpu(env);
|
||||||
unsigned int val;
|
unsigned int val;
|
||||||
TCGv tmp;
|
TCGv tmp;
|
||||||
|
|
||||||
@ -1546,6 +1563,7 @@ static void do_ldst_ir(CPUUniCore32State *env, DisasContext *s, uint32_t insn)
|
|||||||
/* SWP instruction */
|
/* SWP instruction */
|
||||||
static void do_swap(CPUUniCore32State *env, DisasContext *s, uint32_t insn)
|
static void do_swap(CPUUniCore32State *env, DisasContext *s, uint32_t insn)
|
||||||
{
|
{
|
||||||
|
UniCore32CPU *cpu = uc32_env_get_cpu(env);
|
||||||
TCGv addr;
|
TCGv addr;
|
||||||
TCGv tmp;
|
TCGv tmp;
|
||||||
TCGv tmp2;
|
TCGv tmp2;
|
||||||
@ -1573,6 +1591,7 @@ static void do_swap(CPUUniCore32State *env, DisasContext *s, uint32_t insn)
|
|||||||
/* load/store hw/sb */
|
/* load/store hw/sb */
|
||||||
static void do_ldst_hwsb(CPUUniCore32State *env, DisasContext *s, uint32_t insn)
|
static void do_ldst_hwsb(CPUUniCore32State *env, DisasContext *s, uint32_t insn)
|
||||||
{
|
{
|
||||||
|
UniCore32CPU *cpu = uc32_env_get_cpu(env);
|
||||||
TCGv addr;
|
TCGv addr;
|
||||||
TCGv tmp;
|
TCGv tmp;
|
||||||
|
|
||||||
@ -1625,6 +1644,7 @@ static void do_ldst_hwsb(CPUUniCore32State *env, DisasContext *s, uint32_t insn)
|
|||||||
/* load/store multiple words */
|
/* load/store multiple words */
|
||||||
static void do_ldst_m(CPUUniCore32State *env, DisasContext *s, uint32_t insn)
|
static void do_ldst_m(CPUUniCore32State *env, DisasContext *s, uint32_t insn)
|
||||||
{
|
{
|
||||||
|
UniCore32CPU *cpu = uc32_env_get_cpu(env);
|
||||||
unsigned int val, i, mmu_idx;
|
unsigned int val, i, mmu_idx;
|
||||||
int j, n, reg, user, loaded_base;
|
int j, n, reg, user, loaded_base;
|
||||||
TCGv tmp;
|
TCGv tmp;
|
||||||
@ -1766,6 +1786,7 @@ static void do_ldst_m(CPUUniCore32State *env, DisasContext *s, uint32_t insn)
|
|||||||
/* branch (and link) */
|
/* branch (and link) */
|
||||||
static void do_branch(CPUUniCore32State *env, DisasContext *s, uint32_t insn)
|
static void do_branch(CPUUniCore32State *env, DisasContext *s, uint32_t insn)
|
||||||
{
|
{
|
||||||
|
UniCore32CPU *cpu = uc32_env_get_cpu(env);
|
||||||
unsigned int val;
|
unsigned int val;
|
||||||
int32_t offset;
|
int32_t offset;
|
||||||
TCGv tmp;
|
TCGv tmp;
|
||||||
@ -1795,6 +1816,7 @@ static void do_branch(CPUUniCore32State *env, DisasContext *s, uint32_t insn)
|
|||||||
|
|
||||||
static void disas_uc32_insn(CPUUniCore32State *env, DisasContext *s)
|
static void disas_uc32_insn(CPUUniCore32State *env, DisasContext *s)
|
||||||
{
|
{
|
||||||
|
UniCore32CPU *cpu = uc32_env_get_cpu(env);
|
||||||
unsigned int insn;
|
unsigned int insn;
|
||||||
|
|
||||||
if (unlikely(qemu_loglevel_mask(CPU_LOG_TB_OP | CPU_LOG_TB_OP_OPT))) {
|
if (unlikely(qemu_loglevel_mask(CPU_LOG_TB_OP | CPU_LOG_TB_OP_OPT))) {
|
||||||
@ -1978,7 +2000,7 @@ static inline void gen_intermediate_code_internal(UniCore32CPU *cpu,
|
|||||||
if (dc->condjmp) {
|
if (dc->condjmp) {
|
||||||
/* FIXME: This can theoretically happen with self-modifying
|
/* FIXME: This can theoretically happen with self-modifying
|
||||||
code. */
|
code. */
|
||||||
cpu_abort(env, "IO on conditional branch instruction");
|
cpu_abort(cs, "IO on conditional branch instruction");
|
||||||
}
|
}
|
||||||
gen_io_end();
|
gen_io_end();
|
||||||
}
|
}
|
||||||
|
@ -76,6 +76,7 @@ static inline int ucf64_exceptbits_to_host(int target_bits)
|
|||||||
|
|
||||||
void HELPER(ucf64_set_fpscr)(CPUUniCore32State *env, uint32_t val)
|
void HELPER(ucf64_set_fpscr)(CPUUniCore32State *env, uint32_t val)
|
||||||
{
|
{
|
||||||
|
UniCore32CPU *cpu = uc32_env_get_cpu(env);
|
||||||
int i;
|
int i;
|
||||||
uint32_t changed;
|
uint32_t changed;
|
||||||
|
|
||||||
@ -99,7 +100,7 @@ void HELPER(ucf64_set_fpscr)(CPUUniCore32State *env, uint32_t val)
|
|||||||
i = float_round_down;
|
i = float_round_down;
|
||||||
break;
|
break;
|
||||||
default: /* 100 and 101 not implement */
|
default: /* 100 and 101 not implement */
|
||||||
cpu_abort(env, "Unsupported UniCore-F64 round mode");
|
cpu_abort(CPU(cpu), "Unsupported UniCore-F64 round mode");
|
||||||
}
|
}
|
||||||
set_float_rounding_mode(i, &env->ucf64.fp_status);
|
set_float_rounding_mode(i, &env->ucf64.fp_status);
|
||||||
}
|
}
|
||||||
|
@ -688,7 +688,7 @@ static void page_flush_tb(void)
|
|||||||
/* XXX: tb_flush is currently not thread safe */
|
/* XXX: tb_flush is currently not thread safe */
|
||||||
void tb_flush(CPUArchState *env1)
|
void tb_flush(CPUArchState *env1)
|
||||||
{
|
{
|
||||||
CPUState *cpu;
|
CPUState *cpu = ENV_GET_CPU(env1);
|
||||||
|
|
||||||
#if defined(DEBUG_FLUSH)
|
#if defined(DEBUG_FLUSH)
|
||||||
printf("qemu: flush code_size=%ld nb_tbs=%d avg_tb_size=%ld\n",
|
printf("qemu: flush code_size=%ld nb_tbs=%d avg_tb_size=%ld\n",
|
||||||
@ -699,7 +699,7 @@ void tb_flush(CPUArchState *env1)
|
|||||||
#endif
|
#endif
|
||||||
if ((unsigned long)(tcg_ctx.code_gen_ptr - tcg_ctx.code_gen_buffer)
|
if ((unsigned long)(tcg_ctx.code_gen_ptr - tcg_ctx.code_gen_buffer)
|
||||||
> tcg_ctx.code_gen_buffer_size) {
|
> tcg_ctx.code_gen_buffer_size) {
|
||||||
cpu_abort(env1, "Internal error: code buffer overflow\n");
|
cpu_abort(cpu, "Internal error: code buffer overflow\n");
|
||||||
}
|
}
|
||||||
tcg_ctx.tb_ctx.nb_tbs = 0;
|
tcg_ctx.tb_ctx.nb_tbs = 0;
|
||||||
|
|
||||||
@ -1374,12 +1374,11 @@ void tb_invalidate_phys_addr(AddressSpace *as, hwaddr addr)
|
|||||||
|
|
||||||
void tb_check_watchpoint(CPUState *cpu)
|
void tb_check_watchpoint(CPUState *cpu)
|
||||||
{
|
{
|
||||||
CPUArchState *env = cpu->env_ptr;
|
|
||||||
TranslationBlock *tb;
|
TranslationBlock *tb;
|
||||||
|
|
||||||
tb = tb_find_pc(cpu->mem_io_pc);
|
tb = tb_find_pc(cpu->mem_io_pc);
|
||||||
if (!tb) {
|
if (!tb) {
|
||||||
cpu_abort(env, "check_watchpoint: could not find TB for pc=%p",
|
cpu_abort(cpu, "check_watchpoint: could not find TB for pc=%p",
|
||||||
(void *)cpu->mem_io_pc);
|
(void *)cpu->mem_io_pc);
|
||||||
}
|
}
|
||||||
cpu_restore_state_from_tb(cpu, tb, cpu->mem_io_pc);
|
cpu_restore_state_from_tb(cpu, tb, cpu->mem_io_pc);
|
||||||
@ -1390,7 +1389,6 @@ void tb_check_watchpoint(CPUState *cpu)
|
|||||||
/* mask must never be zero, except for A20 change call */
|
/* mask must never be zero, except for A20 change call */
|
||||||
static void tcg_handle_interrupt(CPUState *cpu, int mask)
|
static void tcg_handle_interrupt(CPUState *cpu, int mask)
|
||||||
{
|
{
|
||||||
CPUArchState *env = cpu->env_ptr;
|
|
||||||
int old_mask;
|
int old_mask;
|
||||||
|
|
||||||
old_mask = cpu->interrupt_request;
|
old_mask = cpu->interrupt_request;
|
||||||
@ -1409,7 +1407,7 @@ static void tcg_handle_interrupt(CPUState *cpu, int mask)
|
|||||||
cpu->icount_decr.u16.high = 0xffff;
|
cpu->icount_decr.u16.high = 0xffff;
|
||||||
if (!cpu_can_do_io(cpu)
|
if (!cpu_can_do_io(cpu)
|
||||||
&& (mask & ~old_mask) != 0) {
|
&& (mask & ~old_mask) != 0) {
|
||||||
cpu_abort(env, "Raised interrupt while not in I/O function");
|
cpu_abort(cpu, "Raised interrupt while not in I/O function");
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
cpu->tcg_exit_req = 1;
|
cpu->tcg_exit_req = 1;
|
||||||
@ -1422,7 +1420,9 @@ CPUInterruptHandler cpu_interrupt_handler = tcg_handle_interrupt;
|
|||||||
must be at the end of the TB */
|
must be at the end of the TB */
|
||||||
void cpu_io_recompile(CPUState *cpu, uintptr_t retaddr)
|
void cpu_io_recompile(CPUState *cpu, uintptr_t retaddr)
|
||||||
{
|
{
|
||||||
|
#if defined(TARGET_MIPS) || defined(TARGET_SH4)
|
||||||
CPUArchState *env = cpu->env_ptr;
|
CPUArchState *env = cpu->env_ptr;
|
||||||
|
#endif
|
||||||
TranslationBlock *tb;
|
TranslationBlock *tb;
|
||||||
uint32_t n, cflags;
|
uint32_t n, cflags;
|
||||||
target_ulong pc, cs_base;
|
target_ulong pc, cs_base;
|
||||||
@ -1430,7 +1430,7 @@ void cpu_io_recompile(CPUState *cpu, uintptr_t retaddr)
|
|||||||
|
|
||||||
tb = tb_find_pc(retaddr);
|
tb = tb_find_pc(retaddr);
|
||||||
if (!tb) {
|
if (!tb) {
|
||||||
cpu_abort(env, "cpu_io_recompile: could not find TB for pc=%p",
|
cpu_abort(cpu, "cpu_io_recompile: could not find TB for pc=%p",
|
||||||
(void *)retaddr);
|
(void *)retaddr);
|
||||||
}
|
}
|
||||||
n = cpu->icount_decr.u16.low + tb->icount;
|
n = cpu->icount_decr.u16.low + tb->icount;
|
||||||
@ -1460,7 +1460,7 @@ void cpu_io_recompile(CPUState *cpu, uintptr_t retaddr)
|
|||||||
#endif
|
#endif
|
||||||
/* This should never happen. */
|
/* This should never happen. */
|
||||||
if (n > CF_COUNT_MASK) {
|
if (n > CF_COUNT_MASK) {
|
||||||
cpu_abort(env, "TB too big during recompile");
|
cpu_abort(cpu, "TB too big during recompile");
|
||||||
}
|
}
|
||||||
|
|
||||||
cflags = n | CF_LAST_IO;
|
cflags = n | CF_LAST_IO;
|
||||||
|
Loading…
Reference in New Issue
Block a user