1 #if !defined(__QEMU_MIPS_EXEC_H__)
2 #define __QEMU_MIPS_EXEC_H__
8 #include "dyngen-exec.h"
11 register struct CPUMIPSState
*env
asm(AREG0
);
16 #if !defined(CONFIG_USER_ONLY)
17 #include "softmmu_exec.h"
18 #endif /* !defined(CONFIG_USER_ONLY) */
20 void dump_fpu(CPUState
*env
);
21 void fpu_dump_state(CPUState
*env
, FILE *f
,
22 int (*fpu_fprintf
)(FILE *f
, const char *fmt
, ...),
25 void cpu_mips_clock_init (CPUState
*env
);
26 void cpu_mips_tlb_flush (CPUState
*env
, int flush_global
);
28 static inline int cpu_has_work(CPUState
*env
)
30 return (env
->interrupt_request
&
31 (CPU_INTERRUPT_HARD
| CPU_INTERRUPT_TIMER
));
35 static inline int cpu_halted(CPUState
*env
)
39 if (cpu_has_work(env
)) {
46 static inline void compute_hflags(CPUState
*env
)
48 env
->hflags
&= ~(MIPS_HFLAG_COP1X
| MIPS_HFLAG_64
| MIPS_HFLAG_CP0
|
49 MIPS_HFLAG_F64
| MIPS_HFLAG_FPU
| MIPS_HFLAG_KSU
|
51 if (!(env
->CP0_Status
& (1 << CP0St_EXL
)) &&
52 !(env
->CP0_Status
& (1 << CP0St_ERL
)) &&
53 !(env
->hflags
& MIPS_HFLAG_DM
)) {
54 env
->hflags
|= (env
->CP0_Status
>> CP0St_KSU
) & MIPS_HFLAG_KSU
;
56 #if defined(TARGET_MIPS64)
57 if (((env
->hflags
& MIPS_HFLAG_KSU
) != MIPS_HFLAG_UM
) ||
58 (env
->CP0_Status
& (1 << CP0St_PX
)) ||
59 (env
->CP0_Status
& (1 << CP0St_UX
)))
60 env
->hflags
|= MIPS_HFLAG_64
;
61 if (env
->CP0_Status
& (1 << CP0St_UX
))
62 env
->hflags
|= MIPS_HFLAG_UX
;
64 if ((env
->CP0_Status
& (1 << CP0St_CU0
)) ||
65 !(env
->hflags
& MIPS_HFLAG_KSU
))
66 env
->hflags
|= MIPS_HFLAG_CP0
;
67 if (env
->CP0_Status
& (1 << CP0St_CU1
))
68 env
->hflags
|= MIPS_HFLAG_FPU
;
69 if (env
->CP0_Status
& (1 << CP0St_FR
))
70 env
->hflags
|= MIPS_HFLAG_F64
;
71 if (env
->insn_flags
& ISA_MIPS32R2
) {
72 if (env
->active_fpu
.fcr0
& (1 << FCR0_F64
))
73 env
->hflags
|= MIPS_HFLAG_COP1X
;
74 } else if (env
->insn_flags
& ISA_MIPS32
) {
75 if (env
->hflags
& MIPS_HFLAG_64
)
76 env
->hflags
|= MIPS_HFLAG_COP1X
;
77 } else if (env
->insn_flags
& ISA_MIPS4
) {
78 /* All supported MIPS IV CPUs use the XX (CU3) to enable
79 and disable the MIPS IV extensions to the MIPS III ISA.
80 Some other MIPS IV CPUs ignore the bit, so the check here
81 would be too restrictive for them. */
82 if (env
->CP0_Status
& (1 << CP0St_CU3
))
83 env
->hflags
|= MIPS_HFLAG_COP1X
;
87 #endif /* !defined(__QEMU_MIPS_EXEC_H__) */