提交 29d26d20 编写于 作者: A aurel32

fix alpha cmovxx instruction

The CMOV instruction is defined by the alpha manual as:

CMOVxx Ra.rq,Rb.rq,Rc.wq !Operate format
CMOVxx Ra.rq,#b.ib,Rc.wq !Operate format

Operation:
IF TEST(Rav, Condition_based_on_Opcode) THEN
Rc ← Rbv

The current qemu behavior inverses Ra and Rb.  This is fixed by this
patch.
Signed-off-by: NTristan Gingold <gingold@adacore.com>
Signed-off-by: NAurelien Jarno <aurelien@aurel32.net>

git-svn-id: svn://svn.savannah.nongnu.org/qemu/trunk@5171 c046a42c-6fe2-441c-8c8c-71466251a162
上级 980f8a0b
...@@ -390,15 +390,15 @@ static always_inline void gen_cmov (DisasContext *ctx, ...@@ -390,15 +390,15 @@ static always_inline void gen_cmov (DisasContext *ctx,
int islit, int8_t lit) int islit, int8_t lit)
{ {
if (ra != 31) if (ra != 31)
tcg_gen_mov_i64(cpu_T[1], cpu_ir[ra]); tcg_gen_mov_i64(cpu_T[0], cpu_ir[ra]);
else else
tcg_gen_movi_i64(cpu_T[1], 0); tcg_gen_movi_i64(cpu_T[0], 0);
if (islit) if (islit)
tcg_gen_movi_i64(cpu_T[0], lit); tcg_gen_movi_i64(cpu_T[1], lit);
else if (rb != 31) else if (rb != 31)
tcg_gen_mov_i64(cpu_T[0], cpu_ir[rb]); tcg_gen_mov_i64(cpu_T[1], cpu_ir[rb]);
else else
tcg_gen_movi_i64(cpu_T[0], 0); tcg_gen_movi_i64(cpu_T[1], 0);
(*gen_test_op)(); (*gen_test_op)();
gen_op_cmov_ir(rc); gen_op_cmov_ir(rc);
} }
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册