#include #include #include "MA_EE.h" #include "MIPS.h" using namespace MIPSReflection; void CMA_EE::ReflOpRdRt(INSTRUCTION* pInstr, CMIPS* pCtx, uint32 nAddress, uint32 nOpcode, char* sText, unsigned int nCount) { uint8 nRT, nRD; nRT = (uint8)((nOpcode >> 16) & 0x001F); nRD = (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; uint16 nImm; nRS = (uint8) ((nOpcode >> 21) & 0x001F); nImm = (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 }, { NULL, NULL, NULL, NULL, 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 { 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 }, //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 { NULL, NULL, NULL, NULL, NULL, NULL }, { 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 }, { NULL, NULL, NULL, NULL, NULL, NULL }, { NULL, NULL, NULL, NULL, NULL, NULL }, { NULL, NULL, NULL, NULL, NULL, NULL }, { "PSRAW", NULL, CopyMnemonic, ReflOpRdRtSa, NULL, NULL }, }; INSTRUCTION CMA_EE::m_cReflMmi0[32] = { //0x00 { NULL, NULL, NULL, NULL, NULL, NULL }, { "PSUBW", NULL, CopyMnemonic, ReflOpRdRsRt, NULL, NULL }, { NULL, NULL, NULL, NULL, NULL, NULL }, { NULL, NULL, NULL, NULL, NULL, NULL }, { "PADDH", NULL, CopyMnemonic, ReflOpRdRsRt, NULL, NULL }, { NULL, NULL, NULL, NULL, NULL, NULL }, { "PCGTH", NULL, CopyMnemonic, ReflOpRdRsRt, NULL, NULL }, { "PMAXH", NULL, CopyMnemonic, ReflOpRdRsRt, NULL, NULL }, //0x08 { NULL, NULL, NULL, NULL, NULL, NULL }, { "PSUBB", 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 }, //0x10 { "PADDSW", NULL, CopyMnemonic, ReflOpRdRsRt, NULL, NULL }, { NULL, NULL, NULL, NULL, NULL, NULL }, { "PEXTLW", NULL, CopyMnemonic, ReflOpRdRsRt, NULL, NULL }, { NULL, NULL, NULL, NULL, NULL, NULL }, { NULL, NULL, NULL, NULL, NULL, NULL }, { NULL, NULL, NULL, NULL, 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 }, { NULL, NULL, NULL, NULL, NULL, NULL }, }; INSTRUCTION CMA_EE::m_cReflMmi1[32] = { //0x00 { NULL, NULL, NULL, NULL, NULL, NULL }, { NULL, NULL, NULL, NULL, NULL, NULL }, { "PCEQW", 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 }, { "PMINH", NULL, CopyMnemonic, ReflOpRdRsRt, 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 { "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 }, { 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 }, { "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 }, { 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 }, //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 }, { "PCPYLD", NULL, CopyMnemonic, ReflOpRdRsRt, NULL, NULL }, { NULL, NULL, NULL, NULL, NULL, NULL }, //0x10 { NULL, NULL, NULL, NULL, 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 }, { NULL, NULL, NULL, NULL, NULL, NULL }, { NULL, NULL, NULL, NULL, NULL, NULL }, { NULL, NULL, NULL, NULL, NULL, NULL }, { NULL, NULL, NULL, NULL, 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 }, { 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 }, //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 }, { "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 }, { NULL, NULL, NULL, NULL, NULL, NULL }, { "PCPYH", NULL, CopyMnemonic, ReflOpRdRt, 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() { BOOST_STATIC_ASSERT(sizeof(m_ReflMmi) == sizeof(m_cReflMmi)); BOOST_STATIC_ASSERT(sizeof(m_ReflMmi0) == sizeof(m_cReflMmi0)); BOOST_STATIC_ASSERT(sizeof(m_ReflMmi1) == sizeof(m_cReflMmi1)); BOOST_STATIC_ASSERT(sizeof(m_ReflMmi2) == sizeof(m_cReflMmi2)); BOOST_STATIC_ASSERT(sizeof(m_ReflMmi3) == sizeof(m_cReflMmi3)); 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)); 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; //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_ReflSpecial[0x1D].sMnemonic = "REEXCPT"; m_ReflSpecial[0x1D].pGetMnemonic = MIPSReflection::CopyMnemonic; m_ReflSpecial[0x1D].pGetOperands = NULL; 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; //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; }