mirror of
https://github.com/jpd002/Play-.git
synced 2025-04-29 06:07:56 +03:00
436 lines
9 KiB
C++
436 lines
9 KiB
C++
#include "MA_VU.h"
|
|
#include "MIPS.h"
|
|
#include "VUShared.h"
|
|
#include "VIF.h"
|
|
#include "CodeGen.h"
|
|
|
|
using namespace std;
|
|
|
|
uint8 CMA_VU::CUpper::m_nFT;
|
|
uint8 CMA_VU::CUpper::m_nFS;
|
|
uint8 CMA_VU::CUpper::m_nFD;
|
|
uint8 CMA_VU::CUpper::m_nBc;
|
|
uint8 CMA_VU::CUpper::m_nDest;
|
|
|
|
void CMA_VU::CUpper::CompileInstruction(uint32 nAddress, CCodeGen* codeGen, CMIPS* pCtx, bool nParent)
|
|
{
|
|
m_nDest = (uint8 )((m_nOpcode >> 21) & 0x000F);
|
|
m_nFT = (uint8 )((m_nOpcode >> 16) & 0x001F);
|
|
m_nFS = (uint8 )((m_nOpcode >> 11) & 0x001F);
|
|
m_nFD = (uint8 )((m_nOpcode >> 6) & 0x001F);
|
|
|
|
m_nBc = (uint8 )((m_nOpcode >> 0) & 0x0003);
|
|
|
|
m_pOpVector[m_nOpcode & 0x3F]();
|
|
|
|
if(m_nOpcode & 0x80000000)
|
|
{
|
|
LOI(pCtx->m_pMemoryMap->GetInstruction(nAddress - 4));
|
|
}
|
|
|
|
if(m_nOpcode & 0x40000000)
|
|
{
|
|
//Force exception checking if microprogram is done
|
|
m_codeGen->PushCst(1);
|
|
m_codeGen->PullRel(offsetof(CMIPS, m_State.nHasException));
|
|
}
|
|
}
|
|
|
|
void CMA_VU::CUpper::LOI(uint32 nValue)
|
|
{
|
|
m_codeGen->PushCst(nValue);
|
|
m_codeGen->PullRel(offsetof(CMIPS, m_State.nCOP2I));
|
|
}
|
|
|
|
//////////////////////////////////////////////////
|
|
//Vector Instructions
|
|
//////////////////////////////////////////////////
|
|
|
|
//00
|
|
//01
|
|
//02
|
|
//03
|
|
void CMA_VU::CUpper::ADDbc()
|
|
{
|
|
VUShared::ADDbc(m_codeGen, m_nDest, m_nFD, m_nFS, m_nFT, m_nBc);
|
|
}
|
|
|
|
//04
|
|
//05
|
|
//06
|
|
//07
|
|
void CMA_VU::CUpper::SUBbc()
|
|
{
|
|
VUShared::SUBbc(m_codeGen, m_nDest, m_nFD, m_nFS, m_nFT, m_nBc);
|
|
}
|
|
|
|
//08
|
|
//09
|
|
//0A
|
|
//0B
|
|
void CMA_VU::CUpper::MADDbc()
|
|
{
|
|
VUShared::MADDbc(m_codeGen, m_nDest, m_nFD, m_nFS, m_nFT, m_nBc);
|
|
}
|
|
|
|
//0C
|
|
//0D
|
|
//0E
|
|
//0F
|
|
void CMA_VU::CUpper::MSUBbc()
|
|
{
|
|
VUShared::MSUBbc(m_codeGen, m_nDest, m_nFD, m_nFS, m_nFT, m_nBc);
|
|
}
|
|
|
|
//10
|
|
//11
|
|
//12
|
|
//13
|
|
void CMA_VU::CUpper::MAXbc()
|
|
{
|
|
VUShared::MAXbc(m_codeGen, m_nDest, m_nFD, m_nFS, m_nFT, m_nBc);
|
|
}
|
|
|
|
//14
|
|
//15
|
|
//16
|
|
//17
|
|
void CMA_VU::CUpper::MINIbc()
|
|
{
|
|
VUShared::MINIbc(m_codeGen, m_nDest, m_nFD, m_nFS, m_nFT, m_nBc);
|
|
}
|
|
|
|
//18
|
|
//19
|
|
//1A
|
|
//1B
|
|
void CMA_VU::CUpper::MULbc()
|
|
{
|
|
VUShared::MULbc(m_codeGen, m_nDest, m_nFD, m_nFS, m_nFT, m_nBc);
|
|
}
|
|
|
|
//1C
|
|
void CMA_VU::CUpper::MULq()
|
|
{
|
|
VUShared::MULq(m_codeGen, m_nDest, m_nFD, m_nFS, m_nAddress);
|
|
}
|
|
|
|
//1E
|
|
void CMA_VU::CUpper::MULi()
|
|
{
|
|
VUShared::MULi(m_codeGen, m_nDest, m_nFD, m_nFS);
|
|
}
|
|
|
|
//1F
|
|
void CMA_VU::CUpper::MINIi()
|
|
{
|
|
VUShared::MINIi(m_codeGen, m_nDest, m_nFD, m_nFS);
|
|
}
|
|
|
|
//20
|
|
void CMA_VU::CUpper::ADDq()
|
|
{
|
|
VUShared::ADDq(m_codeGen, m_nDest, m_nFD, m_nFS, m_nAddress);
|
|
}
|
|
|
|
//21
|
|
void CMA_VU::CUpper::MADDq()
|
|
{
|
|
VUShared::MADDq(m_codeGen, m_nDest, m_nFD, m_nFS, m_nAddress);
|
|
}
|
|
|
|
//22
|
|
void CMA_VU::CUpper::ADDi()
|
|
{
|
|
VUShared::ADDi(m_codeGen, m_nDest, m_nFD, m_nFS);
|
|
}
|
|
|
|
//26
|
|
void CMA_VU::CUpper::SUBi()
|
|
{
|
|
VUShared::SUBi(m_codeGen, m_nDest, m_nFD, m_nFS);
|
|
}
|
|
|
|
//27
|
|
void CMA_VU::CUpper::MSUBi()
|
|
{
|
|
VUShared::MSUBi(m_codeGen, m_nDest, m_nFD, m_nFS);
|
|
}
|
|
|
|
//28
|
|
void CMA_VU::CUpper::ADD()
|
|
{
|
|
VUShared::ADD(m_codeGen, m_nDest, m_nFD, m_nFS, m_nFT);
|
|
}
|
|
|
|
//29
|
|
void CMA_VU::CUpper::MADD()
|
|
{
|
|
VUShared::MADD(m_codeGen, m_nDest, m_nFD, m_nFS, m_nFT);
|
|
}
|
|
|
|
//2A
|
|
void CMA_VU::CUpper::MUL()
|
|
{
|
|
VUShared::MUL(m_codeGen, m_nDest, m_nFD, m_nFS, m_nFT);
|
|
}
|
|
|
|
//2B
|
|
void CMA_VU::CUpper::MAX()
|
|
{
|
|
VUShared::MAX(m_codeGen, m_nDest, m_nFD, m_nFS, m_nFT);
|
|
}
|
|
|
|
//2C
|
|
void CMA_VU::CUpper::SUB()
|
|
{
|
|
VUShared::SUB(m_codeGen, m_nDest, m_nFD, m_nFS, m_nFT);
|
|
}
|
|
|
|
//2E
|
|
void CMA_VU::CUpper::OPMSUB()
|
|
{
|
|
VUShared::OPMSUB(m_codeGen, m_nFD, m_nFS, m_nFT);
|
|
}
|
|
|
|
//2F
|
|
void CMA_VU::CUpper::MINI()
|
|
{
|
|
VUShared::MINI(m_codeGen, m_nDest, m_nFD, m_nFS, m_nFT);
|
|
}
|
|
|
|
//3C
|
|
void CMA_VU::CUpper::VECTOR0()
|
|
{
|
|
m_pOpVector0[(m_nOpcode >> 6) & 0x1F]();
|
|
}
|
|
|
|
//3D
|
|
void CMA_VU::CUpper::VECTOR1()
|
|
{
|
|
m_pOpVector1[(m_nOpcode >> 6) & 0x1F]();
|
|
}
|
|
|
|
//3E
|
|
void CMA_VU::CUpper::VECTOR2()
|
|
{
|
|
m_pOpVector2[(m_nOpcode >> 6) & 0x1F]();
|
|
}
|
|
|
|
//3F
|
|
void CMA_VU::CUpper::VECTOR3()
|
|
{
|
|
m_pOpVector3[(m_nOpcode >> 6) & 0x1F]();
|
|
}
|
|
|
|
//////////////////////////////////////////////////
|
|
//VectorX Common Instructions
|
|
//////////////////////////////////////////////////
|
|
|
|
//00
|
|
void CMA_VU::CUpper::ADDAbc()
|
|
{
|
|
VUShared::ADDAbc(m_codeGen, m_nDest, m_nFS, m_nFT, m_nBc);
|
|
}
|
|
|
|
//02
|
|
void CMA_VU::CUpper::MADDAbc()
|
|
{
|
|
VUShared::MADDAbc(m_codeGen, m_nDest, m_nFS, m_nFT, m_nBc);
|
|
}
|
|
|
|
//03
|
|
void CMA_VU::CUpper::MSUBAbc()
|
|
{
|
|
VUShared::MSUBAbc(m_codeGen, m_nDest, m_nFS, m_nFT, m_nBc);
|
|
}
|
|
|
|
//06
|
|
void CMA_VU::CUpper::MULAbc()
|
|
{
|
|
VUShared::MULAbc(m_codeGen, m_nDest, m_nFS, m_nFT, m_nBc);
|
|
}
|
|
|
|
//////////////////////////////////////////////////
|
|
//Vector0 Instructions
|
|
//////////////////////////////////////////////////
|
|
|
|
//04
|
|
void CMA_VU::CUpper::ITOF0()
|
|
{
|
|
VUShared::ITOF0(m_codeGen, m_nDest, m_nFT, m_nFS);
|
|
}
|
|
|
|
//05
|
|
void CMA_VU::CUpper::FTOI0()
|
|
{
|
|
VUShared::FTOI0(m_codeGen, m_nDest, m_nFT, m_nFS);
|
|
}
|
|
|
|
//0A
|
|
void CMA_VU::CUpper::ADDA()
|
|
{
|
|
VUShared::ADDA(m_codeGen, m_nDest, m_nFS, m_nFT);
|
|
}
|
|
|
|
//////////////////////////////////////////////////
|
|
//Vector1 Instructions
|
|
//////////////////////////////////////////////////
|
|
|
|
//04
|
|
void CMA_VU::CUpper::ITOF4()
|
|
{
|
|
VUShared::ITOF4(m_codeGen, m_nDest, m_nFT, m_nFS);
|
|
}
|
|
|
|
//05
|
|
void CMA_VU::CUpper::FTOI4()
|
|
{
|
|
VUShared::FTOI4(m_codeGen, m_nDest, m_nFT, m_nFS);
|
|
}
|
|
|
|
//07
|
|
void CMA_VU::CUpper::ABS()
|
|
{
|
|
VUShared::ABS(m_codeGen, m_nDest, m_nFT, m_nFS);
|
|
}
|
|
|
|
//0A
|
|
void CMA_VU::CUpper::MADDA()
|
|
{
|
|
VUShared::MADDA(m_codeGen, m_nDest, m_nFS, m_nFT);
|
|
}
|
|
|
|
//////////////////////////////////////////////////
|
|
//Vector2 Instructions
|
|
//////////////////////////////////////////////////
|
|
|
|
//04
|
|
void CMA_VU::CUpper::ITOF12()
|
|
{
|
|
VUShared::ITOF12(m_codeGen, m_nDest, m_nFT, m_nFS);
|
|
}
|
|
|
|
//05
|
|
void CMA_VU::CUpper::FTOI12()
|
|
{
|
|
VUShared::FTOI12(m_codeGen, m_nDest, m_nFT, m_nFS);
|
|
}
|
|
|
|
//07
|
|
void CMA_VU::CUpper::MULAi()
|
|
{
|
|
VUShared::MULAi(m_codeGen, m_nDest, m_nFS);
|
|
}
|
|
|
|
//0A
|
|
void CMA_VU::CUpper::MULA()
|
|
{
|
|
VUShared::MULA(m_codeGen, m_nDest, m_nFS, m_nFT);
|
|
}
|
|
|
|
//0B
|
|
void CMA_VU::CUpper::OPMULA()
|
|
{
|
|
VUShared::OPMULA(m_codeGen, m_nFS, m_nFT);
|
|
}
|
|
|
|
//////////////////////////////////////////////////
|
|
//Vector3 Instructions
|
|
//////////////////////////////////////////////////
|
|
|
|
//07
|
|
void CMA_VU::CUpper::CLIP()
|
|
{
|
|
VUShared::CLIP(m_codeGen, m_nFS, m_nFT);
|
|
}
|
|
|
|
//08
|
|
void CMA_VU::CUpper::MADDAi()
|
|
{
|
|
VUShared::MADDAi(m_codeGen, m_nDest, m_nFS);
|
|
}
|
|
|
|
//09
|
|
void CMA_VU::CUpper::MSUBAi()
|
|
{
|
|
VUShared::MSUBAi(m_codeGen, m_nDest, m_nFS);
|
|
}
|
|
|
|
//0B
|
|
void CMA_VU::CUpper::NOP()
|
|
{
|
|
|
|
}
|
|
|
|
//////////////////////////////////////////////////
|
|
//Opcode Tables
|
|
//////////////////////////////////////////////////
|
|
|
|
void (*CMA_VU::CUpper::m_pOpVector[0x40])() =
|
|
{
|
|
//0x00
|
|
ADDbc, ADDbc, ADDbc, ADDbc, SUBbc, SUBbc, SUBbc, SUBbc,
|
|
//0x08
|
|
MADDbc, MADDbc, MADDbc, MADDbc, MSUBbc, MSUBbc, MSUBbc, MSUBbc,
|
|
//0x10
|
|
MAXbc, Illegal, Illegal, MAXbc, Illegal, Illegal, Illegal, MINIbc,
|
|
//0x18
|
|
MULbc, MULbc, MULbc, MULbc, MULq, Illegal, MULi, MINIi,
|
|
//0x20
|
|
ADDq, MADDq, ADDi, Illegal, Illegal, Illegal, SUBi, MSUBi,
|
|
//0x28
|
|
ADD, MADD, MUL, MAX, SUB, Illegal, OPMSUB, MINI,
|
|
//0x30
|
|
Illegal, Illegal, Illegal, Illegal, Illegal, Illegal, Illegal, Illegal,
|
|
//0x38
|
|
Illegal, Illegal, Illegal, Illegal, VECTOR0, VECTOR1, VECTOR2, VECTOR3,
|
|
};
|
|
|
|
void (*CMA_VU::CUpper::m_pOpVector0[0x20])() =
|
|
{
|
|
//0x00
|
|
ADDAbc, Illegal, Illegal, MSUBAbc, ITOF0, FTOI0, MULAbc, Illegal,
|
|
//0x08
|
|
Illegal, Illegal, ADDA, Illegal, Illegal, Illegal, Illegal, Illegal,
|
|
//0x10
|
|
Illegal, Illegal, Illegal, Illegal, Illegal, Illegal, Illegal, Illegal,
|
|
//0x18
|
|
Illegal, Illegal, Illegal, Illegal, Illegal, Illegal, Illegal, Illegal,
|
|
};
|
|
|
|
void (*CMA_VU::CUpper::m_pOpVector1[0x20])() =
|
|
{
|
|
//0x00
|
|
ADDAbc, Illegal, MADDAbc, MSUBAbc, ITOF4, FTOI4, MULAbc, ABS,
|
|
//0x08
|
|
Illegal, Illegal, MADDA, Illegal, Illegal, Illegal, Illegal, Illegal,
|
|
//0x10
|
|
Illegal, Illegal, Illegal, Illegal, Illegal, Illegal, Illegal, Illegal,
|
|
//0x18
|
|
Illegal, Illegal, Illegal, Illegal, Illegal, Illegal, Illegal, Illegal,
|
|
};
|
|
|
|
void (*CMA_VU::CUpper::m_pOpVector2[0x20])() =
|
|
{
|
|
//0x00
|
|
Illegal, Illegal, MADDAbc, MSUBAbc, ITOF12, FTOI12, MULAbc, MULAi,
|
|
//0x08
|
|
Illegal, Illegal, MULA, OPMULA, Illegal, Illegal, Illegal, Illegal,
|
|
//0x10
|
|
Illegal, Illegal, Illegal, Illegal, Illegal, Illegal, Illegal, Illegal,
|
|
//0x18
|
|
Illegal, Illegal, Illegal, Illegal, Illegal, Illegal, Illegal, Illegal,
|
|
};
|
|
|
|
void (*CMA_VU::CUpper::m_pOpVector3[0x20])() =
|
|
{
|
|
//0x00
|
|
Illegal, Illegal, MADDAbc, MSUBAbc, Illegal, Illegal, MULAbc, CLIP,
|
|
//0x08
|
|
MADDAi, MSUBAi, Illegal, NOP, Illegal, Illegal, Illegal, Illegal,
|
|
//0x10
|
|
Illegal, Illegal, Illegal, Illegal, Illegal, Illegal, Illegal, Illegal,
|
|
//0x18
|
|
Illegal, Illegal, Illegal, Illegal, Illegal, Illegal, Illegal, Illegal,
|
|
};
|