2006-06-15 04:19:30 +00:00
|
|
|
#include <stdio.h>
|
|
|
|
#include "VUShared.h"
|
|
|
|
|
|
|
|
using namespace MIPSReflection;
|
|
|
|
using namespace VUShared;
|
|
|
|
|
|
|
|
const char* VUShared::m_sBroadcast[4] =
|
|
|
|
{
|
|
|
|
"x",
|
|
|
|
"y",
|
|
|
|
"z",
|
|
|
|
"w",
|
|
|
|
};
|
|
|
|
|
|
|
|
const char* VUShared::m_sDestination[16] =
|
|
|
|
{
|
|
|
|
"", //0000
|
|
|
|
"w", //000w
|
|
|
|
"z", //00z0
|
|
|
|
"zw", //00zw
|
|
|
|
"y", //0y00
|
|
|
|
"yw", //0y0w
|
|
|
|
"yz", //0yz0
|
|
|
|
"yzw", //0yzw
|
|
|
|
"x", //x000
|
|
|
|
"xw", //x00w
|
|
|
|
"xz", //x0z0
|
|
|
|
"xzw", //x0zw
|
|
|
|
"xy", //xy00
|
|
|
|
"xyw", //xy0w
|
|
|
|
"xyz", //xyz0
|
|
|
|
"xyzw", //xyzw
|
|
|
|
};
|
|
|
|
|
|
|
|
int32 VUShared::GetImm11Offset(uint16 nImm11)
|
|
|
|
{
|
|
|
|
if(nImm11 & 0x400)
|
|
|
|
{
|
|
|
|
return -(0x800 - nImm11);
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
return (nImm11 & 0x3FF);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
int32 VUShared::GetBranch(uint16 nImm11)
|
|
|
|
{
|
|
|
|
return GetImm11Offset(nImm11) * 8;
|
|
|
|
}
|
|
|
|
|
|
|
|
void VUShared::ReflOpFdFsI(INSTRUCTION* pInstr, CMIPS* pCtx, uint32 nAddress, uint32 nOpcode, char* sText, unsigned int nCount)
|
|
|
|
{
|
|
|
|
uint8 nFD, nFS;
|
|
|
|
uint8 nDest;
|
|
|
|
|
|
|
|
nFS = (uint8)((nOpcode >> 11) & 0x001F);
|
|
|
|
nFD = (uint8)((nOpcode >> 6) & 0x001F);
|
|
|
|
|
|
|
|
nDest = (uint8)((nOpcode >> 21) & 0x000F);
|
|
|
|
|
|
|
|
sprintf(sText, "VF%i%s, VF%i%s, I", nFD, m_sDestination[nDest], nFS, m_sDestination[nDest]);
|
|
|
|
}
|
|
|
|
|
|
|
|
void VUShared::ReflOpFdFsQ(INSTRUCTION* pInstr, CMIPS* pCtx, uint32 nAddress, uint32 nOpcode, char* sText, unsigned int nCount)
|
|
|
|
{
|
|
|
|
uint8 nFD, nFS;
|
|
|
|
uint8 nDest;
|
|
|
|
|
|
|
|
nFS = (uint8)((nOpcode >> 11) & 0x001F);
|
|
|
|
nFD = (uint8)((nOpcode >> 6) & 0x001F);
|
|
|
|
|
|
|
|
nDest = (uint8)((nOpcode >> 21) & 0x000F);
|
|
|
|
|
|
|
|
sprintf(sText, "VF%i%s, VF%i%s, Q", nFD, m_sDestination[nDest], nFS, m_sDestination[nDest]);
|
|
|
|
}
|
|
|
|
|
|
|
|
void VUShared::ReflOpFdFsFt(INSTRUCTION* pInstr, CMIPS* pCtx, uint32 nAddress, uint32 nOpcode, char* sText, unsigned int nCount)
|
|
|
|
{
|
|
|
|
uint8 nFD, nFT, nFS;
|
|
|
|
uint8 nDest;
|
|
|
|
|
|
|
|
nFT = (uint8)((nOpcode >> 16) & 0x001F);
|
|
|
|
nFS = (uint8)((nOpcode >> 11) & 0x001F);
|
|
|
|
nFD = (uint8)((nOpcode >> 6) & 0x001F);
|
|
|
|
|
|
|
|
nDest = (uint8)((nOpcode >> 21) & 0x000F);
|
|
|
|
|
|
|
|
sprintf(sText, "VF%i%s, VF%i%s, VF%i%s", nFD, m_sDestination[nDest], nFS, m_sDestination[nDest], nFT, m_sDestination[nDest]);
|
|
|
|
}
|
|
|
|
|
|
|
|
void VUShared::ReflOpFdFsFtBc(INSTRUCTION* pInstr, CMIPS* pCtx, uint32 nAddress, uint32 nOpcode, char* sText, unsigned int nCount)
|
|
|
|
{
|
|
|
|
uint8 nFD, nFT, nFS;
|
|
|
|
uint8 nBc, nDest;
|
|
|
|
|
|
|
|
nFT = (uint8)((nOpcode >> 16) & 0x001F);
|
|
|
|
nFS = (uint8)((nOpcode >> 11) & 0x001F);
|
|
|
|
nFD = (uint8)((nOpcode >> 6) & 0x001F);
|
|
|
|
|
|
|
|
nBc = (uint8)((nOpcode >> 0) & 0x0003);
|
|
|
|
nDest = (uint8)((nOpcode >> 21) & 0x000F);
|
|
|
|
|
|
|
|
sprintf(sText, "VF%i%s, VF%i%s, VF%i%s", nFD, m_sDestination[nDest], nFS, m_sDestination[nDest], nFT, m_sBroadcast[nBc]);
|
|
|
|
}
|
|
|
|
|
|
|
|
void VUShared::ReflOpFtFs(INSTRUCTION* pInstr, CMIPS* pCtx, uint32 nAddress, uint32 nOpcode, char* sText, unsigned int nCount)
|
|
|
|
{
|
|
|
|
uint8 nFT, nFS;
|
|
|
|
uint8 nDest;
|
|
|
|
|
|
|
|
nFT = (uint8)((nOpcode >> 16) & 0x001F);
|
|
|
|
nFS = (uint8)((nOpcode >> 11) & 0x001F);
|
|
|
|
|
|
|
|
nDest = (uint8)((nOpcode >> 21) & 0x000F);
|
|
|
|
|
|
|
|
sprintf(sText, "VF%i%s, VF%i%s", nFT, m_sDestination[nDest], nFS, m_sDestination[nDest]);
|
|
|
|
}
|
|
|
|
|
|
|
|
void VUShared::ReflOpClip(INSTRUCTION* pInstr, CMIPS* pCtx, uint32 nAddress, uint32 nOpcode, char* sText, unsigned int nCount)
|
|
|
|
{
|
|
|
|
uint8 nFT, nFS;
|
|
|
|
|
|
|
|
nFT = (uint8)((nOpcode >> 16) & 0x001F);
|
|
|
|
nFS = (uint8)((nOpcode >> 11) & 0x001F);
|
|
|
|
|
|
|
|
sprintf(sText, "VF%ixyz, VF%iw", nFS, nFT);
|
|
|
|
}
|
|
|
|
|
|
|
|
void VUShared::ReflOpAccFsI(INSTRUCTION* pInstr, CMIPS* pCtx, uint32 nAddress, uint32 nOpcode, char* sText, unsigned int nCount)
|
|
|
|
{
|
|
|
|
uint8 nFS;
|
|
|
|
uint8 nDest;
|
|
|
|
|
|
|
|
nFS = (uint8)((nOpcode >> 11) & 0x001F);
|
|
|
|
|
|
|
|
nDest = (uint8)((nOpcode >> 21) & 0x000F);
|
|
|
|
|
|
|
|
sprintf(sText, "ACC%s, VF%i%s, I", m_sDestination[nDest], nFS, m_sDestination[nDest]);
|
|
|
|
}
|
|
|
|
|
|
|
|
void VUShared::ReflOpAccFsFt(INSTRUCTION* pInstr, CMIPS* pCtx, uint32 nAddress, uint32 nOpcode, char* sText, unsigned int nCount)
|
|
|
|
{
|
|
|
|
uint8 nFT, nFS;
|
|
|
|
uint8 nDest;
|
|
|
|
|
|
|
|
nFT = (uint8)((nOpcode >> 16) & 0x001F);
|
|
|
|
nFS = (uint8)((nOpcode >> 11) & 0x001F);
|
|
|
|
|
|
|
|
nDest = (uint8)((nOpcode >> 21) & 0x000F);
|
|
|
|
|
|
|
|
sprintf(sText, "ACC%s, VF%i%s, VF%i%s", m_sDestination[nDest], nFS, m_sDestination[nDest], nFT, m_sDestination[nDest]);
|
|
|
|
}
|
|
|
|
|
|
|
|
void VUShared::ReflOpAccFsFtBc(INSTRUCTION* pInstr, CMIPS* pCtx, uint32 nAddress, uint32 nOpcode, char* sText, unsigned int nCount)
|
|
|
|
{
|
|
|
|
uint8 nFT, nFS;
|
|
|
|
uint8 nBc, nDest;
|
|
|
|
|
|
|
|
nFT = (uint8)((nOpcode >> 16) & 0x001F);
|
|
|
|
nFS = (uint8)((nOpcode >> 11) & 0x001F);
|
|
|
|
|
|
|
|
nBc = (uint8)((nOpcode >> 0) & 0x0003);
|
|
|
|
nDest = (uint8)((nOpcode >> 21) & 0x000F);
|
|
|
|
|
|
|
|
sprintf(sText, "ACC%s, VF%i%s, VF%i%s", m_sDestination[nDest], nFS, m_sDestination[nDest], nFT, m_sBroadcast[nBc]);
|
|
|
|
}
|
|
|
|
|
2006-06-19 05:43:51 +00:00
|
|
|
void VUShared::ReflOpRFsf(INSTRUCTION* pInstr, CMIPS* pCtx, uint32 nAddress, uint32 nOpcode, char* sText, unsigned int nCount)
|
|
|
|
{
|
|
|
|
uint8 nFS, nFSF;
|
|
|
|
|
|
|
|
nFS = (uint8 )((nOpcode >> 11) & 0x001F);
|
|
|
|
nFSF = (uint8 )((nOpcode >> 21) & 0x0003);
|
|
|
|
|
|
|
|
sprintf(sText, "R, VF%i%s", nFS, m_sBroadcast[nFSF]);
|
|
|
|
}
|
|
|
|
|
|
|
|
void VUShared::ReflOpFtR(INSTRUCTION* pInstr, CMIPS* pCtx, uint32 nAddress, uint32 nOpcode, char* sText, unsigned int nCount)
|
|
|
|
{
|
|
|
|
uint8 nFT, nDest;
|
|
|
|
|
|
|
|
nDest = (uint8 )((nOpcode >> 21) & 0x000F);
|
|
|
|
nFT = (uint8 )((nOpcode >> 16) & 0x001F);
|
|
|
|
|
|
|
|
sprintf(sText, "VF%i%s, R", nFT, m_sDestination[nDest]);
|
|
|
|
}
|
|
|
|
|
2006-06-15 04:19:30 +00:00
|
|
|
void VUShared::ReflOpQFtf(INSTRUCTION* pInstr, CMIPS* pCtx, uint32 nAddress, uint32 nOpcode, char* sText, unsigned int nCount)
|
|
|
|
{
|
|
|
|
uint8 nFT;
|
|
|
|
uint8 nFTF;
|
|
|
|
|
|
|
|
nFT = (uint8)((nOpcode >> 16) & 0x001F);
|
|
|
|
|
|
|
|
nFTF = (uint8)((nOpcode >> 23) & 0x0003);
|
|
|
|
|
|
|
|
sprintf(sText, "Q, VF%i%s", nFT, m_sBroadcast[nFTF]);
|
|
|
|
}
|
|
|
|
|
|
|
|
void VUShared::ReflOpQFsfFtf(INSTRUCTION* pInstr, CMIPS* pCtx, uint32 nAddress, uint32 nOpcode, char* sText, unsigned int nCount)
|
|
|
|
{
|
|
|
|
uint8 nFT, nFS;
|
|
|
|
uint8 nFTF, nFSF;
|
|
|
|
|
|
|
|
nFT = (uint8)((nOpcode >> 16) & 0x001F);
|
|
|
|
nFS = (uint8)((nOpcode >> 11) & 0x001F);
|
|
|
|
|
|
|
|
nFTF = (uint8)((nOpcode >> 23) & 0x0003);
|
|
|
|
nFSF = (uint8)((nOpcode >> 21) & 0x0003);
|
|
|
|
|
|
|
|
sprintf(sText, "Q, VF%i%s, VF%i%s", nFS, m_sBroadcast[nFSF], nFT, m_sBroadcast[nFTF]);
|
|
|
|
}
|
2009-06-06 15:38:03 +00:00
|
|
|
|
|
|
|
////////////////////////////////////////////
|
|
|
|
|
|
|
|
VUShared::VUINSTRUCTION* VUShared::DereferenceInstruction(VUSUBTABLE* pSubTable, uint32 nOpcode)
|
|
|
|
{
|
|
|
|
unsigned int nIndex = (nOpcode >> pSubTable->nShift) & pSubTable->nMask;
|
|
|
|
return &(pSubTable->pTable[nIndex]);
|
|
|
|
}
|
|
|
|
|
|
|
|
void VUShared::SubTableAffectedOperands(VUINSTRUCTION* pInstr, CMIPS* pCtx, uint32 nAddress, uint32 nOpcode, OPERANDSET& operandSet)
|
|
|
|
{
|
|
|
|
pInstr = DereferenceInstruction(pInstr->subTable, nOpcode);
|
|
|
|
if(pInstr->pGetAffectedOperands == NULL)
|
|
|
|
{
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
pInstr->pGetAffectedOperands(pInstr, pCtx, nAddress, nOpcode, operandSet);
|
|
|
|
}
|
|
|
|
|
|
|
|
void VUShared::ReflOpAffAccFsI(VUINSTRUCTION* pInstr, CMIPS* pCtx, uint32 nAddress, uint32 nOpcode, OPERANDSET& operandSet)
|
|
|
|
{
|
|
|
|
uint8 nFS = (uint8)((nOpcode >> 11) & 0x001F);
|
|
|
|
|
|
|
|
operandSet.readF0 = nFS;
|
|
|
|
}
|
|
|
|
|
|
|
|
void VUShared::ReflOpAffAccFsFt(VUINSTRUCTION* pInstr, CMIPS* pCtx, uint32 nAddress, uint32 nOpcode, OPERANDSET& operandSet)
|
|
|
|
{
|
|
|
|
uint8 nFT = (uint8)((nOpcode >> 16) & 0x001F);
|
|
|
|
uint8 nFS = (uint8)((nOpcode >> 11) & 0x001F);
|
|
|
|
|
|
|
|
operandSet.readF0 = nFS;
|
|
|
|
operandSet.readF1 = nFT;
|
|
|
|
}
|
|
|
|
|
|
|
|
void VUShared::ReflOpAffAccFsFtBc(VUINSTRUCTION* pInstr, CMIPS* pCtx, uint32 nAddress, uint32 nOpcode, OPERANDSET& operandSet)
|
|
|
|
{
|
|
|
|
uint8 nFT = (uint8)((nOpcode >> 16) & 0x001F);
|
|
|
|
uint8 nFS = (uint8)((nOpcode >> 11) & 0x001F);
|
|
|
|
|
|
|
|
operandSet.readF0 = nFS;
|
|
|
|
operandSet.readF1 = nFT;
|
|
|
|
}
|
|
|
|
|
|
|
|
void VUShared::ReflOpAffFdFsFt(VUINSTRUCTION* pInstr, CMIPS* pCtx, uint32 nAddress, uint32 nOpcode, OPERANDSET& operandSet)
|
|
|
|
{
|
|
|
|
uint8 nFT = (uint8)((nOpcode >> 16) & 0x001F);
|
|
|
|
uint8 nFS = (uint8)((nOpcode >> 11) & 0x001F);
|
|
|
|
uint8 nFD = (uint8)((nOpcode >> 6) & 0x001F);
|
|
|
|
|
|
|
|
operandSet.readF0 = nFS;
|
|
|
|
operandSet.readF1 = nFT;
|
|
|
|
operandSet.writeF = nFD;
|
|
|
|
}
|
|
|
|
|
|
|
|
void VUShared::ReflOpAffFdFsFtBc(VUINSTRUCTION* pInstr, CMIPS* pCtx, uint32 nAddress, uint32 nOpcode, OPERANDSET& operandSet)
|
|
|
|
{
|
|
|
|
uint8 nFT = (uint8)((nOpcode >> 16) & 0x001F);
|
|
|
|
uint8 nFS = (uint8)((nOpcode >> 11) & 0x001F);
|
|
|
|
uint8 nFD = (uint8)((nOpcode >> 6) & 0x001F);
|
|
|
|
|
|
|
|
operandSet.readF0 = nFS;
|
|
|
|
operandSet.readF1 = nFT;
|
|
|
|
operandSet.writeF = nFD;
|
|
|
|
}
|
|
|
|
|
|
|
|
void VUShared::ReflOpAffFdFsQ(VUINSTRUCTION* pInstr, CMIPS* pCtx, uint32 nAddress, uint32 nOpcode, OPERANDSET& operandSet)
|
|
|
|
{
|
|
|
|
uint8 nFS = (uint8)((nOpcode >> 11) & 0x001F);
|
|
|
|
uint8 nFD = (uint8)((nOpcode >> 6) & 0x001F);
|
|
|
|
|
|
|
|
operandSet.readF0 = nFS;
|
|
|
|
operandSet.writeF = nFD;
|
|
|
|
}
|
|
|
|
|
|
|
|
void VUShared::ReflOpAffFdFsI(VUINSTRUCTION* pInstr, CMIPS* pCtx, uint32 nAddress, uint32 nOpcode, OPERANDSET& operandSet)
|
|
|
|
{
|
|
|
|
uint8 nFS = (uint8)((nOpcode >> 11) & 0x001F);
|
|
|
|
uint8 nFD = (uint8)((nOpcode >> 6) & 0x001F);
|
|
|
|
|
|
|
|
operandSet.readF0 = nFS;
|
|
|
|
operandSet.writeF = nFD;
|
|
|
|
}
|
|
|
|
|
|
|
|
void VUShared::ReflOpAffFtFs(VUINSTRUCTION* pInstr, CMIPS* pCtx, uint32 nAddress, uint32 nOpcode, OPERANDSET& operandSet)
|
|
|
|
{
|
|
|
|
uint8 nFT = (uint8)((nOpcode >> 16) & 0x001F);
|
|
|
|
uint8 nFS = (uint8)((nOpcode >> 11) & 0x001F);
|
|
|
|
|
|
|
|
operandSet.readF0 = nFS;
|
|
|
|
operandSet.writeF = nFT;
|
|
|
|
}
|
|
|
|
|
|
|
|
void VUShared::ReflOpAffRFsf(VUINSTRUCTION* pInstr, CMIPS* pCtx, uint32 nAddress, uint32 nOpcode, OPERANDSET& operandSet)
|
|
|
|
{
|
|
|
|
uint8 nFS = (uint8 )((nOpcode >> 11) & 0x001F);
|
|
|
|
operandSet.readF0 = nFS;
|
|
|
|
}
|
|
|
|
|
|
|
|
void VUShared::ReflOpAffFtR(VUINSTRUCTION* pInstr, CMIPS* pCtx, uint32 nAddress, uint32 nOpcode, OPERANDSET& operandSet)
|
|
|
|
{
|
|
|
|
uint8 nFT = (uint8 )((nOpcode >> 16) & 0x001F);
|
|
|
|
|
|
|
|
operandSet.writeF = nFT;
|
|
|
|
}
|
|
|
|
|
|
|
|
void VUShared::ReflOpAffQFsfFtf(VUINSTRUCTION* pInstr, CMIPS* pCtx, uint32 nAddress, uint32 nOpcode, OPERANDSET& operandSet)
|
|
|
|
{
|
|
|
|
uint8 nFT = (uint8)((nOpcode >> 16) & 0x001F);
|
|
|
|
uint8 nFS = (uint8)((nOpcode >> 11) & 0x001F);
|
|
|
|
|
|
|
|
operandSet.readF0 = nFT;
|
|
|
|
operandSet.readF1 = nFS;
|
|
|
|
}
|