From dbdf3271fb8c4d40706a524a6e48071e149854bc Mon Sep 17 00:00:00 2001 From: "Dr. Chat" Date: Fri, 15 May 2015 10:20:35 -0500 Subject: [PATCH] Fix 8bit multiply instructions --- src/xenia/cpu/backend/x64/x64_sequences.cc | 16 ++++++++-------- 1 file changed, 8 insertions(+), 8 deletions(-) diff --git a/src/xenia/cpu/backend/x64/x64_sequences.cc b/src/xenia/cpu/backend/x64/x64_sequences.cc index a99ace327..529ce614f 100644 --- a/src/xenia/cpu/backend/x64/x64_sequences.cc +++ b/src/xenia/cpu/backend/x64/x64_sequences.cc @@ -3076,22 +3076,22 @@ EMITTER(MUL_I8, MATCH(I, I8<>, I8<>>)) { } } else { // x86 mul instruction - // AX = AL * $1; + // AH:AL = AL * $1; if (i.src1.is_constant) { assert_true(!i.src2.is_constant); e.mov(e.al, i.src1.constant()); e.mul(i.src2); - e.mov(i.dest, e.ax); + e.mov(i.dest, e.al); } else if (i.src2.is_constant) { assert_true(!i.src1.is_constant); e.mov(e.al, i.src2.constant()); e.mul(i.src1); - e.mov(i.dest, e.ax); + e.mov(i.dest, e.al); } else { e.movzx(e.al, i.src1); e.mul(i.src2); - e.mov(i.dest, e.ax); + e.mov(i.dest, e.al); } } @@ -3281,21 +3281,21 @@ EMITTER(MUL_HI_I8, MATCH(I, I8<>, I8<>>)) { e.mulx(i.dest.reg().cvt32(), e.eax, i.src2.reg().cvt32()); } else { // x86 mul instruction - // AX = AL * $1; + // AH:AL = AL * $1; if (i.src1.is_constant) { assert_true(!i.src2.is_constant); // can't multiply 2 constants e.mov(e.al, i.src1.constant()); e.mul(i.src2); - e.mov(i.dest, e.ax); + e.mov(i.dest, e.ah); } else if (i.src2.is_constant) { assert_true(!i.src1.is_constant); // can't multiply 2 constants e.mov(e.al, i.src2.constant()); e.mul(i.src1); - e.mov(i.dest, e.ax); + e.mov(i.dest, e.ah); } else { e.mov(e.al, i.src1); e.mul(i.src2); - e.mov(i.dest, e.ax); + e.mov(i.dest, e.ah); } } } else {