mirror of
https://github.com/yuzu-emu/unicorn.git
synced 2025-03-24 22:25:11 +00:00
target-mips: ll and lld cause AdEL exception for unaligned address
Backports commit 6489dd250a4d6e86ecbb4badf82cc102afe26f33 from qemu
This commit is contained in:
parent
c0fc9b280e
commit
4d259dda9a
|
@ -303,16 +303,20 @@ static inline hwaddr do_translate_address(CPUMIPSState *env,
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
#define HELPER_LD_ATOMIC(name, insn) \
|
#define HELPER_LD_ATOMIC(name, insn, almask) \
|
||||||
target_ulong helper_##name(CPUMIPSState *env, target_ulong arg, int mem_idx) \
|
target_ulong helper_##name(CPUMIPSState *env, target_ulong arg, int mem_idx) \
|
||||||
{ \
|
{ \
|
||||||
|
if (arg & almask) { \
|
||||||
|
env->CP0_BadVAddr = arg; \
|
||||||
|
helper_raise_exception(env, EXCP_AdEL); \
|
||||||
|
} \
|
||||||
env->lladdr = do_translate_address(env, arg, 0); \
|
env->lladdr = do_translate_address(env, arg, 0); \
|
||||||
env->llval = do_##insn(env, arg, mem_idx); \
|
env->llval = do_##insn(env, arg, mem_idx); \
|
||||||
return env->llval; \
|
return env->llval; \
|
||||||
}
|
}
|
||||||
HELPER_LD_ATOMIC(ll, lw)
|
HELPER_LD_ATOMIC(ll, lw, 0x3)
|
||||||
#ifdef TARGET_MIPS64
|
#ifdef TARGET_MIPS64
|
||||||
HELPER_LD_ATOMIC(lld, ld)
|
HELPER_LD_ATOMIC(lld, ld, 0x7)
|
||||||
#endif
|
#endif
|
||||||
#undef HELPER_LD_ATOMIC
|
#undef HELPER_LD_ATOMIC
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue