From cca3e723181e648d99da43c0f302e95b61a119a7 Mon Sep 17 00:00:00 2001 From: Joel Dice Date: Wed, 4 Mar 2009 19:20:15 -0700 Subject: [PATCH] fix 64-bit xorC --- src/powerpc.cpp | 10 ++++++---- 1 file changed, 6 insertions(+), 4 deletions(-) diff --git a/src/powerpc.cpp b/src/powerpc.cpp index 51a6d38725..09d74dda77 100644 --- a/src/powerpc.cpp +++ b/src/powerpc.cpp @@ -1117,7 +1117,7 @@ xorR(Context* c, unsigned size, Assembler::Register* a, xorR(c, 4, a, b, dst); xorR(c, 4, &ah, &bh, &dh); } else { - issue(c, xor_(dst->low, a->low, b->low)); + issue(c, xor_(a->low, dst->low, b->low)); } } @@ -1125,7 +1125,7 @@ void xorC(Context* c, unsigned size, Assembler::Constant* a, Assembler::Register* b, Assembler::Register* dst) { - int64_t v = a->value->value(); + uint64_t v = a->value->value(); if (size == 8) { ResolvedPromise high((v >> 32) & 0xFFFFFFFF); @@ -1140,9 +1140,11 @@ xorC(Context* c, unsigned size, Assembler::Constant* a, xorC(c, 4, &al, b, dst); xorC(c, 4, &ah, &bh, &dh); } else { - issue(c, xori(dst->low, b->low, v)); if (v >> 16) { - issue(c, xoris(dst->low, b->low, v >> 16)); + issue(c, xoris(b->low, dst->low, v >> 16)); + issue(c, xori(dst->low, dst->low, v)); + } else { + issue(c, xori(b->low, dst->low, v)); } } }