Merge pull request #4762 from lioncash/enum

DSPJitRegCache: Convert DSPJitSignExtend into an enum class
This commit is contained in:
Markus Wick 2017-01-27 01:25:19 +01:00 committed by GitHub
commit 540bf4618c
9 changed files with 115 additions and 114 deletions

View File

@ -108,8 +108,9 @@ public:
void dsp_conditional_extend_accum(int reg); void dsp_conditional_extend_accum(int reg);
void dsp_conditional_extend_accum_imm(int reg, u16 val); void dsp_conditional_extend_accum_imm(int reg, u16 val);
void dsp_op_read_reg_dont_saturate(int reg, Gen::X64Reg host_dreg, void dsp_op_read_reg_dont_saturate(int reg, Gen::X64Reg host_dreg,
DSPJitSignExtend extend = NONE); RegisterExtension extend = RegisterExtension::None);
void dsp_op_read_reg(int reg, Gen::X64Reg host_dreg, DSPJitSignExtend extend = NONE); void dsp_op_read_reg(int reg, Gen::X64Reg host_dreg,
RegisterExtension extend = RegisterExtension::None);
// Commands // Commands
void dar(const UDSPInstruction opc); void dar(const UDSPInstruction opc);

View File

@ -533,7 +533,7 @@ void DSPEmitter::addr(const UDSPInstruction opc)
get_long_acc(dreg, tmp1); get_long_acc(dreg, tmp1);
MOV(64, R(RAX), R(tmp1)); MOV(64, R(RAX), R(tmp1));
// s64 ax = (s16)g_dsp.r[sreg]; // s64 ax = (s16)g_dsp.r[sreg];
dsp_op_read_reg(sreg, RDX, SIGN); dsp_op_read_reg(sreg, RDX, RegisterExtension::Sign);
// ax <<= 16; // ax <<= 16;
SHL(64, R(RDX), Imm8(16)); SHL(64, R(RDX), Imm8(16));
// s64 res = acc + ax; // s64 res = acc + ax;
@ -842,7 +842,7 @@ void DSPEmitter::subr(const UDSPInstruction opc)
get_long_acc(dreg, tmp1); get_long_acc(dreg, tmp1);
MOV(64, R(RAX), R(tmp1)); MOV(64, R(RAX), R(tmp1));
// s64 ax = (s16)g_dsp.r[sreg]; // s64 ax = (s16)g_dsp.r[sreg];
dsp_op_read_reg(sreg, RDX, SIGN); dsp_op_read_reg(sreg, RDX, RegisterExtension::Sign);
// ax <<= 16; // ax <<= 16;
SHL(64, R(RDX), Imm8(16)); SHL(64, R(RDX), Imm8(16));
// s64 res = acc - ax; // s64 res = acc - ax;
@ -1089,7 +1089,7 @@ void DSPEmitter::movr(const UDSPInstruction opc)
u8 sreg = ((opc >> 9) & 0x3) + DSP_REG_AXL0; u8 sreg = ((opc >> 9) & 0x3) + DSP_REG_AXL0;
// s64 acc = (s16)g_dsp.r[sreg]; // s64 acc = (s16)g_dsp.r[sreg];
dsp_op_read_reg(sreg, RAX, SIGN); dsp_op_read_reg(sreg, RAX, RegisterExtension::Sign);
// acc <<= 16; // acc <<= 16;
SHL(64, R(RAX), Imm8(16)); SHL(64, R(RAX), Imm8(16));
// acc &= ~0xffff; // acc &= ~0xffff;

View File

@ -157,7 +157,7 @@ static void r_jmprcc(const UDSPInstruction opc, DSPEmitter& emitter)
u8 reg = (opc >> 5) & 0x7; u8 reg = (opc >> 5) & 0x7;
// reg can only be DSP_REG_ARx and DSP_REG_IXx now, // reg can only be DSP_REG_ARx and DSP_REG_IXx now,
// no need to handle DSP_REG_STx. // no need to handle DSP_REG_STx.
emitter.dsp_op_read_reg(reg, RAX, NONE); emitter.dsp_op_read_reg(reg, RAX);
emitter.MOV(16, M(&g_dsp.pc), R(EAX)); emitter.MOV(16, M(&g_dsp.pc), R(EAX));
WriteBranchExit(emitter); WriteBranchExit(emitter);
} }
@ -204,7 +204,7 @@ static void r_callr(const UDSPInstruction opc, DSPEmitter& emitter)
u8 reg = (opc >> 5) & 0x7; u8 reg = (opc >> 5) & 0x7;
emitter.MOV(16, R(DX), Imm16(emitter.m_compile_pc + 1)); emitter.MOV(16, R(DX), Imm16(emitter.m_compile_pc + 1));
emitter.dsp_reg_store_stack(DSP_STACK_C); emitter.dsp_reg_store_stack(DSP_STACK_C);
emitter.dsp_op_read_reg(reg, RAX, NONE); emitter.dsp_op_read_reg(reg, RAX);
emitter.MOV(16, M(&g_dsp.pc), R(EAX)); emitter.MOV(16, M(&g_dsp.pc), R(EAX));
WriteBranchExit(emitter); WriteBranchExit(emitter);
} }
@ -334,7 +334,7 @@ void DSPEmitter::loop(const UDSPInstruction opc)
u16 reg = opc & 0x1f; u16 reg = opc & 0x1f;
// u16 cnt = g_dsp.r[reg]; // u16 cnt = g_dsp.r[reg];
// todo: check if we can use normal variant here // todo: check if we can use normal variant here
dsp_op_read_reg_dont_saturate(reg, RDX, ZERO); dsp_op_read_reg_dont_saturate(reg, RDX, RegisterExtension::Zero);
u16 loop_pc = m_compile_pc + 1; u16 loop_pc = m_compile_pc + 1;
TEST(16, R(EDX), R(EDX)); TEST(16, R(EDX), R(EDX));
@ -403,7 +403,7 @@ void DSPEmitter::bloop(const UDSPInstruction opc)
u16 reg = opc & 0x1f; u16 reg = opc & 0x1f;
// u16 cnt = g_dsp.r[reg]; // u16 cnt = g_dsp.r[reg];
// todo: check if we can use normal variant here // todo: check if we can use normal variant here
dsp_op_read_reg_dont_saturate(reg, RDX, ZERO); dsp_op_read_reg_dont_saturate(reg, RDX, RegisterExtension::Zero);
u16 loop_pc = dsp_imem_read(m_compile_pc + 1); u16 loop_pc = dsp_imem_read(m_compile_pc + 1);
TEST(16, R(EDX), R(EDX)); TEST(16, R(EDX), R(EDX));

View File

