Some minor tweaks for WIP JIT.

git-svn-id: https://dolphin-emu.googlecode.com/svn/trunk@1761 8ced0084-cf51-0410-be5f-012b33b47a6e
This commit is contained in:
magumagu9 2009-01-04 09:14:02 +00:00
parent 94a51a7817
commit 4eed9912ad
1 changed files with 28 additions and 47 deletions

View File

@ -218,33 +218,19 @@ void AsmRoutineManager::GenQuantizedStores() {
const u8* storePairedIllegal = AlignCode4(); const u8* storePairedIllegal = AlignCode4();
UD2(); UD2();
const u8* storePairedFloat = AlignCode4(); const u8* storePairedFloat = AlignCode4();
if (cpu_info.bSSSE3) {
PSHUFB(XMM0, M((void *)pbswapShuffle2x4));
#ifdef _M_X64 #ifdef _M_X64
MOVQ_xmm(MComplex(RBX, RCX, 1, 0), XMM0); MOVQ_xmm(R(RAX), XMM0);
#else ROL(64, RAX, Imm8(32));
AND(32, R(ECX), Imm32(Memory::MEMVIEW32_MASK)); TEST(32, R(ECX), Imm32(0x0C000000));
MOVQ_xmm(MDisp(ECX, (u32)Memory::base), XMM0); FixupBranch argh = J_CC(CC_NZ);
#endif BSWAP(64, RAX);
} else { MOV(64, MComplex(RBX, RCX, 1, 0), R(RAX));
#ifdef _M_X64 FixupBranch arg2 = J();
MOVQ_xmm(R(RCX), XMM0); SetJumpTarget(argh);
ROL(64, RCX, Imm8(32)); ABI_CallFunctionRR(thunks.ProtectFunction((void *)&Memory::Write_U64, 2), RAX, RCX);
BSWAP(64, RCX); SetJumpTarget(arg2);
MOV(64, MComplex(RBX, RCX, 1, 0), R(RCX));
#else
#if 0
AND(32, R(ECX), Imm32(Memory::MEMVIEW32_MASK));
MOVQ_xmm(XMM0, MDisp(ECX, (u32)Memory::base));
PXOR(XMM1, R(XMM1));
PSHUFLW(XMM0, R(XMM0), 0xB1);
MOVAPD(XMM1, R(XMM0));
PSRLW(XMM0, 8);
PSLLW(XMM1, 8);
POR(XMM0, R(XMM1));
#else #else
MOVQ_xmm(M(&psTemp[0]), XMM0); MOVQ_xmm(M(&psTemp[0]), XMM0);
#if 0
TEST(32, R(ECX), Imm32(0x0C000000)); TEST(32, R(ECX), Imm32(0x0C000000));
FixupBranch argh = J_CC(CC_NZ); FixupBranch argh = J_CC(CC_NZ);
MOV(32, R(EAX), M(&psTemp)); MOV(32, R(EAX), M(&psTemp));
@ -256,18 +242,13 @@ void AsmRoutineManager::GenQuantizedStores() {
MOV(32, MDisp(ECX, 4+(u32)Memory::base), R(EAX)); MOV(32, MDisp(ECX, 4+(u32)Memory::base), R(EAX));
FixupBranch arg2 = J(); FixupBranch arg2 = J();
SetJumpTarget(argh); SetJumpTarget(argh);
#endif
MOV(32, R(EAX), M(((char*)&psTemp))); MOV(32, R(EAX), M(((char*)&psTemp)));
ABI_CallFunctionRR(thunks.ProtectFunction((void *)&Memory::Write_U32, 2), EAX, ECX); ABI_CallFunctionRR(thunks.ProtectFunction((void *)&Memory::Write_U32, 2), EAX, ECX);
MOV(32, R(EAX), M(((char*)&psTemp)+4)); MOV(32, R(EAX), M(((char*)&psTemp)+4));
ADD(32, R(ECX), Imm32(4)); ADD(32, R(ECX), Imm32(4));
ABI_CallFunctionRR(thunks.ProtectFunction((void *)&Memory::Write_U32, 2), EAX, ECX); ABI_CallFunctionRR(thunks.ProtectFunction((void *)&Memory::Write_U32, 2), EAX, ECX);
#if 0
SetJumpTarget(arg2); SetJumpTarget(arg2);
#endif #endif
#endif
#endif
}
RET(); RET();
const u8* storePairedU8 = AlignCode4(); const u8* storePairedU8 = AlignCode4();