mirror of
https://github.com/dolphin-emu/dolphin.git
synced 2025-01-25 07:21:14 +01:00
[ARM] rlwnmx implementation.
This commit is contained in:
parent
43f2313ef9
commit
b7f47bc2e1
@ -167,6 +167,7 @@ public:
|
|||||||
void mulhwux(UGeckoInstruction _inst);
|
void mulhwux(UGeckoInstruction _inst);
|
||||||
void rlwimix(UGeckoInstruction _inst);
|
void rlwimix(UGeckoInstruction _inst);
|
||||||
void rlwinmx(UGeckoInstruction _inst);
|
void rlwinmx(UGeckoInstruction _inst);
|
||||||
|
void rlwnmx(UGeckoInstruction _inst);
|
||||||
void srawix(UGeckoInstruction _inst);
|
void srawix(UGeckoInstruction _inst);
|
||||||
void extshx(UGeckoInstruction inst);
|
void extshx(UGeckoInstruction inst);
|
||||||
void extsbx(UGeckoInstruction inst);
|
void extsbx(UGeckoInstruction inst);
|
||||||
|
@ -775,6 +775,7 @@ void JitArm::rlwimix(UGeckoInstruction inst)
|
|||||||
}
|
}
|
||||||
gpr.Unlock(rA, rB);
|
gpr.Unlock(rA, rB);
|
||||||
}
|
}
|
||||||
|
|
||||||
void JitArm::rlwinmx(UGeckoInstruction inst)
|
void JitArm::rlwinmx(UGeckoInstruction inst)
|
||||||
{
|
{
|
||||||
INSTRUCTION_START
|
INSTRUCTION_START
|
||||||
@ -798,6 +799,34 @@ void JitArm::rlwinmx(UGeckoInstruction inst)
|
|||||||
|
|
||||||
//m_GPR[inst.RA] = _rotl(m_GPR[inst.RS],inst.SH) & mask;
|
//m_GPR[inst.RA] = _rotl(m_GPR[inst.RS],inst.SH) & mask;
|
||||||
}
|
}
|
||||||
|
void JitArm::rlwnmx(UGeckoInstruction inst)
|
||||||
|
{
|
||||||
|
INSTRUCTION_START
|
||||||
|
JITDISABLE(bJITIntegerOff)
|
||||||
|
|
||||||
|
u32 mask = Helper_Mask(inst.MB,inst.ME);
|
||||||
|
ARMReg RA = gpr.R(inst.RA);
|
||||||
|
ARMReg RS = gpr.R(inst.RS);
|
||||||
|
ARMReg RB = gpr.R(inst.RB);
|
||||||
|
ARMReg rA = gpr.GetReg();
|
||||||
|
ARMReg rB = gpr.GetReg();
|
||||||
|
MOVI2R(rA, mask);
|
||||||
|
|
||||||
|
// PPC rotates left, ARM rotates right. Swap it
|
||||||
|
MOV(rB, 32);
|
||||||
|
SUB(rB, rB, RB);
|
||||||
|
|
||||||
|
Operand2 Shift(RS, ST_ROR, rB); // Register shifted register
|
||||||
|
if (inst.Rc)
|
||||||
|
{
|
||||||
|
ANDS(RA, rA, Shift);
|
||||||
|
GenerateRC();
|
||||||
|
}
|
||||||
|
else
|
||||||
|
AND (RA, rA, Shift);
|
||||||
|
gpr.Unlock(rA, rB);
|
||||||
|
}
|
||||||
|
|
||||||
void JitArm::srawix(UGeckoInstruction inst)
|
void JitArm::srawix(UGeckoInstruction inst)
|
||||||
{
|
{
|
||||||
INSTRUCTION_START
|
INSTRUCTION_START
|
||||||
|
@ -69,7 +69,7 @@ static GekkoOPTemplate primarytable[] =
|
|||||||
|
|
||||||
{20, &JitArm::rlwimix}, //"rlwimix", OPTYPE_INTEGER, FL_OUT_A | FL_IN_A | FL_IN_S | FL_RC_BIT}},
|
{20, &JitArm::rlwimix}, //"rlwimix", OPTYPE_INTEGER, FL_OUT_A | FL_IN_A | FL_IN_S | FL_RC_BIT}},
|
||||||
{21, &JitArm::rlwinmx}, //"rlwinmx", OPTYPE_INTEGER, FL_OUT_A | FL_IN_S | FL_RC_BIT}},
|
{21, &JitArm::rlwinmx}, //"rlwinmx", OPTYPE_INTEGER, FL_OUT_A | FL_IN_S | FL_RC_BIT}},
|
||||||
{23, &JitArm::Default}, //"rlwnmx", OPTYPE_INTEGER, FL_OUT_A | FL_IN_S | FL_IN_B | FL_RC_BIT}},
|
{23, &JitArm::rlwnmx}, //"rlwnmx", OPTYPE_INTEGER, FL_OUT_A | FL_IN_S | FL_IN_B | FL_RC_BIT}},
|
||||||
|
|
||||||
{24, &JitArm::arith}, //"ori", OPTYPE_INTEGER, FL_OUT_A | FL_IN_S}},
|
{24, &JitArm::arith}, //"ori", OPTYPE_INTEGER, FL_OUT_A | FL_IN_S}},
|
||||||
{25, &JitArm::arith}, //"oris", OPTYPE_INTEGER, FL_OUT_A | FL_IN_S}},
|
{25, &JitArm::arith}, //"oris", OPTYPE_INTEGER, FL_OUT_A | FL_IN_S}},
|
||||||
|
Loading…
x
Reference in New Issue
Block a user