@ -64,7 +64,7 @@ void DSPEmitter::mv(const UDSPInstruction opc)
{ {
u8 sreg = (opc & 0x3) + DSP_REG_ACL0; u8 sreg = (opc & 0x3) + DSP_REG_ACL0;
u8 dreg = ((opc >> 2) & 0x3); u8 dreg = ((opc >> 2) & 0x3);
dsp_op_read_reg(sreg, RBX, ZERO); dsp_op_read_reg(sreg, RBX, RegisterExtension::Zero);
m_store_index = dreg + DSP_REG_AXL0; m_store_index = dreg + DSP_REG_AXL0;
} }
@ -77,11 +77,11 @@ void DSPEmitter::s(const UDSPInstruction opc)
u8 dreg = opc & 0x3; u8 dreg = opc & 0x3;
u8 sreg = ((opc >> 3) & 0x3) + DSP_REG_ACL0; u8 sreg = ((opc >> 3) & 0x3) + DSP_REG_ACL0;
// u16 addr = g_dsp.r[dest]; // u16 addr = g_dsp.r[dest];
dsp_op_read_reg(dreg, RAX, ZERO); dsp_op_read_reg(dreg, RAX, RegisterExtension::Zero);
X64Reg tmp1 = m_gpr.GetFreeXReg(); X64Reg tmp1 = m_gpr.GetFreeXReg();
dsp_op_read_reg(sreg, tmp1, ZERO); dsp_op_read_reg(sreg, tmp1, RegisterExtension::Zero);
// u16 val = g_dsp.r[src]; // u16 val = g_dsp.r[src];
dmem_write(tmp1); dmem_write(tmp1);
@ -98,11 +98,11 @@ void DSPEmitter::sn(const UDSPInstruction opc)
{ {
u8 dreg = opc & 0x3; u8 dreg = opc & 0x3;
u8 sreg = ((opc >> 3) & 0x3) + DSP_REG_ACL0; u8 sreg = ((opc >> 3) & 0x3) + DSP_REG_ACL0;
dsp_op_read_reg(dreg, RAX, ZERO); dsp_op_read_reg(dreg, RAX, RegisterExtension::Zero);
X64Reg tmp1 = m_gpr.GetFreeXReg(); X64Reg tmp1 = m_gpr.GetFreeXReg();
dsp_op_read_reg(sreg, tmp1, ZERO); dsp_op_read_reg(sreg, tmp1, RegisterExtension::Zero);
dmem_write(tmp1); dmem_write(tmp1);
m_gpr.PutXReg(tmp1); m_gpr.PutXReg(tmp1);
@ -169,11 +169,11 @@ void DSPEmitter::ls(const UDSPInstruction opc)
{ {
u8 sreg = opc & 0x1; u8 sreg = opc & 0x1;
u8 dreg = ((opc >> 4) & 0x3) + DSP_REG_AXL0; u8 dreg = ((opc >> 4) & 0x3) + DSP_REG_AXL0;
dsp_op_read_reg(DSP_REG_AR3, RAX, ZERO); dsp_op_read_reg(DSP_REG_AR3, RAX, RegisterExtension::Zero);
X64Reg tmp1 = m_gpr.GetFreeXReg(); X64Reg tmp1 = m_gpr.GetFreeXReg();
dsp_op_read_reg(sreg + DSP_REG_ACM0, tmp1, ZERO); dsp_op_read_reg(sreg + DSP_REG_ACM0, tmp1, RegisterExtension::Zero);
dmem_write(tmp1); dmem_write(tmp1);
m_gpr.PutXReg(tmp1); m_gpr.PutXReg(tmp1);
@ -194,11 +194,11 @@ void DSPEmitter::lsn(const UDSPInstruction opc)
{ {
u8 sreg = opc & 0x1; u8 sreg = opc & 0x1;
u8 dreg = ((opc >> 4) & 0x3) + DSP_REG_AXL0; u8 dreg = ((opc >> 4) & 0x3) + DSP_REG_AXL0;
dsp_op_read_reg(DSP_REG_AR3, RAX, ZERO); dsp_op_read_reg(DSP_REG_AR3, RAX, RegisterExtension::Zero);
X64Reg tmp1 = m_gpr.GetFreeXReg(); X64Reg tmp1 = m_gpr.GetFreeXReg();
dsp_op_read_reg(sreg + DSP_REG_ACM0, tmp1, ZERO); dsp_op_read_reg(sreg + DSP_REG_ACM0, tmp1, RegisterExtension::Zero);
dmem_write(tmp1); dmem_write(tmp1);
m_gpr.PutXReg(tmp1); m_gpr.PutXReg(tmp1);
@ -219,11 +219,11 @@ void DSPEmitter::lsm(const UDSPInstruction opc)
{ {
u8 sreg = opc & 0x1; u8 sreg = opc & 0x1;
u8 dreg = ((opc >> 4) & 0x3) + DSP_REG_AXL0; u8 dreg = ((opc >> 4) & 0x3) + DSP_REG_AXL0;
dsp_op_read_reg(DSP_REG_AR3, RAX, ZERO); dsp_op_read_reg(DSP_REG_AR3, RAX, RegisterExtension::Zero);
X64Reg tmp1 = m_gpr.GetFreeXReg(); X64Reg tmp1 = m_gpr.GetFreeXReg();
dsp_op_read_reg(sreg + DSP_REG_ACM0, tmp1, ZERO); dsp_op_read_reg(sreg + DSP_REG_ACM0, tmp1, RegisterExtension::Zero);
dmem_write(tmp1); dmem_write(tmp1);
m_gpr.PutXReg(tmp1); m_gpr.PutXReg(tmp1);
@ -245,11 +245,11 @@ void DSPEmitter::lsnm(const UDSPInstruction opc)
{ {
u8 sreg = opc & 0x1; u8 sreg = opc & 0x1;
u8 dreg = ((opc >> 4) & 0x3) + DSP_REG_AXL0; u8 dreg = ((opc >> 4) & 0x3) + DSP_REG_AXL0;
dsp_op_read_reg(DSP_REG_AR3, RAX, ZERO); dsp_op_read_reg(DSP_REG_AR3, RAX, RegisterExtension::Zero);
X64Reg tmp1 = m_gpr.GetFreeXReg(); X64Reg tmp1 = m_gpr.GetFreeXReg();
dsp_op_read_reg(sreg + DSP_REG_ACM0, tmp1, ZERO); dsp_op_read_reg(sreg + DSP_REG_ACM0, tmp1, RegisterExtension::Zero);
dmem_write(tmp1); dmem_write(tmp1);
m_gpr.PutXReg(tmp1); m_gpr.PutXReg(tmp1);
@ -269,11 +269,11 @@ void DSPEmitter::sl(const UDSPInstruction opc)
{ {
u8 sreg = opc & 0x1; u8 sreg = opc & 0x1;
u8 dreg = ((opc >> 4) & 0x3) + DSP_REG_AXL0; u8 dreg = ((opc >> 4) & 0x3) + DSP_REG_AXL0;
dsp_op_read_reg(DSP_REG_AR0, RAX, ZERO); dsp_op_read_reg(DSP_REG_AR0, RAX, RegisterExtension::Zero);
X64Reg tmp1 = m_gpr.GetFreeXReg(); X64Reg tmp1 = m_gpr.GetFreeXReg();
dsp_op_read_reg(sreg + DSP_REG_ACM0, tmp1, ZERO); dsp_op_read_reg(sreg + DSP_REG_ACM0, tmp1, RegisterExtension::Zero);
dmem_write(tmp1); dmem_write(tmp1);
m_gpr.PutXReg(tmp1); m_gpr.PutXReg(tmp1);
@ -294,11 +294,11 @@ void DSPEmitter::sln(const UDSPInstruction opc)
{ {
u8 sreg = opc & 0x1; u8 sreg = opc & 0x1;
u8 dreg = ((opc >> 4) & 0x3) + DSP_REG_AXL0; u8 dreg = ((opc >> 4) & 0x3) + DSP_REG_AXL0;
dsp_op_read_reg(DSP_REG_AR0, RAX, ZERO); dsp_op_read_reg(DSP_REG_AR0, RAX, RegisterExtension::Zero);
X64Reg tmp1 = m_gpr.GetFreeXReg(); X64Reg tmp1 = m_gpr.GetFreeXReg();
dsp_op_read_reg(sreg + DSP_REG_ACM0, tmp1, ZERO); dsp_op_read_reg(sreg + DSP_REG_ACM0, tmp1, RegisterExtension::Zero);
dmem_write(tmp1); dmem_write(tmp1);
m_gpr.PutXReg(tmp1); m_gpr.PutXReg(tmp1);
@ -319,11 +319,11 @@ void DSPEmitter::slm(const UDSPInstruction opc)
{ {
u8 sreg = opc & 0x1; u8 sreg = opc & 0x1;
u8 dreg = ((opc >> 4) & 0x3) + DSP_REG_AXL0; u8 dreg = ((opc >> 4) & 0x3) + DSP_REG_AXL0;
dsp_op_read_reg(DSP_REG_AR0, RAX, ZERO); dsp_op_read_reg(DSP_REG_AR0, RAX, RegisterExtension::Zero);
X64Reg tmp1 = m_gpr.GetFreeXReg(); X64Reg tmp1 = m_gpr.GetFreeXReg();
dsp_op_read_reg(sreg + DSP_REG_ACM0, tmp1, ZERO); dsp_op_read_reg(sreg + DSP_REG_ACM0, tmp1, RegisterExtension::Zero);
dmem_write(tmp1); dmem_write(tmp1);
m_gpr.PutXReg(tmp1); m_gpr.PutXReg(tmp1);
@ -344,11 +344,11 @@ void DSPEmitter::slnm(const UDSPInstruction opc)
{ {
u8 sreg = opc & 0x1; u8 sreg = opc & 0x1;
u8 dreg = ((opc >> 4) & 0x3) + DSP_REG_AXL0; u8 dreg = ((opc >> 4) & 0x3) + DSP_REG_AXL0;
dsp_op_read_reg(DSP_REG_AR0, RAX, ZERO); dsp_op_read_reg(DSP_REG_AR0, RAX, RegisterExtension::Zero);
X64Reg tmp1 = m_gpr.GetFreeXReg(); X64Reg tmp1 = m_gpr.GetFreeXReg();
dsp_op_read_reg(sreg + DSP_REG_ACM0, tmp1, ZERO); dsp_op_read_reg(sreg + DSP_REG_ACM0, tmp1, RegisterExtension::Zero);
dmem_write(tmp1); dmem_write(tmp1);
m_gpr.PutXReg(tmp1); m_gpr.PutXReg(tmp1);
@ -379,8 +379,8 @@ void DSPEmitter::ld(const UDSPInstruction opc)
// if (IsSameMemArea(g_dsp.r[sreg], g_dsp.r[DSP_REG_AR3])) { // if (IsSameMemArea(g_dsp.r[sreg], g_dsp.r[DSP_REG_AR3])) {
X64Reg tmp = m_gpr.GetFreeXReg(); X64Reg tmp = m_gpr.GetFreeXReg();
dsp_op_read_reg(sreg, RCX, NONE); dsp_op_read_reg(sreg, RCX);
dsp_op_read_reg(DSP_REG_AR3, tmp, NONE); dsp_op_read_reg(DSP_REG_AR3, tmp);
XOR(16, R(ECX), R(tmp)); XOR(16, R(ECX), R(tmp));
m_gpr.PutXReg(tmp); m_gpr.PutXReg(tmp);
DSPJitRegCache c(m_gpr); DSPJitRegCache c(m_gpr);
@ -410,8 +410,8 @@ void DSPEmitter::ldax(const UDSPInstruction opc)
X64Reg tmp = m_gpr.GetFreeXReg(); X64Reg tmp = m_gpr.GetFreeXReg();
// if (IsSameMemArea(g_dsp.r[sreg], g_dsp.r[DSP_REG_AR3])) { // if (IsSameMemArea(g_dsp.r[sreg], g_dsp.r[DSP_REG_AR3])) {
dsp_op_read_reg(sreg, RCX, NONE); dsp_op_read_reg(sreg, RCX);
dsp_op_read_reg(DSP_REG_AR3, tmp, NONE); dsp_op_read_reg(DSP_REG_AR3, tmp);
XOR(16, R(ECX), R(tmp)); XOR(16, R(ECX), R(tmp));
m_gpr.PutXReg(tmp); m_gpr.PutXReg(tmp);
DSPJitRegCache c(m_gpr); DSPJitRegCache c(m_gpr);
@ -442,8 +442,8 @@ void DSPEmitter::ldn(const UDSPInstruction opc)
X64Reg tmp = m_gpr.GetFreeXReg(); X64Reg tmp = m_gpr.GetFreeXReg();
// if (IsSameMemArea(g_dsp.r[sreg], g_dsp.r[DSP_REG_AR3])) { // if (IsSameMemArea(g_dsp.r[sreg], g_dsp.r[DSP_REG_AR3])) {
dsp_op_read_reg(sreg, RCX, NONE); dsp_op_read_reg(sreg, RCX);
dsp_op_read_reg(DSP_REG_AR3, tmp, NONE); dsp_op_read_reg(DSP_REG_AR3, tmp);
XOR(16, R(ECX), R(tmp)); XOR(16, R(ECX), R(tmp));
m_gpr.PutXReg(tmp); m_gpr.PutXReg(tmp);
DSPJitRegCache c(m_gpr); DSPJitRegCache c(m_gpr);
@ -473,8 +473,8 @@ void DSPEmitter::ldaxn(const UDSPInstruction opc)
X64Reg tmp = m_gpr.GetFreeXReg(); X64Reg tmp = m_gpr.GetFreeXReg();
// if (IsSameMemArea(g_dsp.r[sreg], g_dsp.r[DSP_REG_AR3])) { // if (IsSameMemArea(g_dsp.r[sreg], g_dsp.r[DSP_REG_AR3])) {
dsp_op_read_reg(sreg, RCX, NONE); dsp_op_read_reg(sreg, RCX);
dsp_op_read_reg(DSP_REG_AR3, tmp, NONE); dsp_op_read_reg(DSP_REG_AR3, tmp);
XOR(16, R(ECX), R(tmp)); XOR(16, R(ECX), R(tmp));
m_gpr.PutXReg(tmp); m_gpr.PutXReg(tmp);
DSPJitRegCache c(m_gpr); DSPJitRegCache c(m_gpr);
@ -505,8 +505,8 @@ void DSPEmitter::ldm(const UDSPInstruction opc)
X64Reg tmp = m_gpr.GetFreeXReg(); X64Reg tmp = m_gpr.GetFreeXReg();
// if (IsSameMemArea(g_dsp.r[sreg], g_dsp.r[DSP_REG_AR3])) { // if (IsSameMemArea(g_dsp.r[sreg], g_dsp.r[DSP_REG_AR3])) {
dsp_op_read_reg(sreg, RCX, NONE); dsp_op_read_reg(sreg, RCX);
dsp_op_read_reg(DSP_REG_AR3, tmp, NONE); dsp_op_read_reg(DSP_REG_AR3, tmp);
XOR(16, R(ECX), R(tmp)); XOR(16, R(ECX), R(tmp));
m_gpr.PutXReg(tmp); m_gpr.PutXReg(tmp);
DSPJitRegCache c(m_gpr); DSPJitRegCache c(m_gpr);
@ -536,8 +536,8 @@ void DSPEmitter::ldaxm(const UDSPInstruction opc)
X64Reg tmp = m_gpr.GetFreeXReg(); X64Reg tmp = m_gpr.GetFreeXReg();
// if (IsSameMemArea(g_dsp.r[sreg], g_dsp.r[DSP_REG_AR3])) { // if (IsSameMemArea(g_dsp.r[sreg], g_dsp.r[DSP_REG_AR3])) {
dsp_op_read_reg(sreg, RCX, NONE); dsp_op_read_reg(sreg, RCX);
dsp_op_read_reg(DSP_REG_AR3, tmp, NONE); dsp_op_read_reg(DSP_REG_AR3, tmp);
XOR(16, R(ECX), R(tmp)); XOR(16, R(ECX), R(tmp));
m_gpr.PutXReg(tmp); m_gpr.PutXReg(tmp);
DSPJitRegCache c(m_gpr); DSPJitRegCache c(m_gpr);
@ -568,8 +568,8 @@ void DSPEmitter::ldnm(const UDSPInstruction opc)
X64Reg tmp = m_gpr.GetFreeXReg(); X64Reg tmp = m_gpr.GetFreeXReg();
// if (IsSameMemArea(g_dsp.r[sreg], g_dsp.r[DSP_REG_AR3])) { // if (IsSameMemArea(g_dsp.r[sreg], g_dsp.r[DSP_REG_AR3])) {
dsp_op_read_reg(sreg, RCX, NONE); dsp_op_read_reg(sreg, RCX);
dsp_op_read_reg(DSP_REG_AR3, tmp, NONE); dsp_op_read_reg(DSP_REG_AR3, tmp);
XOR(16, R(ECX), R(tmp)); XOR(16, R(ECX), R(tmp));
m_gpr.PutXReg(tmp); m_gpr.PutXReg(tmp);
DSPJitRegCache c(m_gpr); DSPJitRegCache c(m_gpr);
@ -599,8 +599,8 @@ void DSPEmitter::ldaxnm(const UDSPInstruction opc)
X64Reg tmp = m_gpr.GetFreeXReg(); X64Reg tmp = m_gpr.GetFreeXReg();
// if (IsSameMemArea(g_dsp.r[sreg], g_dsp.r[DSP_REG_AR3])) { // if (IsSameMemArea(g_dsp.r[sreg], g_dsp.r[DSP_REG_AR3])) {
dsp_op_read_reg(sreg, RCX, NONE); dsp_op_read_reg(sreg, RCX);
dsp_op_read_reg(DSP_REG_AR3, tmp, NONE); dsp_op_read_reg(DSP_REG_AR3, tmp);
XOR(16, R(ECX), R(tmp)); XOR(16, R(ECX), R(tmp));
m_gpr.PutXReg(tmp); m_gpr.PutXReg(tmp);
DSPJitRegCache c(m_gpr); DSPJitRegCache c(m_gpr);
@ -627,7 +627,7 @@ void DSPEmitter::pushExtValueFromMem(u16 dreg, u16 sreg)
X64Reg tmp1 = m_gpr.GetFreeXReg(); X64Reg tmp1 = m_gpr.GetFreeXReg();
dsp_op_read_reg(sreg, tmp1, ZERO); dsp_op_read_reg(sreg, tmp1, RegisterExtension::Zero);
dmem_read(tmp1); dmem_read(tmp1);
m_gpr.PutXReg(tmp1); m_gpr.PutXReg(tmp1);
@ -643,7 +643,7 @@ void DSPEmitter::pushExtValueFromMem2(u16 dreg, u16 sreg)
X64Reg tmp1 = m_gpr.GetFreeXReg(); X64Reg tmp1 = m_gpr.GetFreeXReg();
dsp_op_read_reg(sreg, tmp1, ZERO); dsp_op_read_reg(sreg, tmp1, RegisterExtension::Zero);
dmem_read(tmp1); dmem_read(tmp1);
m_gpr.PutXReg(tmp1); m_gpr.PutXReg(tmp1);

View File

@ -31,8 +31,8 @@ void DSPEmitter::srs(const UDSPInstruction opc)
X64Reg tmp1 = m_gpr.GetFreeXReg(); X64Reg tmp1 = m_gpr.GetFreeXReg();
dsp_op_read_reg(reg, tmp1, ZERO); dsp_op_read_reg(reg, tmp1, RegisterExtension::Zero);
dsp_op_read_reg(DSP_REG_CR, RAX, ZERO); dsp_op_read_reg(DSP_REG_CR, RAX, RegisterExtension::Zero);
SHL(16, R(EAX), Imm8(8)); SHL(16, R(EAX), Imm8(8));
OR(16, R(EAX), Imm16(opc & 0xFF)); OR(16, R(EAX), Imm16(opc & 0xFF));
dmem_write(tmp1); dmem_write(tmp1);
@ -52,7 +52,7 @@ void DSPEmitter::lrs(const UDSPInstruction opc)
X64Reg tmp1 = m_gpr.GetFreeXReg(); X64Reg tmp1 = m_gpr.GetFreeXReg();
// u16 addr = (g_dsp.r[DSP_REG_CR] << 8) | (opc & 0xFF); // u16 addr = (g_dsp.r[DSP_REG_CR] << 8) | (opc & 0xFF);
dsp_op_read_reg(DSP_REG_CR, tmp1, ZERO); dsp_op_read_reg(DSP_REG_CR, tmp1, RegisterExtension::Zero);
SHL(16, R(tmp1), Imm8(8)); SHL(16, R(tmp1), Imm8(8));
OR(16, R(tmp1), Imm16(opc & 0xFF)); OR(16, R(tmp1), Imm16(opc & 0xFF));
dmem_read(tmp1); dmem_read(tmp1);
@ -205,7 +205,7 @@ void DSPEmitter::srr(const UDSPInstruction opc)
X64Reg tmp1 = m_gpr.GetFreeXReg(); X64Reg tmp1 = m_gpr.GetFreeXReg();
dsp_op_read_reg(sreg, tmp1); dsp_op_read_reg(sreg, tmp1);
dsp_op_read_reg(dreg, RAX, ZERO); dsp_op_read_reg(dreg, RAX, RegisterExtension::Zero);
dmem_write(tmp1); dmem_write(tmp1);
m_gpr.PutXReg(tmp1); m_gpr.PutXReg(tmp1);
@ -223,7 +223,7 @@ void DSPEmitter::srrd(const UDSPInstruction opc)
X64Reg tmp1 = m_gpr.GetFreeXReg(); X64Reg tmp1 = m_gpr.GetFreeXReg();
dsp_op_read_reg(sreg, tmp1); dsp_op_read_reg(sreg, tmp1);
dsp_op_read_reg(dreg, RAX, ZERO); dsp_op_read_reg(dreg, RAX, RegisterExtension::Zero);
dmem_write(tmp1); dmem_write(tmp1);
m_gpr.PutXReg(tmp1); m_gpr.PutXReg(tmp1);
@ -243,7 +243,7 @@ void DSPEmitter::srri(const UDSPInstruction opc)
X64Reg tmp1 = m_gpr.GetFreeXReg(); X64Reg tmp1 = m_gpr.GetFreeXReg();
dsp_op_read_reg(sreg, tmp1); dsp_op_read_reg(sreg, tmp1);
dsp_op_read_reg(dreg, RAX, ZERO); dsp_op_read_reg(dreg, RAX, RegisterExtension::Zero);
dmem_write(tmp1); dmem_write(tmp1);
m_gpr.PutXReg(tmp1); m_gpr.PutXReg(tmp1);
@ -263,7 +263,7 @@ void DSPEmitter::srrn(const UDSPInstruction opc)
X64Reg tmp1 = m_gpr.GetFreeXReg(); X64Reg tmp1 = m_gpr.GetFreeXReg();
dsp_op_read_reg(sreg, tmp1); dsp_op_read_reg(sreg, tmp1);
dsp_op_read_reg(dreg, RAX, ZERO); dsp_op_read_reg(dreg, RAX, RegisterExtension::Zero);
dmem_write(tmp1); dmem_write(tmp1);
m_gpr.PutXReg(tmp1); m_gpr.PutXReg(tmp1);
@ -282,7 +282,7 @@ void DSPEmitter::ilrr(const UDSPInstruction opc)
X64Reg tmp1 = m_gpr.GetFreeXReg(); X64Reg tmp1 = m_gpr.GetFreeXReg();
dsp_op_read_reg(reg, tmp1, ZERO); dsp_op_read_reg(reg, tmp1, RegisterExtension::Zero);
imem_read(tmp1); imem_read(tmp1);
m_gpr.PutXReg(tmp1); m_gpr.PutXReg(tmp1);
@ -302,7 +302,7 @@ void DSPEmitter::ilrrd(const UDSPInstruction opc)
X64Reg tmp1 = m_gpr.GetFreeXReg(); X64Reg tmp1 = m_gpr.GetFreeXReg();
dsp_op_read_reg(reg, tmp1, ZERO); dsp_op_read_reg(reg, tmp1, RegisterExtension::Zero);
imem_read(tmp1); imem_read(tmp1);
m_gpr.PutXReg(tmp1); m_gpr.PutXReg(tmp1);
@ -323,7 +323,7 @@ void DSPEmitter::ilrri(const UDSPInstruction opc)
X64Reg tmp1 = m_gpr.GetFreeXReg(); X64Reg tmp1 = m_gpr.GetFreeXReg();
dsp_op_read_reg(reg, tmp1, ZERO); dsp_op_read_reg(reg, tmp1, RegisterExtension::Zero);
imem_read(tmp1); imem_read(tmp1);
m_gpr.PutXReg(tmp1); m_gpr.PutXReg(tmp1);
@ -345,7 +345,7 @@ void DSPEmitter::ilrrn(const UDSPInstruction opc)
X64Reg tmp1 = m_gpr.GetFreeXReg(); X64Reg tmp1 = m_gpr.GetFreeXReg();
dsp_op_read_reg(reg, tmp1, ZERO); dsp_op_read_reg(reg, tmp1, RegisterExtension::Zero);
imem_read(tmp1); imem_read(tmp1);
m_gpr.PutXReg(tmp1); m_gpr.PutXReg(tmp1);

View File

@ -285,7 +285,7 @@ void DSPEmitter::addpaxz(const UDSPInstruction opc)
void DSPEmitter::mulaxh(const UDSPInstruction opc) void DSPEmitter::mulaxh(const UDSPInstruction opc)
{ {
// s64 prod = dsp_multiply(dsp_get_ax_h(0), dsp_get_ax_h(0)); // s64 prod = dsp_multiply(dsp_get_ax_h(0), dsp_get_ax_h(0));
dsp_op_read_reg(DSP_REG_AXH0, RCX, SIGN); dsp_op_read_reg(DSP_REG_AXH0, RCX, RegisterExtension::Sign);
MOV(64, R(RAX), R(RCX)); MOV(64, R(RAX), R(RCX));
multiply(); multiply();
// dsp_set_long_prod(prod); // dsp_set_long_prod(prod);
@ -303,9 +303,9 @@ void DSPEmitter::mul(const UDSPInstruction opc)
u8 sreg = (opc >> 11) & 0x1; u8 sreg = (opc >> 11) & 0x1;
// u16 axl = dsp_get_ax_l(sreg); // u16 axl = dsp_get_ax_l(sreg);
dsp_op_read_reg(DSP_REG_AXL0 + sreg, RCX, SIGN); dsp_op_read_reg(DSP_REG_AXL0 + sreg, RCX, RegisterExtension::Sign);
// u16 axh = dsp_get_ax_h(sreg); // u16 axh = dsp_get_ax_h(sreg);
dsp_op_read_reg(DSP_REG_AXH0 + sreg, RAX, SIGN); dsp_op_read_reg(DSP_REG_AXH0 + sreg, RAX, RegisterExtension::Sign);
// s64 prod = dsp_multiply(axh, axl); // s64 prod = dsp_multiply(axh, axl);
multiply(); multiply();
// dsp_set_long_prod(prod); // dsp_set_long_prod(prod);
@ -331,9 +331,9 @@ void DSPEmitter::mulac(const UDSPInstruction opc)
ADD(64, R(RAX), R(RDX)); ADD(64, R(RAX), R(RDX));
PUSH(64, R(RAX)); PUSH(64, R(RAX));
// u16 axl = dsp_get_ax_l(sreg); // u16 axl = dsp_get_ax_l(sreg);
dsp_op_read_reg(DSP_REG_AXL0 + sreg, RCX, SIGN); dsp_op_read_reg(DSP_REG_AXL0 + sreg, RCX, RegisterExtension::Sign);
// u16 axh = dsp_get_ax_h(sreg); // u16 axh = dsp_get_ax_h(sreg);
dsp_op_read_reg(DSP_REG_AXH0 + sreg, RAX, SIGN); dsp_op_read_reg(DSP_REG_AXH0 + sreg, RAX, RegisterExtension::Sign);
// s64 prod = dsp_multiply(axl, axh); // s64 prod = dsp_multiply(axl, axh);
multiply(); multiply();
// dsp_set_long_prod(prod); // dsp_set_long_prod(prod);
@ -409,9 +409,9 @@ void DSPEmitter::mulx(const UDSPInstruction opc)
u8 sreg = ((opc >> 12) & 0x1); u8 sreg = ((opc >> 12) & 0x1);
// u16 val1 = (sreg == 0) ? dsp_get_ax_l(0) : dsp_get_ax_h(0); // u16 val1 = (sreg == 0) ? dsp_get_ax_l(0) : dsp_get_ax_h(0);
dsp_op_read_reg(DSP_REG_AXL0 + sreg * 2, RCX, SIGN); dsp_op_read_reg(DSP_REG_AXL0 + sreg * 2, RCX, RegisterExtension::Sign);
// u16 val2 = (treg == 0) ? dsp_get_ax_l(1) : dsp_get_ax_h(1); // u16 val2 = (treg == 0) ? dsp_get_ax_l(1) : dsp_get_ax_h(1);
dsp_op_read_reg(DSP_REG_AXL1 + treg * 2, RAX, SIGN); dsp_op_read_reg(DSP_REG_AXL1 + treg * 2, RAX, RegisterExtension::Sign);
// s64 prod = dsp_multiply_mulx(sreg, treg, val1, val2); // s64 prod = dsp_multiply_mulx(sreg, treg, val1, val2);
multiply_mulx(sreg, treg); multiply_mulx(sreg, treg);
// dsp_set_long_prod(prod); // dsp_set_long_prod(prod);
@ -437,9 +437,9 @@ void DSPEmitter::mulxac(const UDSPInstruction opc)
get_long_prod(); get_long_prod();
ADD(64, R(tmp1), R(RAX)); ADD(64, R(tmp1), R(RAX));
// u16 val1 = (sreg == 0) ? dsp_get_ax_l(0) : dsp_get_ax_h(0); // u16 val1 = (sreg == 0) ? dsp_get_ax_l(0) : dsp_get_ax_h(0);
dsp_op_read_reg(DSP_REG_AXL0 + sreg * 2, RCX, SIGN); dsp_op_read_reg(DSP_REG_AXL0 + sreg * 2, RCX, RegisterExtension::Sign);
// u16 val2 = (treg == 0) ? dsp_get_ax_l(1) : dsp_get_ax_h(1); // u16 val2 = (treg == 0) ? dsp_get_ax_l(1) : dsp_get_ax_h(1);
dsp_op_read_reg(DSP_REG_AXL1 + treg * 2, RAX, SIGN); dsp_op_read_reg(DSP_REG_AXL1 + treg * 2, RAX, RegisterExtension::Sign);
// s64 prod = dsp_multiply_mulx(sreg, treg, val1, val2); // s64 prod = dsp_multiply_mulx(sreg, treg, val1, val2);
multiply_mulx(sreg, treg); multiply_mulx(sreg, treg);
@ -472,9 +472,9 @@ void DSPEmitter::mulxmv(const UDSPInstruction opc)
X64Reg tmp1 = m_gpr.GetFreeXReg(); X64Reg tmp1 = m_gpr.GetFreeXReg();
get_long_prod(tmp1); get_long_prod(tmp1);
// u16 val1 = (sreg == 0) ? dsp_get_ax_l(0) : dsp_get_ax_h(0); // u16 val1 = (sreg == 0) ? dsp_get_ax_l(0) : dsp_get_ax_h(0);
dsp_op_read_reg(DSP_REG_AXL0 + sreg * 2, RCX, SIGN); dsp_op_read_reg(DSP_REG_AXL0 + sreg * 2, RCX, RegisterExtension::Sign);
// u16 val2 = (treg == 0) ? dsp_get_ax_l(1) : dsp_get_ax_h(1); // u16 val2 = (treg == 0) ? dsp_get_ax_l(1) : dsp_get_ax_h(1);
dsp_op_read_reg(DSP_REG_AXL1 + treg * 2, RAX, SIGN); dsp_op_read_reg(DSP_REG_AXL1 + treg * 2, RAX, RegisterExtension::Sign);
// s64 prod = dsp_multiply_mulx(sreg, treg, val1, val2); // s64 prod = dsp_multiply_mulx(sreg, treg, val1, val2);
multiply_mulx(sreg, treg); multiply_mulx(sreg, treg);
@ -508,9 +508,9 @@ void DSPEmitter::mulxmvz(const UDSPInstruction opc)
X64Reg tmp1 = m_gpr.GetFreeXReg(); X64Reg tmp1 = m_gpr.GetFreeXReg();
get_long_prod_round_prodl(tmp1); get_long_prod_round_prodl(tmp1);
// u16 val1 = (sreg == 0) ? dsp_get_ax_l(0) : dsp_get_ax_h(0); // u16 val1 = (sreg == 0) ? dsp_get_ax_l(0) : dsp_get_ax_h(0);
dsp_op_read_reg(DSP_REG_AXL0 + sreg * 2, RCX, SIGN); dsp_op_read_reg(DSP_REG_AXL0 + sreg * 2, RCX, RegisterExtension::Sign);
// u16 val2 = (treg == 0) ? dsp_get_ax_l(1) : dsp_get_ax_h(1); // u16 val2 = (treg == 0) ? dsp_get_ax_l(1) : dsp_get_ax_h(1);
dsp_op_read_reg(DSP_REG_AXL1 + treg * 2, RAX, SIGN); dsp_op_read_reg(DSP_REG_AXL1 + treg * 2, RAX, RegisterExtension::Sign);
// s64 prod = dsp_multiply_mulx(sreg, treg, val1, val2); // s64 prod = dsp_multiply_mulx(sreg, treg, val1, val2);
multiply_mulx(sreg, treg); multiply_mulx(sreg, treg);
@ -540,7 +540,7 @@ void DSPEmitter::mulc(const UDSPInstruction opc)
// u16 accm = dsp_get_acc_m(sreg); // u16 accm = dsp_get_acc_m(sreg);
get_acc_m(sreg, ECX); get_acc_m(sreg, ECX);
// u16 axh = dsp_get_ax_h(treg); // u16 axh = dsp_get_ax_h(treg);
dsp_op_read_reg(DSP_REG_AXH0 + treg, RAX, SIGN); dsp_op_read_reg(DSP_REG_AXH0 + treg, RAX, RegisterExtension::Sign);
// s64 prod = dsp_multiply(accm, axh); // s64 prod = dsp_multiply(accm, axh);
multiply(); multiply();
// dsp_set_long_prod(prod); // dsp_set_long_prod(prod);
@ -569,7 +569,7 @@ void DSPEmitter::mulcac(const UDSPInstruction opc)
// u16 accm = dsp_get_acc_m(sreg); // u16 accm = dsp_get_acc_m(sreg);
get_acc_m(sreg, ECX); get_acc_m(sreg, ECX);
// u16 axh = dsp_get_ax_h(treg); // u16 axh = dsp_get_ax_h(treg);
dsp_op_read_reg(DSP_REG_AXH0 + treg, RAX, SIGN); dsp_op_read_reg(DSP_REG_AXH0 + treg, RAX, RegisterExtension::Sign);
// s64 prod = dsp_multiply(accm, axh); // s64 prod = dsp_multiply(accm, axh);
multiply(); multiply();
// dsp_set_long_prod(prod); // dsp_set_long_prod(prod);
@ -604,7 +604,7 @@ void DSPEmitter::mulcmv(const UDSPInstruction opc)
// u16 accm = dsp_get_acc_m(sreg); // u16 accm = dsp_get_acc_m(sreg);
get_acc_m(sreg, ECX); get_acc_m(sreg, ECX);
// u16 axh = dsp_get_ax_h(treg); // u16 axh = dsp_get_ax_h(treg);
dsp_op_read_reg(DSP_REG_AXH0 + treg, RAX, SIGN); dsp_op_read_reg(DSP_REG_AXH0 + treg, RAX, RegisterExtension::Sign);
// s64 prod = dsp_multiply(accm, axh); // s64 prod = dsp_multiply(accm, axh);
multiply(); multiply();
// dsp_set_long_prod(prod); // dsp_set_long_prod(prod);
@ -640,7 +640,7 @@ void DSPEmitter::mulcmvz(const UDSPInstruction opc)
// u16 accm = dsp_get_acc_m(sreg); // u16 accm = dsp_get_acc_m(sreg);
get_acc_m(sreg, ECX); get_acc_m(sreg, ECX);
// u16 axh = dsp_get_ax_h(treg); // u16 axh = dsp_get_ax_h(treg);
dsp_op_read_reg(DSP_REG_AXH0 + treg, RAX, SIGN); dsp_op_read_reg(DSP_REG_AXH0 + treg, RAX, RegisterExtension::Sign);
// s64 prod = dsp_multiply(accm, axh); // s64 prod = dsp_multiply(accm, axh);
multiply(); multiply();
// dsp_set_long_prod(prod); // dsp_set_long_prod(prod);
@ -668,9 +668,9 @@ void DSPEmitter::maddx(const UDSPInstruction opc)
u8 sreg = (opc >> 9) & 0x1; u8 sreg = (opc >> 9) & 0x1;
// u16 val1 = (sreg == 0) ? dsp_get_ax_l(0) : dsp_get_ax_h(0); // u16 val1 = (sreg == 0) ? dsp_get_ax_l(0) : dsp_get_ax_h(0);
dsp_op_read_reg(DSP_REG_AXL0 + sreg * 2, RCX, SIGN); dsp_op_read_reg(DSP_REG_AXL0 + sreg * 2, RCX, RegisterExtension::Sign);
// u16 val2 = (treg == 0) ? dsp_get_ax_l(1) : dsp_get_ax_h(1); // u16 val2 = (treg == 0) ? dsp_get_ax_l(1) : dsp_get_ax_h(1);
dsp_op_read_reg(DSP_REG_AXL1 + treg * 2, RAX, SIGN); dsp_op_read_reg(DSP_REG_AXL1 + treg * 2, RAX, RegisterExtension::Sign);
// s64 prod = dsp_multiply_add(val1, val2); // s64 prod = dsp_multiply_add(val1, val2);
multiply_add(); multiply_add();
// dsp_set_long_prod(prod); // dsp_set_long_prod(prod);
@ -688,9 +688,9 @@ void DSPEmitter::msubx(const UDSPInstruction opc)
u8 sreg = (opc >> 9) & 0x1; u8 sreg = (opc >> 9) & 0x1;
// u16 val1 = (sreg == 0) ? dsp_get_ax_l(0) : dsp_get_ax_h(0); // u16 val1 = (sreg == 0) ? dsp_get_ax_l(0) : dsp_get_ax_h(0);
dsp_op_read_reg(DSP_REG_AXL0 + sreg * 2, RCX, SIGN); dsp_op_read_reg(DSP_REG_AXL0 + sreg * 2, RCX, RegisterExtension::Sign);
// u16 val2 = (treg == 0) ? dsp_get_ax_l(1) : dsp_get_ax_h(1); // u16 val2 = (treg == 0) ? dsp_get_ax_l(1) : dsp_get_ax_h(1);
dsp_op_read_reg(DSP_REG_AXL1 + treg * 2, RAX, SIGN); dsp_op_read_reg(DSP_REG_AXL1 + treg * 2, RAX, RegisterExtension::Sign);
// s64 prod = dsp_multiply_sub(val1, val2); // s64 prod = dsp_multiply_sub(val1, val2);
multiply_sub(); multiply_sub();
// dsp_set_long_prod(prod); // dsp_set_long_prod(prod);
@ -710,7 +710,7 @@ void DSPEmitter::maddc(const UDSPInstruction opc)
// u16 accm = dsp_get_acc_m(sreg); // u16 accm = dsp_get_acc_m(sreg);
get_acc_m(sreg, ECX); get_acc_m(sreg, ECX);
// u16 axh = dsp_get_ax_h(treg); // u16 axh = dsp_get_ax_h(treg);
dsp_op_read_reg(DSP_REG_AXH0 + treg, RAX, SIGN); dsp_op_read_reg(DSP_REG_AXH0 + treg, RAX, RegisterExtension::Sign);
// s64 prod = dsp_multiply_add(accm, axh); // s64 prod = dsp_multiply_add(accm, axh);
multiply_add(); multiply_add();
// dsp_set_long_prod(prod); // dsp_set_long_prod(prod);
@ -730,7 +730,7 @@ void DSPEmitter::msubc(const UDSPInstruction opc)
// u16 accm = dsp_get_acc_m(sreg); // u16 accm = dsp_get_acc_m(sreg);
get_acc_m(sreg, ECX); get_acc_m(sreg, ECX);
// u16 axh = dsp_get_ax_h(treg); // u16 axh = dsp_get_ax_h(treg);
dsp_op_read_reg(DSP_REG_AXH0 + treg, RAX, SIGN); dsp_op_read_reg(DSP_REG_AXH0 + treg, RAX, RegisterExtension::Sign);
// s64 prod = dsp_multiply_sub(accm, axh); // s64 prod = dsp_multiply_sub(accm, axh);
multiply_sub(); multiply_sub();
// dsp_set_long_prod(prod); // dsp_set_long_prod(prod);
@ -747,9 +747,9 @@ void DSPEmitter::madd(const UDSPInstruction opc)
u8 sreg = (opc >> 8) & 0x1; u8 sreg = (opc >> 8) & 0x1;
// u16 axl = dsp_get_ax_l(sreg); // u16 axl = dsp_get_ax_l(sreg);
dsp_op_read_reg(DSP_REG_AXL0 + sreg, RCX, SIGN); dsp_op_read_reg(DSP_REG_AXL0 + sreg, RCX, RegisterExtension::Sign);
// u16 axh = dsp_get_ax_h(sreg); // u16 axh = dsp_get_ax_h(sreg);
dsp_op_read_reg(DSP_REG_AXH0 + sreg, RAX, SIGN); dsp_op_read_reg(DSP_REG_AXH0 + sreg, RAX, RegisterExtension::Sign);
// s64 prod = dsp_multiply_add(axl, axh); // s64 prod = dsp_multiply_add(axl, axh);
multiply_add(); multiply_add();
// dsp_set_long_prod(prod); // dsp_set_long_prod(prod);
@ -766,9 +766,9 @@ void DSPEmitter::msub(const UDSPInstruction opc)
u8 sreg = (opc >> 8) & 0x1; u8 sreg = (opc >> 8) & 0x1;
// u16 axl = dsp_get_ax_l(sreg); // u16 axl = dsp_get_ax_l(sreg);
dsp_op_read_reg(DSP_REG_AXL0 + sreg, RCX, SIGN); dsp_op_read_reg(DSP_REG_AXL0 + sreg, RCX, RegisterExtension::Sign);
// u16 axh = dsp_get_ax_h(sreg); // u16 axh = dsp_get_ax_h(sreg);
dsp_op_read_reg(DSP_REG_AXH0 + sreg, RAX, SIGN); dsp_op_read_reg(DSP_REG_AXH0 + sreg, RAX, RegisterExtension::Sign);
// s64 prod = dsp_multiply_sub(axl, axh); // s64 prod = dsp_multiply_sub(axl, axh);
multiply_sub(); multiply_sub();
// dsp_set_long_prod(prod); // dsp_set_long_prod(prod);

View File

@ -808,7 +808,7 @@ void DSPJitRegCache::PutReg(int reg, bool dirty)
} }
} }
void DSPJitRegCache::ReadReg(int sreg, X64Reg host_dreg, DSPJitSignExtend extend) void DSPJitRegCache::ReadReg(int sreg, X64Reg host_dreg, RegisterExtension extend)
{ {
const OpArg reg = GetReg(sreg); const OpArg reg = GetReg(sreg);
@ -817,13 +817,13 @@ void DSPJitRegCache::ReadReg(int sreg, X64Reg host_dreg, DSPJitSignExtend extend
case 2: case 2:
switch (extend) switch (extend)
{ {
case SIGN: case RegisterExtension::Sign:
m_emitter.MOVSX(64, 16, host_dreg, reg); m_emitter.MOVSX(64, 16, host_dreg, reg);
break; break;
case ZERO: case RegisterExtension::Zero:
m_emitter.MOVZX(64, 16, host_dreg, reg); m_emitter.MOVZX(64, 16, host_dreg, reg);
break; break;
case NONE: case RegisterExtension::None:
m_emitter.MOV(16, R(host_dreg), reg); m_emitter.MOV(16, R(host_dreg), reg);
break; break;
} }
@ -831,13 +831,13 @@ void DSPJitRegCache::ReadReg(int sreg, X64Reg host_dreg, DSPJitSignExtend extend
case 4: case 4:
switch (extend) switch (extend)
{ {
case SIGN: case RegisterExtension::Sign:
m_emitter.MOVSX(64, 32, host_dreg, reg); m_emitter.MOVSX(64, 32, host_dreg, reg);
break; break;
case ZERO: case RegisterExtension::Zero:
m_emitter.MOVZX(64, 32, host_dreg, reg); m_emitter.MOVZX(64, 32, host_dreg, reg);
break; break;
case NONE: case RegisterExtension::None:
m_emitter.MOV(32, R(host_dreg), reg); m_emitter.MOV(32, R(host_dreg), reg);
break; break;
} }

View File

@ -29,11 +29,11 @@ enum DSPJitRegSpecial
DSP_REG_NONE = 255 DSP_REG_NONE = 255
}; };
enum DSPJitSignExtend enum class RegisterExtension
{ {
SIGN, Sign,
ZERO, Zero,
NONE None
}; };
class DSPJitRegCache class DSPJitRegCache
@ -123,7 +123,7 @@ public:
// Done with all usages of OpArg above // Done with all usages of OpArg above
void PutReg(int reg, bool dirty = true); void PutReg(int reg, bool dirty = true);
void ReadReg(int sreg, Gen::X64Reg host_dreg, DSPJitSignExtend extend); void ReadReg(int sreg, Gen::X64Reg host_dreg, RegisterExtension extend);
void WriteReg(int dreg, Gen::OpArg arg); void WriteReg(int dreg, Gen::OpArg arg);
// Find a free host reg, spill if used, reserve // Find a free host reg, spill if used, reserve

View File

@ -194,7 +194,7 @@ void DSPEmitter::dsp_conditional_extend_accum_imm(int reg, u16 val)
} }
void DSPEmitter::dsp_op_read_reg_dont_saturate(int reg, Gen::X64Reg host_dreg, void DSPEmitter::dsp_op_read_reg_dont_saturate(int reg, Gen::X64Reg host_dreg,
DSPJitSignExtend extend) RegisterExtension extend)
{ {
switch (reg & 0x1f) switch (reg & 0x1f)
{ {
@ -205,13 +205,13 @@ void DSPEmitter::dsp_op_read_reg_dont_saturate(int reg, Gen::X64Reg host_dreg,
dsp_reg_load_stack(reg - DSP_REG_ST0, host_dreg); dsp_reg_load_stack(reg - DSP_REG_ST0, host_dreg);
switch (extend) switch (extend)
{ {
case SIGN: case RegisterExtension::Sign:
MOVSX(64, 16, host_dreg, R(host_dreg)); MOVSX(64, 16, host_dreg, R(host_dreg));
break; break;
case ZERO: case RegisterExtension::Zero:
MOVZX(64, 16, host_dreg, R(host_dreg)); MOVZX(64, 16, host_dreg, R(host_dreg));
break; break;
case NONE: case RegisterExtension::None:
default: default:
break; break;
} }
@ -222,7 +222,7 @@ void DSPEmitter::dsp_op_read_reg_dont_saturate(int reg, Gen::X64Reg host_dreg,
} }
} }
void DSPEmitter::dsp_op_read_reg(int reg, Gen::X64Reg host_dreg, DSPJitSignExtend extend) void DSPEmitter::dsp_op_read_reg(int reg, Gen::X64Reg host_dreg, RegisterExtension extend)
{ {
switch (reg & 0x1f) switch (reg & 0x1f)
{ {
@ -233,13 +233,13 @@ void DSPEmitter::dsp_op_read_reg(int reg, Gen::X64Reg host_dreg, DSPJitSignExten
dsp_reg_load_stack(reg - DSP_REG_ST0, host_dreg); dsp_reg_load_stack(reg - DSP_REG_ST0, host_dreg);
switch (extend) switch (extend)
{ {
case SIGN: case RegisterExtension::Sign:
MOVSX(64, 16, host_dreg, R(host_dreg)); MOVSX(64, 16, host_dreg, R(host_dreg));
break; break;
case ZERO: case RegisterExtension::Zero:
MOVZX(64, 16, host_dreg, R(host_dreg)); MOVZX(64, 16, host_dreg, R(host_dreg));
break; break;
case NONE: case RegisterExtension::None:
default: default:
break; break;
} }
@ -266,7 +266,7 @@ void DSPEmitter::dsp_op_read_reg(int reg, Gen::X64Reg host_dreg, DSPJitSignExten
FixupBranch done_positive = J(); FixupBranch done_positive = J();
SetJumpTarget(negative); SetJumpTarget(negative);
if (extend == NONE || extend == ZERO) if (extend == RegisterExtension::None || extend == RegisterExtension::Zero)
MOV(64, R(host_dreg), Imm32(0x00008000)); MOV(64, R(host_dreg), Imm32(0x00008000));
else else
MOV(64, R(host_dreg), Imm32(0xffff8000)); MOV(64, R(host_dreg), Imm32(0xffff8000));
@ -276,7 +276,7 @@ void DSPEmitter::dsp_op_read_reg(int reg, Gen::X64Reg host_dreg, DSPJitSignExten
SetJumpTarget(not_40bit); SetJumpTarget(not_40bit);
MOV(64, R(host_dreg), acc_reg); MOV(64, R(host_dreg), acc_reg);
if (extend == NONE || extend == ZERO) if (extend == RegisterExtension::None || extend == RegisterExtension::Zero)
SHR(64, R(host_dreg), Imm8(16)); SHR(64, R(host_dreg), Imm8(16));
else else
SAR(64, R(host_dreg), Imm8(16)); SAR(64, R(host_dreg), Imm8(16));
@ -744,7 +744,7 @@ void DSPEmitter::set_long_acc(int _reg, X64Reg acc)
void DSPEmitter::get_acc_l(int _reg, X64Reg acl, bool sign) void DSPEmitter::get_acc_l(int _reg, X64Reg acl, bool sign)
{ {
// return g_dsp.r[DSP_REG_ACM0 + _reg]; // return g_dsp.r[DSP_REG_ACM0 + _reg];
m_gpr.ReadReg(_reg + DSP_REG_ACL0, acl, sign ? SIGN : ZERO); m_gpr.ReadReg(_reg + DSP_REG_ACL0, acl, sign ? RegisterExtension::Sign : RegisterExtension::Zero);
} }
void DSPEmitter::set_acc_l(int _reg, const OpArg& arg) void DSPEmitter::set_acc_l(int _reg, const OpArg& arg)
@ -757,7 +757,7 @@ void DSPEmitter::set_acc_l(int _reg, const OpArg& arg)
void DSPEmitter::get_acc_m(int _reg, X64Reg acm, bool sign) void DSPEmitter::get_acc_m(int _reg, X64Reg acm, bool sign)
{ {
// return g_dsp.r[DSP_REG_ACM0 + _reg]; // return g_dsp.r[DSP_REG_ACM0 + _reg];
m_gpr.ReadReg(_reg + DSP_REG_ACM0, acm, sign ? SIGN : ZERO); m_gpr.ReadReg(_reg + DSP_REG_ACM0, acm, sign ? RegisterExtension::Sign : RegisterExtension::Zero);
} }
// In: s16 in AX // In: s16 in AX
@ -771,7 +771,7 @@ void DSPEmitter::set_acc_m(int _reg, const OpArg& arg)
void DSPEmitter::get_acc_h(int _reg, X64Reg ach, bool sign) void DSPEmitter::get_acc_h(int _reg, X64Reg ach, bool sign)
{ {
// return g_dsp.r.ac[_reg].h; // return g_dsp.r.ac[_reg].h;
m_gpr.ReadReg(_reg + DSP_REG_ACH0, ach, sign ? SIGN : ZERO); m_gpr.ReadReg(_reg + DSP_REG_ACH0, ach, sign ? RegisterExtension::Sign : RegisterExtension::Zero);
} }
// In: s16 in AX // In: s16 in AX
@ -785,21 +785,21 @@ void DSPEmitter::set_acc_h(int _reg, const OpArg& arg)
void DSPEmitter::get_long_acx(int _reg, X64Reg acx) void DSPEmitter::get_long_acx(int _reg, X64Reg acx)
{ {
// return ((u32)g_dsp.r[DSP_REG_AXH0 + _reg] << 16) | g_dsp.r[DSP_REG_AXL0 + _reg]; // return ((u32)g_dsp.r[DSP_REG_AXH0 + _reg] << 16) | g_dsp.r[DSP_REG_AXL0 + _reg];
m_gpr.ReadReg(_reg + DSP_REG_AX0_32, acx, SIGN); m_gpr.ReadReg(_reg + DSP_REG_AX0_32, acx, RegisterExtension::Sign);
} }
// Returns s16 in EAX // Returns s16 in EAX
void DSPEmitter::get_ax_l(int _reg, X64Reg axl) void DSPEmitter::get_ax_l(int _reg, X64Reg axl)
{ {
// return (s16)g_dsp.r[DSP_REG_AXL0 + _reg]; // return (s16)g_dsp.r[DSP_REG_AXL0 + _reg];
m_gpr.ReadReg(_reg + DSP_REG_AXL0, axl, SIGN); m_gpr.ReadReg(_reg + DSP_REG_AXL0, axl, RegisterExtension::Sign);
} }
// Returns s16 in EAX // Returns s16 in EAX
void DSPEmitter::get_ax_h(int _reg, X64Reg axh) void DSPEmitter::get_ax_h(int _reg, X64Reg axh)
{ {
// return (s16)g_dsp.r[DSP_REG_AXH0 + _reg]; // return (s16)g_dsp.r[DSP_REG_AXH0 + _reg];
m_gpr.ReadReg(_reg + DSP_REG_AXH0, axh, SIGN); m_gpr.ReadReg(_reg + DSP_REG_AXH0, axh, RegisterExtension::Sign);
} }
} // namespace x86 } // namespace x86