void Interpreter::psq_lux(UGeckoInstruction _inst) { const UGQR gqr(rSPR(SPR_GQR0 + _inst.Ix)); const EQuantizeType ldType = static_cast<EQuantizeType>(gqr.LD_TYPE); const unsigned int ldScale = gqr.LD_SCALE; const u32 EA = m_GPR[_inst.RA] + m_GPR[_inst.RB]; int c = 4; if ((ldType == 4) || (ldType == 6)) c = 0x1; if ((ldType == 5) || (ldType == 7)) c = 0x2; if (_inst.Wx == 0) { float ps0 = Helper_Dequantize( EA, ldType, ldScale ); float ps1 = Helper_Dequantize( EA+c, ldType, ldScale ); if (PowerPC::ppcState.Exceptions & EXCEPTION_DSI) { return; } rPS0(_inst.RS) = ps0; rPS1(_inst.RS) = ps1; } else { float ps0 = Helper_Dequantize( EA, ldType, ldScale ); if (PowerPC::ppcState.Exceptions & EXCEPTION_DSI) { return; } rPS0(_inst.RS) = ps0; rPS1(_inst.RS) = 1.0f; } m_GPR[_inst.RA] = EA; }
void Interpreter::psq_l(UGeckoInstruction _inst) { const UGQR gqr(rSPR(SPR_GQR0 + _inst.I)); const EQuantizeType ldType = static_cast<EQuantizeType>(gqr.LD_TYPE); const unsigned int ldScale = gqr.LD_SCALE; const u32 EA = _inst.RA ? (m_GPR[_inst.RA] + _inst.SIMM_12) : (u32)_inst.SIMM_12; int c = 4; if ((ldType == QUANTIZE_U8) || (ldType == QUANTIZE_S8)) c = 0x1; if ((ldType == QUANTIZE_U16) || (ldType == QUANTIZE_S16)) c = 0x2; if (_inst.W == 0) { float ps0 = Helper_Dequantize(EA, ldType, ldScale); float ps1 = Helper_Dequantize(EA+c, ldType, ldScale); if (PowerPC::ppcState.Exceptions & EXCEPTION_DSI) { return; } rPS0(_inst.RS) = ps0; rPS1(_inst.RS) = ps1; } else { float ps0 = Helper_Dequantize(EA, ldType, ldScale); if (PowerPC::ppcState.Exceptions & EXCEPTION_DSI) { return; } rPS0(_inst.RS) = ps0; rPS1(_inst.RS) = 1.0f; } }
// Internal square root function in the crazy math lib. Acts a bit odd, just read it. It's not a bug :p void FZ_sqrt_internal() { double f = sqrt(rPS0(1)); rPS0(0) = rPS0(1); rPS1(0) = rPS0(1); rPS0(1) = f; rPS1(1) = f; NPC = LR; }
void Interpreter::psq_stux(UGeckoInstruction _inst) { const UGQR gqr(rSPR(SPR_GQR0 + _inst.Ix)); const EQuantizeType stType = static_cast<EQuantizeType>(gqr.ST_TYPE); const unsigned int stScale = gqr.ST_SCALE; const u32 EA = m_GPR[_inst.RA] + m_GPR[_inst.RB]; int c = 4; if (stType == QUANTIZE_U8 || stType == QUANTIZE_S8) c = 0x1; else if (stType == QUANTIZE_U16 || stType == QUANTIZE_S16) c = 0x2; if (_inst.Wx == 0) { Helper_Quantize(EA, rPS0(_inst.RS), stType, stScale); Helper_Quantize(EA + c, rPS1(_inst.RS), stType, stScale); } else { Helper_Quantize(EA, rPS0(_inst.RS), stType, stScale); } if (PowerPC::ppcState.Exceptions & EXCEPTION_DSI) { return; } m_GPR[_inst.RA] = EA; } // namespace=======
// Internal inverse square root function in the crazy math lib. void FZ_rsqrt_internal() { double f = 1.0 / sqrt(rPS0(1)); rPS0(1) = f; rPS1(1) = f; NPC = LR; }
void Interpreter::psq_stu(UGeckoInstruction _inst) { const UGQR gqr(rSPR(SPR_GQR0 + _inst.I)); const EQuantizeType stType = static_cast<EQuantizeType>(gqr.ST_TYPE); const unsigned int stScale = gqr.ST_SCALE; const u32 EA = m_GPR[_inst.RA] + _inst.SIMM_12; int c = 4; if ((stType == 4) || (stType == 6)) c = 0x1; if ((stType == 5) || (stType == 7)) c = 0x2; if (_inst.W == 0) { Helper_Quantize(EA, rPS0(_inst.RS), stType, stScale); Helper_Quantize(EA+c, rPS1(_inst.RS), stType, stScale); } else { Helper_Quantize(EA, rPS0(_inst.RS), stType, stScale); } if (PowerPC::ppcState.Exceptions & EXCEPTION_DSI) { return; } m_GPR[_inst.RA] = EA; }
void FZero_evil_vec_normalize() { u32 r3 = GPR(3); float x = F(r3); float y = F(r3 + 4); float z = F(r3 + 8); float sq_len = x*x + y*y + z*z; float inv_len = 1.0f / sqrtf(sq_len); x *= inv_len; y *= inv_len; z *= inv_len; FW(r3, x); FW(r3 + 4, y); FW(r3 + 8, z); rPS0(1) = inv_len * sq_len; // len rPS1(1) = inv_len * sq_len; // len NPC = LR; /* .evil_vec_something (f6, f7, f8) <- [r3] f1 = f6 * f6 f1 += f7 * f7 f1 += f8 * f8 f2 = mystery f4 = f2 * f1 f3 = f2 + f2 f1 = 1/f0 f6 *= f1 f7 *= f1 f8 *= f1 8006d668: lis r5, 0xE000 8006d684: lfs f2, 0x01A0 (r5) 8006d69c: fmr f0,f2 8006d6a0: fmuls f4,f2,f1 8006d6a4: fadds f3,f2,f2 8006d6a8: frsqrte f1,f0,f1 8006d6ac: fadds f3,f3,f2 8006d6b0: fmuls f5,f1,f1 8006d6b4: fnmsubs f5,f5,f4,f3 8006d6b8: fmuls f1,f1,f5 8006d6bc: fmuls f5,f1,f1 8006d6c0: fnmsubs f5,f5,f4,f3 8006d6c4: fmuls f1,f1,f5 8006d6c8: fmuls f6,f6,f1 8006d6cc: stfs f6, 0 (r3) 8006d6d0: fmuls f7,f7,f1 8006d6d4: stfs f7, 0x0004 (r3) 8006d6d8: fmuls f8,f8,f1 8006d6dc: stfs f8, 0x0008 (r3) 8006d6e0: fmuls f1,f1,f0 8006d6e4: blr */ NPC = LR; }
void Interpreter::lfsx(UGeckoInstruction _inst) { u32 uTemp = Memory::Read_U32(Helper_Get_EA_X(_inst)); if (!(PowerPC::ppcState.Exceptions & EXCEPTION_DSI)) { double value = *(float*)&uTemp; rPS0(_inst.FD) = value; rPS1(_inst.FD) = value; } }
wxString CRegTable::FormatFPR(int reg_index, int reg_part) { if (m_formatFRegs[reg_index][reg_part] == FormatSpecifier::Double) { double reg = (reg_part == 0) ? rPS0(reg_index) : rPS1(reg_index); return wxString::Format(GetFormatString(m_formatFRegs[reg_index][reg_part]), reg); } u64 reg = (reg_part == 0) ? riPS0(reg_index) : riPS1(reg_index); return wxString::Format(GetFormatString(m_formatFRegs[reg_index][reg_part]), reg); }
void Interpreter::lfsux(UGeckoInstruction _inst) { u32 uAddress = Helper_Get_EA_UX(_inst); u32 uTemp = Memory::Read_U32(uAddress); if (!(PowerPC::ppcState.Exceptions & EXCEPTION_DSI)) { double value = *(float*)&uTemp; rPS0(_inst.FD) = value; rPS1(_inst.FD) = value; m_GPR[_inst.RA] = uAddress; } }
void Interpreter::psq_stx(UGeckoInstruction _inst) { const UGQR gqr(rSPR(SPR_GQR0 + _inst.Ix)); const EQuantizeType stType = static_cast<EQuantizeType>(gqr.ST_TYPE); const unsigned int stScale = gqr.ST_SCALE; const u32 EA = _inst.RA ? (m_GPR[_inst.RA] + m_GPR[_inst.RB]) : m_GPR[_inst.RB]; int c = 4; if ((stType == 4) || (stType == 6)) c = 0x1; if ((stType == 5) || (stType == 7)) c = 0x2; if (_inst.Wx == 0) { Helper_Quantize(EA, rPS0(_inst.RS), stType, stScale); Helper_Quantize(EA+c, rPS1(_inst.RS), stType, stScale); } else { Helper_Quantize(EA, rPS0(_inst.RS), stType, stScale); } }
void Interpreter::psq_st(UGeckoInstruction _inst) { const UGQR gqr(rSPR(SPR_GQR0 + _inst.I)); const EQuantizeType stType = static_cast<EQuantizeType>(gqr.ST_TYPE); const unsigned int stScale = gqr.ST_SCALE; const u32 EA = _inst.RA ? (m_GPR[_inst.RA] + _inst.SIMM_12) : (u32)_inst.SIMM_12; int c = 4; if (stType == QUANTIZE_U8 || stType == QUANTIZE_S8) c = 0x1; else if (stType == QUANTIZE_U16 || stType == QUANTIZE_S16) c = 0x2; if (_inst.W == 0) { Helper_Quantize(EA, rPS0(_inst.RS), stType, stScale); Helper_Quantize(EA + c, rPS1(_inst.RS), stType, stScale); } else { Helper_Quantize(EA, rPS0(_inst.RS), stType, stScale); } }