提交 a6763a58 编写于 作者: T ths

Fix MIPS64 address computation specialcase, by Aurelien Jarno.


git-svn-id: svn://svn.savannah.nongnu.org/qemu/trunk@2793 c046a42c-6fe2-441c-8c8c-71466251a162
上级 204a1b8d
......@@ -289,6 +289,22 @@ void op_store_LO (void)
#undef MEMSUFFIX
#endif
/* Addresses computation */
void op_addr_add (void)
{
/* For compatibility with 32-bit code, data reference in user mode
with Status_UX = 0 should be casted to 32-bit and sign extended.
See the MIPS64 PRA manual, section 4.10. */
#ifdef TARGET_MIPS64
if ((env->CP0_Status & (1 << CP0St_UM)) &&
!(env->CP0_Status & (1 << CP0St_UX)))
T0 = (int64_t)(int32_t)(T0 + T1);
else
#endif
T0 += T1;
RETURN();
}
/* Arithmetic */
void op_add (void)
{
......
......@@ -719,7 +719,7 @@ static void gen_ldst (DisasContext *ctx, uint32_t opc, int rt,
} else {
gen_op_load_gpr_T0(base);
gen_op_set_T1(offset);
gen_op_add();
gen_op_addr_add();
}
/* Don't do NOP if destination is zero: we must perform the actual
* memory access
......@@ -868,7 +868,7 @@ static void gen_flt_ldst (DisasContext *ctx, uint32_t opc, int ft,
} else {
gen_op_load_gpr_T0(base);
gen_op_set_T1(offset);
gen_op_add();
gen_op_addr_add();
}
/* Don't do NOP if destination is zero: we must perform the actual
* memory access
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册