Core: Handle CPO1 unimplemented op
This commit is contained in:
parent
85f4f147a1
commit
2c19c2c362
|
@ -395,11 +395,11 @@ R4300iOp::Func * R4300iOp::BuildInterpreter()
|
||||||
Jump_CoP1[0] = COP1_MF;
|
Jump_CoP1[0] = COP1_MF;
|
||||||
Jump_CoP1[1] = COP1_DMF;
|
Jump_CoP1[1] = COP1_DMF;
|
||||||
Jump_CoP1[2] = COP1_CF;
|
Jump_CoP1[2] = COP1_CF;
|
||||||
Jump_CoP1[3] = UnknownOpcode;
|
Jump_CoP1[3] = CPO1_UNIMPLEMENTED_OP;
|
||||||
Jump_CoP1[4] = COP1_MT;
|
Jump_CoP1[4] = COP1_MT;
|
||||||
Jump_CoP1[5] = COP1_DMT;
|
Jump_CoP1[5] = COP1_DMT;
|
||||||
Jump_CoP1[6] = COP1_CT;
|
Jump_CoP1[6] = COP1_CT;
|
||||||
Jump_CoP1[7] = UnknownOpcode;
|
Jump_CoP1[7] = CPO1_UNIMPLEMENTED_OP;
|
||||||
Jump_CoP1[8] = COP1_BC;
|
Jump_CoP1[8] = COP1_BC;
|
||||||
Jump_CoP1[9] = UnknownOpcode;
|
Jump_CoP1[9] = UnknownOpcode;
|
||||||
Jump_CoP1[10] = UnknownOpcode;
|
Jump_CoP1[10] = UnknownOpcode;
|
||||||
|
@ -490,7 +490,7 @@ R4300iOp::Func * R4300iOp::BuildInterpreter()
|
||||||
Jump_CoP1_S[29] = UnknownOpcode;
|
Jump_CoP1_S[29] = UnknownOpcode;
|
||||||
Jump_CoP1_S[30] = UnknownOpcode;
|
Jump_CoP1_S[30] = UnknownOpcode;
|
||||||
Jump_CoP1_S[31] = UnknownOpcode;
|
Jump_CoP1_S[31] = UnknownOpcode;
|
||||||
Jump_CoP1_S[32] = COP1_S_CVT_S;
|
Jump_CoP1_S[32] = CPO1_UNIMPLEMENTED_OP;
|
||||||
Jump_CoP1_S[33] = COP1_S_CVT_D;
|
Jump_CoP1_S[33] = COP1_S_CVT_D;
|
||||||
Jump_CoP1_S[34] = UnknownOpcode;
|
Jump_CoP1_S[34] = UnknownOpcode;
|
||||||
Jump_CoP1_S[35] = UnknownOpcode;
|
Jump_CoP1_S[35] = UnknownOpcode;
|
||||||
|
@ -556,7 +556,7 @@ R4300iOp::Func * R4300iOp::BuildInterpreter()
|
||||||
Jump_CoP1_D[30] = UnknownOpcode;
|
Jump_CoP1_D[30] = UnknownOpcode;
|
||||||
Jump_CoP1_D[31] = UnknownOpcode;
|
Jump_CoP1_D[31] = UnknownOpcode;
|
||||||
Jump_CoP1_D[32] = COP1_D_CVT_S;
|
Jump_CoP1_D[32] = COP1_D_CVT_S;
|
||||||
Jump_CoP1_D[33] = COP1_D_CVT_D;
|
Jump_CoP1_D[33] = CPO1_UNIMPLEMENTED_OP;
|
||||||
Jump_CoP1_D[34] = UnknownOpcode;
|
Jump_CoP1_D[34] = UnknownOpcode;
|
||||||
Jump_CoP1_D[35] = UnknownOpcode;
|
Jump_CoP1_D[35] = UnknownOpcode;
|
||||||
Jump_CoP1_D[36] = COP1_D_CVT_W;
|
Jump_CoP1_D[36] = COP1_D_CVT_W;
|
||||||
|
@ -600,10 +600,10 @@ R4300iOp::Func * R4300iOp::BuildInterpreter()
|
||||||
Jump_CoP1_W[9] = UnknownOpcode;
|
Jump_CoP1_W[9] = UnknownOpcode;
|
||||||
Jump_CoP1_W[10] = UnknownOpcode;
|
Jump_CoP1_W[10] = UnknownOpcode;
|
||||||
Jump_CoP1_W[11] = UnknownOpcode;
|
Jump_CoP1_W[11] = UnknownOpcode;
|
||||||
Jump_CoP1_W[12] = UnknownOpcode;
|
Jump_CoP1_W[12] = CPO1_UNIMPLEMENTED_OP;
|
||||||
Jump_CoP1_W[13] = UnknownOpcode;
|
Jump_CoP1_W[13] = CPO1_UNIMPLEMENTED_OP;
|
||||||
Jump_CoP1_W[14] = UnknownOpcode;
|
Jump_CoP1_W[14] = CPO1_UNIMPLEMENTED_OP;
|
||||||
Jump_CoP1_W[15] = UnknownOpcode;
|
Jump_CoP1_W[15] = CPO1_UNIMPLEMENTED_OP;
|
||||||
Jump_CoP1_W[16] = UnknownOpcode;
|
Jump_CoP1_W[16] = UnknownOpcode;
|
||||||
Jump_CoP1_W[17] = UnknownOpcode;
|
Jump_CoP1_W[17] = UnknownOpcode;
|
||||||
Jump_CoP1_W[18] = UnknownOpcode;
|
Jump_CoP1_W[18] = UnknownOpcode;
|
||||||
|
@ -624,7 +624,7 @@ R4300iOp::Func * R4300iOp::BuildInterpreter()
|
||||||
Jump_CoP1_W[33] = COP1_W_CVT_D;
|
Jump_CoP1_W[33] = COP1_W_CVT_D;
|
||||||
Jump_CoP1_W[34] = UnknownOpcode;
|
Jump_CoP1_W[34] = UnknownOpcode;
|
||||||
Jump_CoP1_W[35] = UnknownOpcode;
|
Jump_CoP1_W[35] = UnknownOpcode;
|
||||||
Jump_CoP1_W[36] = COP1_W_CVT_W;
|
Jump_CoP1_W[36] = CPO1_UNIMPLEMENTED_OP;
|
||||||
Jump_CoP1_W[37] = UnknownOpcode;
|
Jump_CoP1_W[37] = UnknownOpcode;
|
||||||
Jump_CoP1_W[38] = UnknownOpcode;
|
Jump_CoP1_W[38] = UnknownOpcode;
|
||||||
Jump_CoP1_W[39] = UnknownOpcode;
|
Jump_CoP1_W[39] = UnknownOpcode;
|
||||||
|
@ -661,14 +661,14 @@ R4300iOp::Func * R4300iOp::BuildInterpreter()
|
||||||
Jump_CoP1_L[5] = UnknownOpcode;
|
Jump_CoP1_L[5] = UnknownOpcode;
|
||||||
Jump_CoP1_L[6] = UnknownOpcode;
|
Jump_CoP1_L[6] = UnknownOpcode;
|
||||||
Jump_CoP1_L[7] = UnknownOpcode;
|
Jump_CoP1_L[7] = UnknownOpcode;
|
||||||
Jump_CoP1_L[8] = UnknownOpcode;
|
Jump_CoP1_L[8] = CPO1_UNIMPLEMENTED_OP;
|
||||||
Jump_CoP1_L[9] = UnknownOpcode;
|
Jump_CoP1_L[9] = CPO1_UNIMPLEMENTED_OP;
|
||||||
Jump_CoP1_L[10] = UnknownOpcode;
|
Jump_CoP1_L[10] = CPO1_UNIMPLEMENTED_OP;
|
||||||
Jump_CoP1_L[11] = UnknownOpcode;
|
Jump_CoP1_L[11] = CPO1_UNIMPLEMENTED_OP;
|
||||||
Jump_CoP1_L[12] = UnknownOpcode;
|
Jump_CoP1_L[12] = CPO1_UNIMPLEMENTED_OP;
|
||||||
Jump_CoP1_L[13] = UnknownOpcode;
|
Jump_CoP1_L[13] = CPO1_UNIMPLEMENTED_OP;
|
||||||
Jump_CoP1_L[14] = UnknownOpcode;
|
Jump_CoP1_L[14] = CPO1_UNIMPLEMENTED_OP;
|
||||||
Jump_CoP1_L[15] = UnknownOpcode;
|
Jump_CoP1_L[15] = CPO1_UNIMPLEMENTED_OP;
|
||||||
Jump_CoP1_L[16] = UnknownOpcode;
|
Jump_CoP1_L[16] = UnknownOpcode;
|
||||||
Jump_CoP1_L[17] = UnknownOpcode;
|
Jump_CoP1_L[17] = UnknownOpcode;
|
||||||
Jump_CoP1_L[18] = UnknownOpcode;
|
Jump_CoP1_L[18] = UnknownOpcode;
|
||||||
|
@ -689,8 +689,8 @@ R4300iOp::Func * R4300iOp::BuildInterpreter()
|
||||||
Jump_CoP1_L[33] = COP1_L_CVT_D;
|
Jump_CoP1_L[33] = COP1_L_CVT_D;
|
||||||
Jump_CoP1_L[34] = UnknownOpcode;
|
Jump_CoP1_L[34] = UnknownOpcode;
|
||||||
Jump_CoP1_L[35] = UnknownOpcode;
|
Jump_CoP1_L[35] = UnknownOpcode;
|
||||||
Jump_CoP1_L[36] = UnknownOpcode;
|
Jump_CoP1_L[36] = CPO1_UNIMPLEMENTED_OP;
|
||||||
Jump_CoP1_L[37] = UnknownOpcode;
|
Jump_CoP1_L[37] = CPO1_UNIMPLEMENTED_OP;
|
||||||
Jump_CoP1_L[38] = UnknownOpcode;
|
Jump_CoP1_L[38] = UnknownOpcode;
|
||||||
Jump_CoP1_L[39] = UnknownOpcode;
|
Jump_CoP1_L[39] = UnknownOpcode;
|
||||||
Jump_CoP1_L[40] = UnknownOpcode;
|
Jump_CoP1_L[40] = UnknownOpcode;
|
||||||
|
@ -1886,6 +1886,18 @@ void R4300iOp::COP0_CO_ERET()
|
||||||
}
|
}
|
||||||
|
|
||||||
// COP1 functions
|
// COP1 functions
|
||||||
|
void R4300iOp::CPO1_UNIMPLEMENTED_OP()
|
||||||
|
{
|
||||||
|
if (TestCop1UsableException())
|
||||||
|
{
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
FPStatusReg & StatusReg = (FPStatusReg &)_FPCR[31];
|
||||||
|
StatusReg.Cause.UnimplementedOperation = 1;
|
||||||
|
g_Reg->DoFloatingPointException(g_System->m_PipelineStage == PIPELINE_STAGE_JUMP);
|
||||||
|
g_System->m_PipelineStage = PIPELINE_STAGE_JUMP;
|
||||||
|
g_System->m_JumpToLocation = (*_PROGRAM_COUNTER);
|
||||||
|
}
|
||||||
|
|
||||||
void R4300iOp::COP1_MF()
|
void R4300iOp::COP1_MF()
|
||||||
{
|
{
|
||||||
|
@ -2341,19 +2353,6 @@ void R4300iOp::COP1_S_FLOOR_W()
|
||||||
*(uint32_t *)_FPR_S[m_Opcode.fd] = *(uint32_t *)&Result;
|
*(uint32_t *)_FPR_S[m_Opcode.fd] = *(uint32_t *)&Result;
|
||||||
}
|
}
|
||||||
|
|
||||||
void R4300iOp::COP1_S_CVT_S()
|
|
||||||
{
|
|
||||||
if (TestCop1UsableException())
|
|
||||||
{
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
FPStatusReg & StatusReg = (FPStatusReg &)_FPCR[31];
|
|
||||||
StatusReg.Cause.UnimplementedOperation = 1;
|
|
||||||
g_Reg->DoFloatingPointException(g_System->m_PipelineStage == PIPELINE_STAGE_JUMP);
|
|
||||||
g_System->m_PipelineStage = PIPELINE_STAGE_JUMP;
|
|
||||||
g_System->m_JumpToLocation = (*_PROGRAM_COUNTER);
|
|
||||||
}
|
|
||||||
|
|
||||||
void R4300iOp::COP1_S_CVT_D()
|
void R4300iOp::COP1_S_CVT_D()
|
||||||
{
|
{
|
||||||
if (TestCop1UsableException())
|
if (TestCop1UsableException())
|
||||||
|
@ -2820,19 +2819,6 @@ void R4300iOp::COP1_D_CVT_S()
|
||||||
*(uint32_t *)_FPR_S[m_Opcode.fd] = *(uint32_t *)&Result;
|
*(uint32_t *)_FPR_S[m_Opcode.fd] = *(uint32_t *)&Result;
|
||||||
}
|
}
|
||||||
|
|
||||||
void R4300iOp::COP1_D_CVT_D()
|
|
||||||
{
|
|
||||||
if (TestCop1UsableException())
|
|
||||||
{
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
FPStatusReg & StatusReg = (FPStatusReg &)_FPCR[31];
|
|
||||||
StatusReg.Cause.UnimplementedOperation = 1;
|
|
||||||
g_Reg->DoFloatingPointException(g_System->m_PipelineStage == PIPELINE_STAGE_JUMP);
|
|
||||||
g_System->m_PipelineStage = PIPELINE_STAGE_JUMP;
|
|
||||||
g_System->m_JumpToLocation = (*_PROGRAM_COUNTER);
|
|
||||||
}
|
|
||||||
|
|
||||||
void R4300iOp::COP1_D_CVT_W()
|
void R4300iOp::COP1_D_CVT_W()
|
||||||
{
|
{
|
||||||
if (TestCop1UsableException())
|
if (TestCop1UsableException())
|
||||||
|
@ -2920,7 +2906,6 @@ void R4300iOp::COP1_D_CMP()
|
||||||
}
|
}
|
||||||
|
|
||||||
// COP1: W functions
|
// COP1: W functions
|
||||||
|
|
||||||
void R4300iOp::COP1_W_CVT_S()
|
void R4300iOp::COP1_W_CVT_S()
|
||||||
{
|
{
|
||||||
if (TestCop1UsableException())
|
if (TestCop1UsableException())
|
||||||
|
@ -2955,19 +2940,6 @@ void R4300iOp::COP1_W_CVT_D()
|
||||||
*(uint64_t *)_FPR_D[m_Opcode.fd] = *(uint64_t *)&Result;
|
*(uint64_t *)_FPR_D[m_Opcode.fd] = *(uint64_t *)&Result;
|
||||||
}
|
}
|
||||||
|
|
||||||
void R4300iOp::COP1_W_CVT_W()
|
|
||||||
{
|
|
||||||
if (TestCop1UsableException())
|
|
||||||
{
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
FPStatusReg & StatusReg = (FPStatusReg &)_FPCR[31];
|
|
||||||
StatusReg.Cause.UnimplementedOperation = 1;
|
|
||||||
g_Reg->DoFloatingPointException(g_System->m_PipelineStage == PIPELINE_STAGE_JUMP);
|
|
||||||
g_System->m_PipelineStage = PIPELINE_STAGE_JUMP;
|
|
||||||
g_System->m_JumpToLocation = (*_PROGRAM_COUNTER);
|
|
||||||
}
|
|
||||||
|
|
||||||
// COP1: L functions
|
// COP1: L functions
|
||||||
|
|
||||||
void R4300iOp::COP1_L_CVT_S()
|
void R4300iOp::COP1_L_CVT_S()
|
||||||
|
|
|
@ -147,6 +147,7 @@ public:
|
||||||
static void COP0_CO_ERET();
|
static void COP0_CO_ERET();
|
||||||
|
|
||||||
// COP1 functions
|
// COP1 functions
|
||||||
|
static void CPO1_UNIMPLEMENTED_OP(void);
|
||||||
static void COP1_MF();
|
static void COP1_MF();
|
||||||
static void COP1_DMF();
|
static void COP1_DMF();
|
||||||
static void COP1_CF();
|
static void COP1_CF();
|
||||||
|
@ -177,7 +178,6 @@ public:
|
||||||
static void COP1_S_TRUNC_W();
|
static void COP1_S_TRUNC_W();
|
||||||
static void COP1_S_CEIL_W();
|
static void COP1_S_CEIL_W();
|
||||||
static void COP1_S_FLOOR_W();
|
static void COP1_S_FLOOR_W();
|
||||||
static void COP1_S_CVT_S();
|
|
||||||
static void COP1_S_CVT_D();
|
static void COP1_S_CVT_D();
|
||||||
static void COP1_S_CVT_W();
|
static void COP1_S_CVT_W();
|
||||||
static void COP1_S_CVT_L();
|
static void COP1_S_CVT_L();
|
||||||
|
@ -201,7 +201,6 @@ public:
|
||||||
static void COP1_D_CEIL_W();
|
static void COP1_D_CEIL_W();
|
||||||
static void COP1_D_FLOOR_W();
|
static void COP1_D_FLOOR_W();
|
||||||
static void COP1_D_CVT_S();
|
static void COP1_D_CVT_S();
|
||||||
static void COP1_D_CVT_D();
|
|
||||||
static void COP1_D_CVT_W();
|
static void COP1_D_CVT_W();
|
||||||
static void COP1_D_CVT_L();
|
static void COP1_D_CVT_L();
|
||||||
static void COP1_D_CMP();
|
static void COP1_D_CMP();
|
||||||
|
@ -209,7 +208,6 @@ public:
|
||||||
// COP1: W functions
|
// COP1: W functions
|
||||||
static void COP1_W_CVT_S();
|
static void COP1_W_CVT_S();
|
||||||
static void COP1_W_CVT_D();
|
static void COP1_W_CVT_D();
|
||||||
static void COP1_W_CVT_W();
|
|
||||||
|
|
||||||
// COP1: L functions
|
// COP1: L functions
|
||||||
static void COP1_L_CVT_S();
|
static void COP1_L_CVT_S();
|
||||||
|
|
Loading…
Reference in New Issue