From: ths Date: Fri, 22 Jun 2007 10:11:48 +0000 (+0000) Subject: Add missing cpu_halted function, by Magnus Damm. X-Git-Tag: release_0_9_1~899 X-Git-Url: http://git.ipfire.org/?a=commitdiff_plain;h=d10927f86bd2458fd154fc5a8b529d7e54846c14;p=thirdparty%2Fqemu.git Add missing cpu_halted function, by Magnus Damm. git-svn-id: svn://svn.savannah.nongnu.org/qemu/trunk@2998 c046a42c-6fe2-441c-8c8c-71466251a162 --- diff --git a/target-sh4/cpu.h b/target-sh4/cpu.h index 00ee0626804..4f25b6cafa7 100644 --- a/target-sh4/cpu.h +++ b/target-sh4/cpu.h @@ -114,6 +114,7 @@ typedef struct CPUSH4State { jmp_buf jmp_env; int user_mode_only; int interrupt_request; + int halted; int exception_index; CPU_COMMON tlb_t utlb[UTLB_SIZE]; /* unified translation table */ tlb_t itlb[ITLB_SIZE]; /* instruction translation table */ diff --git a/target-sh4/exec.h b/target-sh4/exec.h index 35633003077..84f29319e25 100644 --- a/target-sh4/exec.h +++ b/target-sh4/exec.h @@ -36,6 +36,16 @@ register uint32_t T1 asm(AREG2); #include "cpu.h" #include "exec-all.h" +static inline int cpu_halted(CPUState *env) { + if (!env->halted) + return 0; + if (env->interrupt_request & CPU_INTERRUPT_HARD) { + env->halted = 0; + return 0; + } + return EXCP_HALTED; +} + #ifndef CONFIG_USER_ONLY #include "softmmu_exec.h" #endif