mirror of
https://github.com/libretro/Play-.git
synced 2025-03-03 16:57:03 +00:00
381 lines
18 KiB
C++
381 lines
18 KiB
C++
#include <stdio.h>
|
|
#include "../MIPS.h"
|
|
#include "MA_EE.h"
|
|
|
|
using namespace MIPSReflection;
|
|
|
|
void CMA_EE::ReflOpRdRt(INSTRUCTION* pInstr, CMIPS* pCtx, uint32 nAddress, uint32 nOpcode, char* sText, unsigned int nCount)
|
|
{
|
|
uint8 nRT = static_cast<uint8>((nOpcode >> 16) & 0x001F);
|
|
uint8 nRD = static_cast<uint8>((nOpcode >> 11) & 0x001F);
|
|
|
|
sprintf(sText, "%s, %s", CMIPS::m_sGPRName[nRD], CMIPS::m_sGPRName[nRT]);
|
|
}
|
|
|
|
void CMA_EE::ReflOpRsImm(INSTRUCTION* pInstr, CMIPS* pCtx, uint32 nAddress, uint32 nOpcode, char* sText, unsigned int nCount)
|
|
{
|
|
uint8 nRS = static_cast<uint8> ((nOpcode >> 21) & 0x001F);
|
|
uint16 nImm = static_cast<uint16>((nOpcode >> 0) & 0xFFFF);
|
|
|
|
sprintf(sText, "%s, $%0.4X", CMIPS::m_sGPRName[nRS], nImm);
|
|
}
|
|
|
|
INSTRUCTION CMA_EE::m_cReflMmi[64] =
|
|
{
|
|
//0x00
|
|
{ "MADD", NULL, CopyMnemonic, ReflOpRdRsRt, NULL, NULL },
|
|
{ "MADDU", NULL, CopyMnemonic, ReflOpRdRsRt, NULL, NULL },
|
|
{ NULL, NULL, NULL, NULL, NULL, NULL },
|
|
{ NULL, NULL, NULL, NULL, NULL, NULL },
|
|
{ "PLZCW", NULL, CopyMnemonic, ReflOpRdRs, NULL, NULL },
|
|
{ NULL, NULL, NULL, NULL, NULL, NULL },
|
|
{ NULL, NULL, NULL, NULL, NULL, NULL },
|
|
{ NULL, NULL, NULL, NULL, NULL, NULL },
|
|
//0x08
|
|
{ "MMI0", NULL, SubTableMnemonic, SubTableOperands, SubTableIsBranch, SubTableEffAddr },
|
|
{ "MMI2", NULL, SubTableMnemonic, SubTableOperands, SubTableIsBranch, SubTableEffAddr },
|
|
{ NULL, NULL, NULL, NULL, NULL, NULL },
|
|
{ NULL, NULL, NULL, NULL, NULL, NULL },
|
|
{ NULL, NULL, NULL, NULL, NULL, NULL },
|
|
{ NULL, NULL, NULL, NULL, NULL, NULL },
|
|
{ NULL, NULL, NULL, NULL, NULL, NULL },
|
|
{ NULL, NULL, NULL, NULL, NULL, NULL },
|
|
//0x10
|
|
{ "MFHI1", NULL, CopyMnemonic, ReflOpRd, NULL, NULL },
|
|
{ "MTHI1", NULL, CopyMnemonic, ReflOpRs, NULL, NULL },
|
|
{ "MFLO1", NULL, CopyMnemonic, ReflOpRd, NULL, NULL },
|
|
{ "MTLO1", NULL, CopyMnemonic, ReflOpRs, NULL, NULL },
|
|
{ NULL, NULL, NULL, NULL, NULL, NULL },
|
|
{ NULL, NULL, NULL, NULL, NULL, NULL },
|
|
{ NULL, NULL, NULL, NULL, NULL, NULL },
|
|
{ NULL, NULL, NULL, NULL, NULL, NULL },
|
|
//0x18
|
|
{ "MULT1", NULL, CopyMnemonic, ReflOpRdRsRt, NULL, NULL },
|
|
{ "MULTU1", NULL, CopyMnemonic, ReflOpRdRsRt, NULL, NULL },
|
|
{ "DIV1", NULL, CopyMnemonic, ReflOpRsRt, NULL, NULL },
|
|
{ "DIVU1", NULL, CopyMnemonic, ReflOpRsRt, NULL, NULL },
|
|
{ NULL, NULL, NULL, NULL, NULL, NULL },
|
|
{ NULL, NULL, NULL, NULL, NULL, NULL },
|
|
{ NULL, NULL, NULL, NULL, NULL, NULL },
|
|
{ NULL, NULL, NULL, NULL, NULL, NULL },
|
|
//0x20
|
|
{ "MADD1", NULL, CopyMnemonic, ReflOpRdRsRt, NULL, NULL },
|
|
{ "MADDU1", NULL, CopyMnemonic, ReflOpRdRsRt, NULL, NULL },
|
|
{ NULL, NULL, NULL, NULL, NULL, NULL },
|
|
{ NULL, NULL, NULL, NULL, NULL, NULL },
|
|
{ NULL, NULL, NULL, NULL, NULL, NULL },
|
|
{ NULL, NULL, NULL, NULL, NULL, NULL },
|
|
{ NULL, NULL, NULL, NULL, NULL, NULL },
|
|
{ NULL, NULL, NULL, NULL, NULL, NULL },
|
|
//0x28
|
|
{ "MMI1", NULL, SubTableMnemonic, SubTableOperands, SubTableIsBranch, SubTableEffAddr },
|
|
{ "MMI3", NULL, SubTableMnemonic, SubTableOperands, SubTableIsBranch, SubTableEffAddr },
|
|
{ NULL, NULL, NULL, NULL, NULL, NULL },
|
|
{ NULL, NULL, NULL, NULL, NULL, NULL },
|
|
{ NULL, NULL, NULL, NULL, NULL, NULL },
|
|
{ NULL, NULL, NULL, NULL, NULL, NULL },
|
|
{ NULL, NULL, NULL, NULL, NULL, NULL },
|
|
{ NULL, NULL, NULL, NULL, NULL, NULL },
|
|
//0x30
|
|
{ "PMFHL", NULL, SubTableMnemonic, SubTableOperands, SubTableIsBranch, SubTableEffAddr },
|
|
{ NULL, NULL, NULL, NULL, NULL, NULL },
|
|
{ NULL, NULL, NULL, NULL, NULL, NULL },
|
|
{ NULL, NULL, NULL, NULL, NULL, NULL },
|
|
{ "PSLLH", NULL, CopyMnemonic, ReflOpRdRtSa, NULL, NULL },
|
|
{ NULL, NULL, NULL, NULL, NULL, NULL },
|
|
{ "PSRLH", NULL, CopyMnemonic, ReflOpRdRtSa, NULL, NULL },
|
|
{ "PSRAH", NULL, CopyMnemonic, ReflOpRdRtSa, NULL, NULL },
|
|
//0x38
|
|
{ NULL, NULL, NULL, NULL, NULL, NULL },
|
|
{ NULL, NULL, NULL, NULL, NULL, NULL },
|
|
{ NULL, NULL, NULL, NULL, NULL, NULL },
|
|
{ NULL, NULL, NULL, NULL, NULL, NULL },
|
|
{ "PSLLW", NULL, CopyMnemonic, ReflOpRdRtSa, NULL, NULL },
|
|
{ NULL, NULL, NULL, NULL, NULL, NULL },
|
|
{ "PSRLW", NULL, CopyMnemonic, ReflOpRdRtSa, NULL, NULL },
|
|
{ "PSRAW", NULL, CopyMnemonic, ReflOpRdRtSa, NULL, NULL },
|
|
};
|
|
|
|
INSTRUCTION CMA_EE::m_cReflMmi0[32] =
|
|
{
|
|
//0x00
|
|
{ "PADDW", NULL, CopyMnemonic, ReflOpRdRsRt, NULL, NULL },
|
|
{ "PSUBW", NULL, CopyMnemonic, ReflOpRdRsRt, NULL, NULL },
|
|
{ "PCGTW", NULL, CopyMnemonic, ReflOpRdRsRt, NULL, NULL },
|
|
{ "PMAXW", NULL, CopyMnemonic, ReflOpRdRsRt, NULL, NULL },
|
|
{ "PADDH", NULL, CopyMnemonic, ReflOpRdRsRt, NULL, NULL },
|
|
{ "PSUBH", NULL, CopyMnemonic, ReflOpRdRsRt, NULL, NULL },
|
|
{ "PCGTH", NULL, CopyMnemonic, ReflOpRdRsRt, NULL, NULL },
|
|
{ "PMAXH", NULL, CopyMnemonic, ReflOpRdRsRt, NULL, NULL },
|
|
//0x08
|
|
{ "PADDB", NULL, CopyMnemonic, ReflOpRdRsRt, NULL, NULL },
|
|
{ "PSUBB", NULL, CopyMnemonic, ReflOpRdRsRt, NULL, NULL },
|
|
{ "PCGTB", NULL, CopyMnemonic, ReflOpRdRsRt, NULL, NULL },
|
|
{ NULL, NULL, NULL, NULL, NULL, NULL },
|
|
{ NULL, NULL, NULL, NULL, NULL, NULL },
|
|
{ NULL, NULL, NULL, NULL, NULL, NULL },
|
|
{ NULL, NULL, NULL, NULL, NULL, NULL },
|
|
{ NULL, NULL, NULL, NULL, NULL, NULL },
|
|
//0x10
|
|
{ "PADDSW", NULL, CopyMnemonic, ReflOpRdRsRt, NULL, NULL },
|
|
{ "PSUBSW", NULL, CopyMnemonic, ReflOpRdRsRt, NULL, NULL },
|
|
{ "PEXTLW", NULL, CopyMnemonic, ReflOpRdRsRt, NULL, NULL },
|
|
{ "PPACW", NULL, CopyMnemonic, ReflOpRdRsRt, NULL, NULL },
|
|
{ "PADDSH", NULL, CopyMnemonic, ReflOpRdRsRt, NULL, NULL },
|
|
{ "PSUBSH", NULL, CopyMnemonic, ReflOpRdRsRt, NULL, NULL },
|
|
{ "PEXTLH", NULL, CopyMnemonic, ReflOpRdRsRt, NULL, NULL },
|
|
{ "PPACH", NULL, CopyMnemonic, ReflOpRdRsRt, NULL, NULL },
|
|
//0x18
|
|
{ NULL, NULL, NULL, NULL, NULL, NULL },
|
|
{ NULL, NULL, NULL, NULL, NULL, NULL },
|
|
{ "PEXTLB", NULL, CopyMnemonic, ReflOpRdRsRt, NULL, NULL },
|
|
{ "PPACB", NULL, CopyMnemonic, ReflOpRdRsRt, NULL, NULL },
|
|
{ NULL, NULL, NULL, NULL, NULL, NULL },
|
|
{ NULL, NULL, NULL, NULL, NULL, NULL },
|
|
{ "PEXT5", NULL, CopyMnemonic, ReflOpRdRt, NULL, NULL },
|
|
{ "PPAC5", NULL, CopyMnemonic, ReflOpRdRt, NULL, NULL },
|
|
};
|
|
|
|
INSTRUCTION CMA_EE::m_cReflMmi1[32] =
|
|
{
|
|
//0x00
|
|
{ NULL, NULL, NULL, NULL, NULL, NULL },
|
|
{ "PABSW", NULL, CopyMnemonic, ReflOpRdRt, NULL, NULL },
|
|
{ "PCEQW", NULL, CopyMnemonic, ReflOpRdRsRt, NULL, NULL },
|
|
{ "PMINW", NULL, CopyMnemonic, ReflOpRdRsRt, NULL, NULL },
|
|
{ NULL, NULL, NULL, NULL, NULL, NULL },
|
|
{ NULL, NULL, NULL, NULL, NULL, NULL },
|
|
{ "PCEQH", NULL, CopyMnemonic, ReflOpRdRsRt, NULL, NULL },
|
|
{ "PMINH", NULL, CopyMnemonic, ReflOpRdRsRt, NULL, NULL },
|
|
//0x08
|
|
{ NULL, NULL, NULL, NULL, NULL, NULL },
|
|
{ NULL, NULL, NULL, NULL, NULL, NULL },
|
|
{ "PCEQB", NULL, CopyMnemonic, ReflOpRdRsRt, NULL, NULL },
|
|
{ NULL, NULL, NULL, NULL, NULL, NULL },
|
|
{ NULL, NULL, NULL, NULL, NULL, NULL },
|
|
{ NULL, NULL, NULL, NULL, NULL, NULL },
|
|
{ NULL, NULL, NULL, NULL, NULL, NULL },
|
|
{ NULL, NULL, NULL, NULL, NULL, NULL },
|
|
//0x10
|
|
{ "PADDUW", NULL, CopyMnemonic, ReflOpRdRsRt, NULL, NULL },
|
|
{ NULL, NULL, NULL, NULL, NULL, NULL },
|
|
{ "PEXTUW", NULL, CopyMnemonic, ReflOpRdRsRt, NULL, NULL },
|
|
{ NULL, NULL, NULL, NULL, NULL, NULL },
|
|
{ NULL, NULL, NULL, NULL, NULL, NULL },
|
|
{ "PSUBUH", NULL, CopyMnemonic, ReflOpRdRsRt, NULL, NULL },
|
|
{ "PEXTUH", NULL, CopyMnemonic, ReflOpRdRsRt, NULL, NULL },
|
|
{ NULL, NULL, NULL, NULL, NULL, NULL },
|
|
//0x18
|
|
{ "PADDUB", NULL, CopyMnemonic, ReflOpRdRsRt, NULL, NULL },
|
|
{ "PSUBUB", NULL, CopyMnemonic, ReflOpRdRsRt, NULL, NULL },
|
|
{ "PEXTUB", NULL, CopyMnemonic, ReflOpRdRsRt, NULL, NULL },
|
|
{ "QFSRV", NULL, CopyMnemonic, ReflOpRdRsRt, NULL, NULL },
|
|
{ NULL, NULL, NULL, NULL, NULL, NULL },
|
|
{ NULL, NULL, NULL, NULL, NULL, NULL },
|
|
{ NULL, NULL, NULL, NULL, NULL, NULL },
|
|
{ NULL, NULL, NULL, NULL, NULL, NULL },
|
|
};
|
|
|
|
INSTRUCTION CMA_EE::m_cReflMmi2[32] =
|
|
{
|
|
//0x00
|
|
{ NULL, NULL, NULL, NULL, NULL, NULL },
|
|
{ NULL, NULL, NULL, NULL, NULL, NULL },
|
|
{ "PSLLVW", NULL, CopyMnemonic, ReflOpRdRtRs, NULL, NULL },
|
|
{ "PSRLVW", NULL, CopyMnemonic, ReflOpRdRtRs, NULL, NULL },
|
|
{ NULL, NULL, NULL, NULL, NULL, NULL },
|
|
{ NULL, NULL, NULL, NULL, NULL, NULL },
|
|
{ NULL, NULL, NULL, NULL, NULL, NULL },
|
|
{ NULL, NULL, NULL, NULL, NULL, NULL },
|
|
//0x08
|
|
{ "PMFHI", NULL, CopyMnemonic, ReflOpRd, NULL, NULL },
|
|
{ "PMFLO", NULL, CopyMnemonic, ReflOpRd, NULL, NULL },
|
|
{ NULL, NULL, NULL, NULL, NULL, NULL },
|
|
{ NULL, NULL, NULL, NULL, NULL, NULL },
|
|
{ "PMULTW", NULL, CopyMnemonic, ReflOpRdRsRt, NULL, NULL },
|
|
{ "PDIVW", NULL, CopyMnemonic, ReflOpRsRt, NULL, NULL },
|
|
{ "PCPYLD", NULL, CopyMnemonic, ReflOpRdRsRt, NULL, NULL },
|
|
{ NULL, NULL, NULL, NULL, NULL, NULL },
|
|
//0x10
|
|
{ "PMADDH", NULL, CopyMnemonic, ReflOpRdRsRt, NULL, NULL },
|
|
{ NULL, NULL, NULL, NULL, NULL, NULL },
|
|
{ "PAND", NULL, CopyMnemonic, ReflOpRdRsRt, NULL, NULL },
|
|
{ "PXOR", NULL, CopyMnemonic, ReflOpRdRsRt, NULL, NULL },
|
|
{ NULL, NULL, NULL, NULL, NULL, NULL },
|
|
{ NULL, NULL, NULL, NULL, NULL, NULL },
|
|
{ NULL, NULL, NULL, NULL, NULL, NULL },
|
|
{ NULL, NULL, NULL, NULL, NULL, NULL },
|
|
//0x18
|
|
{ NULL, NULL, NULL, NULL, NULL, NULL },
|
|
{ NULL, NULL, NULL, NULL, NULL, NULL },
|
|
{ NULL, NULL, NULL, NULL, NULL, NULL },
|
|
{ "PREVH", NULL, CopyMnemonic, ReflOpRdRt, NULL, NULL },
|
|
{ "PMULTH", NULL, CopyMnemonic, ReflOpRdRsRt, NULL, NULL },
|
|
{ NULL, NULL, NULL, NULL, NULL, NULL },
|
|
{ "PEXEW", NULL, CopyMnemonic, ReflOpRdRt, NULL, NULL },
|
|
{ "PROT3W", NULL, CopyMnemonic, ReflOpRdRt, NULL, NULL },
|
|
};
|
|
|
|
INSTRUCTION CMA_EE::m_cReflMmi3[32] =
|
|
{
|
|
//0x00
|
|
{ NULL, NULL, NULL, NULL, NULL, NULL },
|
|
{ NULL, NULL, NULL, NULL, NULL, NULL },
|
|
{ NULL, NULL, NULL, NULL, NULL, NULL },
|
|
{ "PSRAVW", NULL, CopyMnemonic, ReflOpRdRtRs, NULL, NULL },
|
|
{ NULL, NULL, NULL, NULL, NULL, NULL },
|
|
{ NULL, NULL, NULL, NULL, NULL, NULL },
|
|
{ NULL, NULL, NULL, NULL, NULL, NULL },
|
|
{ NULL, NULL, NULL, NULL, NULL, NULL },
|
|
//0x08
|
|
{ "PMTHI", NULL, CopyMnemonic, ReflOpRs, NULL, NULL },
|
|
{ "PMTLO", NULL, CopyMnemonic, ReflOpRs, NULL, NULL },
|
|
{ "PINTEH", NULL, CopyMnemonic, ReflOpRdRsRt, NULL, NULL },
|
|
{ NULL, NULL, NULL, NULL, NULL, NULL },
|
|
{ NULL, NULL, NULL, NULL, NULL, NULL },
|
|
{ NULL, NULL, NULL, NULL, NULL, NULL },
|
|
{ "PCPYUD", NULL, CopyMnemonic, ReflOpRdRsRt, NULL, NULL },
|
|
{ NULL, NULL, NULL, NULL, NULL, NULL },
|
|
//0x10
|
|
{ NULL, NULL, NULL, NULL, NULL, NULL },
|
|
{ NULL, NULL, NULL, NULL, NULL, NULL },
|
|
{ "POR", NULL, CopyMnemonic, ReflOpRdRsRt, NULL, NULL },
|
|
{ "PNOR", NULL, CopyMnemonic, ReflOpRdRsRt, NULL, NULL },
|
|
{ NULL, NULL, NULL, NULL, NULL, NULL },
|
|
{ NULL, NULL, NULL, NULL, NULL, NULL },
|
|
{ NULL, NULL, NULL, NULL, NULL, NULL },
|
|
{ NULL, NULL, NULL, NULL, NULL, NULL },
|
|
//0x18
|
|
{ NULL, NULL, NULL, NULL, NULL, NULL },
|
|
{ NULL, NULL, NULL, NULL, NULL, NULL },
|
|
{ "PEXCH", NULL, CopyMnemonic, ReflOpRdRt, NULL, NULL },
|
|
{ "PCPYH", NULL, CopyMnemonic, ReflOpRdRt, NULL, NULL },
|
|
{ NULL, NULL, NULL, NULL, NULL, NULL },
|
|
{ NULL, NULL, NULL, NULL, NULL, NULL },
|
|
{ "PEXCW", NULL, CopyMnemonic, ReflOpRdRt, NULL, NULL },
|
|
{ NULL, NULL, NULL, NULL, NULL, NULL },
|
|
};
|
|
|
|
INSTRUCTION CMA_EE::m_cReflPmfhl[32] =
|
|
{
|
|
//0x00
|
|
{ "PMFHL.LW", NULL, CopyMnemonic, ReflOpRd, NULL, NULL },
|
|
{ "PMFHL.UW", NULL, CopyMnemonic, ReflOpRd, NULL, NULL },
|
|
{ NULL, NULL, NULL, NULL, NULL, NULL },
|
|
{ "PMFHL.LH", NULL, CopyMnemonic, ReflOpRd, NULL, NULL },
|
|
{ "PMFHL.SH", NULL, CopyMnemonic, ReflOpRd, NULL, NULL },
|
|
{ NULL, NULL, NULL, NULL, NULL, NULL },
|
|
{ NULL, NULL, NULL, NULL, NULL, NULL },
|
|
{ NULL, NULL, NULL, NULL, NULL, NULL },
|
|
//0x08
|
|
{ NULL, NULL, NULL, NULL, NULL, NULL },
|
|
{ NULL, NULL, NULL, NULL, NULL, NULL },
|
|
{ NULL, NULL, NULL, NULL, NULL, NULL },
|
|
{ NULL, NULL, NULL, NULL, NULL, NULL },
|
|
{ NULL, NULL, NULL, NULL, NULL, NULL },
|
|
{ NULL, NULL, NULL, NULL, NULL, NULL },
|
|
{ NULL, NULL, NULL, NULL, NULL, NULL },
|
|
{ NULL, NULL, NULL, NULL, NULL, NULL },
|
|
//0x10
|
|
{ NULL, NULL, NULL, NULL, NULL, NULL },
|
|
{ NULL, NULL, NULL, NULL, NULL, NULL },
|
|
{ NULL, NULL, NULL, NULL, NULL, NULL },
|
|
{ NULL, NULL, NULL, NULL, NULL, NULL },
|
|
{ NULL, NULL, NULL, NULL, NULL, NULL },
|
|
{ NULL, NULL, NULL, NULL, NULL, NULL },
|
|
{ NULL, NULL, NULL, NULL, NULL, NULL },
|
|
{ NULL, NULL, NULL, NULL, NULL, NULL },
|
|
//0x18
|
|
{ NULL, NULL, NULL, NULL, NULL, NULL },
|
|
{ NULL, NULL, NULL, NULL, NULL, NULL },
|
|
{ NULL, NULL, NULL, NULL, NULL, NULL },
|
|
{ NULL, NULL, NULL, NULL, NULL, NULL },
|
|
{ NULL, NULL, NULL, NULL, NULL, NULL },
|
|
{ NULL, NULL, NULL, NULL, NULL, NULL },
|
|
{ NULL, NULL, NULL, NULL, NULL, NULL },
|
|
{ NULL, NULL, NULL, NULL, NULL, NULL },
|
|
};
|
|
|
|
void CMA_EE::SetupReflectionTables()
|
|
{
|
|
static_assert(sizeof(m_ReflMmi) == sizeof(m_cReflMmi), "Array sizes don't match");
|
|
static_assert(sizeof(m_ReflMmi0) == sizeof(m_cReflMmi0), "Array sizes don't match");
|
|
static_assert(sizeof(m_ReflMmi1) == sizeof(m_cReflMmi1), "Array sizes don't match");
|
|
static_assert(sizeof(m_ReflMmi2) == sizeof(m_cReflMmi2), "Array sizes don't match");
|
|
static_assert(sizeof(m_ReflMmi3) == sizeof(m_cReflMmi3), "Array sizes don't match");
|
|
static_assert(sizeof(m_ReflPmfhl) == sizeof(m_cReflPmfhl), "Array sizes don't match");
|
|
|
|
memcpy(m_ReflMmi, m_cReflMmi, sizeof(m_cReflMmi));
|
|
memcpy(m_ReflMmi0, m_cReflMmi0, sizeof(m_cReflMmi0));
|
|
memcpy(m_ReflMmi1, m_cReflMmi1, sizeof(m_cReflMmi1));
|
|
memcpy(m_ReflMmi2, m_cReflMmi2, sizeof(m_cReflMmi2));
|
|
memcpy(m_ReflMmi3, m_cReflMmi3, sizeof(m_cReflMmi3));
|
|
memcpy(m_ReflPmfhl, m_cReflPmfhl, sizeof(m_cReflPmfhl));
|
|
|
|
m_ReflMmiTable.pTable = m_ReflMmi;
|
|
m_ReflMmiTable.nShift = 0;
|
|
m_ReflMmiTable.nMask = 0x3F;
|
|
|
|
m_ReflMmi0Table.pTable = m_ReflMmi0;
|
|
m_ReflMmi0Table.nShift = 6;
|
|
m_ReflMmi0Table.nMask = 0x1F;
|
|
|
|
m_ReflMmi1Table.pTable = m_ReflMmi1;
|
|
m_ReflMmi1Table.nShift = 6;
|
|
m_ReflMmi1Table.nMask = 0x1F;
|
|
|
|
m_ReflMmi2Table.pTable = m_ReflMmi2;
|
|
m_ReflMmi2Table.nShift = 6;
|
|
m_ReflMmi2Table.nMask = 0x1F;
|
|
|
|
m_ReflMmi3Table.pTable = m_ReflMmi3;
|
|
m_ReflMmi3Table.nShift = 6;
|
|
m_ReflMmi3Table.nMask = 0x1F;
|
|
|
|
m_ReflPmfhlTable.pTable = m_ReflPmfhl;
|
|
m_ReflPmfhlTable.nShift = 6;
|
|
m_ReflPmfhlTable.nMask = 0x1F;
|
|
|
|
//Fix MIPSIV tables
|
|
m_ReflGeneral[0x1C].sMnemonic = "MMI";
|
|
m_ReflGeneral[0x1C].pSubTable = &m_ReflMmiTable;
|
|
m_ReflGeneral[0x1C].pGetMnemonic = SubTableMnemonic;
|
|
m_ReflGeneral[0x1C].pGetOperands = SubTableOperands;
|
|
m_ReflGeneral[0x1C].pIsBranch = SubTableIsBranch;
|
|
m_ReflGeneral[0x1C].pGetEffectiveAddress = SubTableEffAddr;
|
|
|
|
m_ReflGeneral[0x1E].sMnemonic = "LQ";
|
|
m_ReflGeneral[0x1E].pGetMnemonic = MIPSReflection::CopyMnemonic;
|
|
m_ReflGeneral[0x1E].pGetOperands = ReflOpRtOffRs;
|
|
|
|
m_ReflGeneral[0x1F].sMnemonic = "SQ";
|
|
m_ReflGeneral[0x1F].pGetMnemonic = MIPSReflection::CopyMnemonic;
|
|
m_ReflGeneral[0x1F].pGetOperands = ReflOpRtOffRs;
|
|
|
|
m_ReflRegImm[0x18].sMnemonic = "MTSAB";
|
|
m_ReflRegImm[0x18].pGetMnemonic = MIPSReflection::CopyMnemonic;
|
|
m_ReflRegImm[0x18].pGetOperands = ReflOpRsImm;
|
|
|
|
m_ReflRegImm[0x19].sMnemonic = "MTSAH";
|
|
m_ReflRegImm[0x19].pGetMnemonic = MIPSReflection::CopyMnemonic;
|
|
m_ReflRegImm[0x19].pGetOperands = ReflOpRsImm;
|
|
|
|
m_ReflSpecial[0x28].sMnemonic = "MFSA";
|
|
m_ReflSpecial[0x28].pGetMnemonic = MIPSReflection::CopyMnemonic;
|
|
m_ReflSpecial[0x28].pGetOperands = ReflOpRd;
|
|
|
|
m_ReflSpecial[0x29].sMnemonic = "MTSA";
|
|
m_ReflSpecial[0x29].pGetMnemonic = MIPSReflection::CopyMnemonic;
|
|
m_ReflSpecial[0x29].pGetOperands = ReflOpRs;
|
|
|
|
//Fix MULT/MULTU operands
|
|
m_ReflSpecial[0x18].pGetOperands = ReflOpRdRsRt;
|
|
m_ReflSpecial[0x19].pGetOperands = ReflOpRdRsRt;
|
|
|
|
m_ReflMmi[0x08].pSubTable = &m_ReflMmi0Table;
|
|
m_ReflMmi[0x09].pSubTable = &m_ReflMmi2Table;
|
|
m_ReflMmi[0x28].pSubTable = &m_ReflMmi1Table;
|
|
m_ReflMmi[0x29].pSubTable = &m_ReflMmi3Table;
|
|
m_ReflMmi[0x30].pSubTable = &m_ReflPmfhlTable;
|
|
}
|