Vif: Cleanup code a bit.

Const, casts, nullptr.
This commit is contained in:
lightningterror 2024-11-24 19:31:06 +01:00
parent b0496645f1
commit 1b80f3aea2
6 changed files with 52 additions and 52 deletions

View File

@ -33,7 +33,7 @@ bool _VIF0chain()
} }
pMem = (u32*)dmaGetAddr(vif0ch.madr, false); pMem = (u32*)dmaGetAddr(vif0ch.madr, false);
if (pMem == NULL) if (pMem == nullptr)
{ {
vif0.cmd = 0; vif0.cmd = 0;
vif0.tag.size = 0; vif0.tag.size = 0;

View File

@ -27,7 +27,7 @@ void vif1TransferToMemory()
u128* pMem = (u128*)dmaGetAddr(vif1ch.madr, false); u128* pMem = (u128*)dmaGetAddr(vif1ch.madr, false);
// VIF from gsMemory // VIF from gsMemory
if (pMem == NULL) if (pMem == nullptr)
{ // Is vif0ptag empty? { // Is vif0ptag empty?
Console.WriteLn("Vif1 Tag BUSERR"); Console.WriteLn("Vif1 Tag BUSERR");
dmacRegs.stat.BEIS = true; // Bus Error dmacRegs.stat.BEIS = true; // Bus Error
@ -117,7 +117,7 @@ bool _VIF1chain()
} }
pMem = (u32*)dmaGetAddr(vif1ch.madr, !vif1ch.chcr.DIR); pMem = (u32*)dmaGetAddr(vif1ch.madr, !vif1ch.chcr.DIR);
if (pMem == NULL) if (pMem == nullptr)
{ {
vif1.cmd = 0; vif1.cmd = 0;
vif1.tag.size = 0; vif1.tag.size = 0;
@ -305,8 +305,8 @@ __fi void vif1Interrupt()
// from the GS then we handle that separately (KH2 for testing) // from the GS then we handle that separately (KH2 for testing)
if (vif1ch.chcr.DIR) if (vif1ch.chcr.DIR)
{ {
bool isDirect = (vif1.cmd & 0x7f) == 0x50; const bool isDirect = (vif1.cmd & 0x7f) == 0x50;
bool isDirectHL = (vif1.cmd & 0x7f) == 0x51; const bool isDirectHL = (vif1.cmd & 0x7f) == 0x51;
if ((isDirect && !gifUnit.CanDoPath2()) || (isDirectHL && !gifUnit.CanDoPath2HL())) if ((isDirect && !gifUnit.CanDoPath2()) || (isDirectHL && !gifUnit.CanDoPath2HL()))
{ {
GUNIT_WARN("vif1Interrupt() - Waiting for Path 2 to be ready"); GUNIT_WARN("vif1Interrupt() - Waiting for Path 2 to be ready");

View File

@ -23,7 +23,7 @@ static u32 QWCinVIFMFIFO(u32 DrainADDR, u32 qwc)
} }
else else
{ {
u32 limit = dmacRegs.rbor.ADDR + dmacRegs.rbsr.RMSK + 16; const u32 limit = dmacRegs.rbor.ADDR + dmacRegs.rbsr.RMSK + 16;
//Drain is higher than SPR so it has looped round, //Drain is higher than SPR so it has looped round,
//calculate from base to the SPR tag addr and what is left in the top of the ring //calculate from base to the SPR tag addr and what is left in the top of the ring
ret = ((spr0ch.madr - dmacRegs.rbor.ADDR) + (limit - DrainADDR)) >> 4; ret = ((spr0ch.madr - dmacRegs.rbor.ADDR) + (limit - DrainADDR)) >> 4;
@ -35,8 +35,8 @@ static u32 QWCinVIFMFIFO(u32 DrainADDR, u32 qwc)
} }
static __fi bool mfifoVIF1rbTransfer() static __fi bool mfifoVIF1rbTransfer()
{ {
u32 msize = dmacRegs.rbor.ADDR + dmacRegs.rbsr.RMSK + 16; const u32 msize = dmacRegs.rbor.ADDR + dmacRegs.rbsr.RMSK + 16;
u32 mfifoqwc = std::min(QWCinVIFMFIFO(vif1ch.madr, vif1ch.qwc), vif1ch.qwc); const u32 mfifoqwc = std::min(QWCinVIFMFIFO(vif1ch.madr, vif1ch.qwc), vif1ch.qwc);
u32* src; u32* src;
bool ret; bool ret;
@ -49,7 +49,7 @@ static __fi bool mfifoVIF1rbTransfer()
/* Check if the transfer should wrap around the ring buffer */ /* Check if the transfer should wrap around the ring buffer */
if ((vif1ch.madr + (mfifoqwc << 4)) > (msize)) if ((vif1ch.madr + (mfifoqwc << 4)) > (msize))
{ {
int s1 = ((msize)-vif1ch.madr) >> 2; const int s1 = ((msize)-vif1ch.madr) >> 2;
VIF_LOG("Split MFIFO"); VIF_LOG("Split MFIFO");
@ -57,7 +57,7 @@ static __fi bool mfifoVIF1rbTransfer()
vif1ch.madr = qwctag(vif1ch.madr); vif1ch.madr = qwctag(vif1ch.madr);
src = (u32*)PSM(vif1ch.madr); src = (u32*)PSM(vif1ch.madr);
if (src == NULL) if (src == nullptr)
return false; return false;
if (vif1.irqoffset.enabled) if (vif1.irqoffset.enabled)
@ -75,7 +75,7 @@ static __fi bool mfifoVIF1rbTransfer()
vif1ch.madr = qwctag(vif1ch.madr); vif1ch.madr = qwctag(vif1ch.madr);
src = (u32*)PSM(vif1ch.madr); src = (u32*)PSM(vif1ch.madr);
if (src == NULL) if (src == nullptr)
return false; return false;
VIF1transfer(src, ((mfifoqwc << 2) - s1)); VIF1transfer(src, ((mfifoqwc << 2) - s1));
} }
@ -86,7 +86,7 @@ static __fi bool mfifoVIF1rbTransfer()
/* it doesn't, so just transfer 'qwc*4' words */ /* it doesn't, so just transfer 'qwc*4' words */
src = (u32*)PSM(vif1ch.madr); src = (u32*)PSM(vif1ch.madr);
if (src == NULL) if (src == nullptr)
return false; return false;
if (vif1.irqoffset.enabled) if (vif1.irqoffset.enabled)
@ -133,7 +133,7 @@ static __fi void mfifo_VIF1chain()
//No need to exit on non-mfifo as it is indirect anyway, so it can be transferring this while spr refills the mfifo //No need to exit on non-mfifo as it is indirect anyway, so it can be transferring this while spr refills the mfifo
if (pMem == NULL) if (pMem == nullptr)
return; return;
if (vif1.irqoffset.enabled) if (vif1.irqoffset.enabled)
@ -158,7 +158,7 @@ void mfifoVifMaskMem(int id)
//DevCon.Warning("VIF MFIFO MADR below bottom of ring buffer, wrapping VIF MADR = %x Ring Bottom %x", vif1ch.madr, dmacRegs.rbor.ADDR); //DevCon.Warning("VIF MFIFO MADR below bottom of ring buffer, wrapping VIF MADR = %x Ring Bottom %x", vif1ch.madr, dmacRegs.rbor.ADDR);
vif1ch.madr = qwctag(vif1ch.madr); vif1ch.madr = qwctag(vif1ch.madr);
} }
if (vif1ch.madr > (dmacRegs.rbor.ADDR + (u32)dmacRegs.rbsr.RMSK)) //Usual scenario is the tag is near the end (Front Mission 4) if (vif1ch.madr > (dmacRegs.rbor.ADDR + static_cast<u32>(dmacRegs.rbsr.RMSK))) //Usual scenario is the tag is near the end (Front Mission 4)
{ {
//DevCon.Warning("VIF MFIFO MADR outside top of ring buffer, wrapping VIF MADR = %x Ring Top %x", vif1ch.madr, (dmacRegs.rbor.ADDR + dmacRegs.rbsr.RMSK)+16); //DevCon.Warning("VIF MFIFO MADR outside top of ring buffer, wrapping VIF MADR = %x Ring Top %x", vif1ch.madr, (dmacRegs.rbor.ADDR + dmacRegs.rbsr.RMSK)+16);
vif1ch.madr = qwctag(vif1ch.madr); vif1ch.madr = qwctag(vif1ch.madr);
@ -281,8 +281,8 @@ void vifMFIFOInterrupt()
if (vif1ch.chcr.DIR) if (vif1ch.chcr.DIR)
{ {
bool isDirect = (vif1.cmd & 0x7f) == 0x50; const bool isDirect = (vif1.cmd & 0x7f) == 0x50;
bool isDirectHL = (vif1.cmd & 0x7f) == 0x51; const bool isDirectHL = (vif1.cmd & 0x7f) == 0x51;
if ((isDirect && !gifUnit.CanDoPath2()) || (isDirectHL && !gifUnit.CanDoPath2HL())) if ((isDirect && !gifUnit.CanDoPath2()) || (isDirectHL && !gifUnit.CanDoPath2HL()))
{ {
GUNIT_WARN("vifMFIFOInterrupt() - Waiting for Path 2 to be ready"); GUNIT_WARN("vifMFIFOInterrupt() - Waiting for Path 2 to be ready");

View File

@ -109,7 +109,7 @@ static __fi void vuExecMicro(int idx, u32 addr, bool requires_wait)
} }
GetVifX.queued_program = true; GetVifX.queued_program = true;
if ((s32)addr == -1) if (static_cast<s32>(addr) == -1)
GetVifX.queued_pc = addr; GetVifX.queued_pc = addr;
else else
GetVifX.queued_pc = addr & (idx ? 0x7ffu : 0x1ffu); GetVifX.queued_pc = addr & (idx ? 0x7ffu : 0x1ffu);
@ -144,7 +144,7 @@ __fi int _vifCode_Direct(int pass, const u8* data, bool isDirectHL)
vif1Only(); vif1Only();
pass1 pass1
{ {
int vifImm = (u16)vif1Regs.code; const int vifImm = static_cast<u16>(vif1Regs.code);
vif1.tag.size = vifImm ? (vifImm * 4) : (65536 * 4); vif1.tag.size = vifImm ? (vifImm * 4) : (65536 * 4);
vif1.pass = 1; vif1.pass = 1;
return 1; return 1;
@ -152,9 +152,9 @@ __fi int _vifCode_Direct(int pass, const u8* data, bool isDirectHL)
pass2 pass2
{ {
const char* name = isDirectHL ? "DirectHL" : "Direct"; const char* name = isDirectHL ? "DirectHL" : "Direct";
GIF_TRANSFER_TYPE tranType = isDirectHL ? GIF_TRANS_DIRECTHL : GIF_TRANS_DIRECT; const GIF_TRANSFER_TYPE tranType = isDirectHL ? GIF_TRANS_DIRECTHL : GIF_TRANS_DIRECT;
uint size = std::min(vif1.vifpacketsize, vif1.tag.size) * 4; // Get size in bytes const uint size = std::min(vif1.vifpacketsize, vif1.tag.size) * 4; // Get size in bytes
uint ret = gifUnit.TransferGSPacketData(tranType, (u8*)data, size); const uint ret = gifUnit.TransferGSPacketData(tranType, (u8*)data, size);
vif1.tag.size -= ret / 4; // Convert to u32's vif1.tag.size -= ret / 4; // Convert to u32's
vif1Regs.stat.VGW = false; vif1Regs.stat.VGW = false;
@ -202,7 +202,7 @@ vifOp(vifCode_Flush)
//vifStruct& vifX = GetVifX; //vifStruct& vifX = GetVifX;
pass1or2 pass1or2
{ {
bool p1or2 = (gifRegs.stat.APATH != 0 && gifRegs.stat.APATH != 3); const bool p1or2 = (gifRegs.stat.APATH != 0 && gifRegs.stat.APATH != 3);
vif1Regs.stat.VGW = false; vif1Regs.stat.VGW = false;
vifFlush(idx); vifFlush(idx);
if (gifUnit.checkPaths(1, 1, 0) || p1or2) if (gifUnit.checkPaths(1, 1, 0) || p1or2)
@ -234,7 +234,7 @@ vifOp(vifCode_FlushA)
pass1or2 pass1or2
{ {
//Gif_Path& p3 = gifUnit.gifPath[GIF_PATH_3]; //Gif_Path& p3 = gifUnit.gifPath[GIF_PATH_3];
u32 gifBusy = gifUnit.checkPaths(1, 1, 1) || (gifRegs.stat.APATH != 0); const u32 gifBusy = gifUnit.checkPaths(1, 1, 1) || (gifRegs.stat.APATH != 0);
//bool doStall = false; //bool doStall = false;
vif1Regs.stat.VGW = false; vif1Regs.stat.VGW = false;
vifFlush(idx); vifFlush(idx);
@ -298,7 +298,7 @@ vifOp(vifCode_Mark)
vifStruct& vifX = GetVifX; vifStruct& vifX = GetVifX;
pass1 pass1
{ {
vifXRegs.mark = (u16)vifXRegs.code; vifXRegs.mark = static_cast<u16>(vifXRegs.code);
vifXRegs.stat.MRK = true; vifXRegs.stat.MRK = true;
vifX.cmd = 0; vifX.cmd = 0;
vifX.pass = 0; vifX.pass = 0;
@ -311,7 +311,7 @@ static __fi void _vifCode_MPG(int idx, u32 addr, const u32* data, int size)
{ {
VURegs& VUx = idx ? VU1 : VU0; VURegs& VUx = idx ? VU1 : VU0;
vifStruct& vifX = GetVifX; vifStruct& vifX = GetVifX;
u16 vuMemSize = idx ? 0x4000 : 0x1000; const u16 vuMemSize = idx ? 0x4000 : 0x1000;
pxAssert(VUx.Micro); pxAssert(VUx.Micro);
vifExecQueue(idx); vifExecQueue(idx);
@ -371,8 +371,8 @@ vifOp(vifCode_MPG)
vifStruct& vifX = GetVifX; vifStruct& vifX = GetVifX;
pass1 pass1
{ {
int vifNum = (u8)(vifXRegs.code >> 16); const int vifNum = static_cast<u8>(vifXRegs.code >> 16);
vifX.tag.addr = (u16)(vifXRegs.code << 3) & (idx ? 0x3fff : 0xfff); vifX.tag.addr = static_cast<u16>(vifXRegs.code << 3) & (idx ? 0x3fff : 0xfff);
vifX.tag.size = vifNum ? (vifNum * 2) : 512; vifX.tag.size = vifNum ? (vifNum * 2) : 512;
vifFlush(idx); vifFlush(idx);
@ -406,7 +406,7 @@ vifOp(vifCode_MPG)
//DevCon.Warning("Vif%d MPG Split Overflow full %x", idx, vifX.tag.addr + vifX.tag.size*4); //DevCon.Warning("Vif%d MPG Split Overflow full %x", idx, vifX.tag.addr + vifX.tag.size*4);
} }
_vifCode_MPG(idx, vifX.tag.addr, data, vifX.tag.size); _vifCode_MPG(idx, vifX.tag.addr, data, vifX.tag.size);
int ret = vifX.tag.size; const int ret = vifX.tag.size;
vifX.tag.size = 0; vifX.tag.size = 0;
vifX.cmd = 0; vifX.cmd = 0;
vifX.pass = 0; vifX.pass = 0;
@ -430,7 +430,7 @@ vifOp(vifCode_MSCAL)
return 0; return 0;
} }
vuExecMicro(idx, (u16)(vifXRegs.code), false); vuExecMicro(idx, static_cast<u16>(vifXRegs.code), false);
vifX.cmd = 0; vifX.cmd = 0;
vifX.pass = 0; vifX.pass = 0;
@ -455,7 +455,7 @@ vifOp(vifCode_MSCALF)
{ {
vifXRegs.stat.VGW = false; vifXRegs.stat.VGW = false;
vifFlush(idx); vifFlush(idx);
if (u32 a = gifUnit.checkPaths(1, 1, 0)) if (const u32 a = gifUnit.checkPaths(1, 1, 0))
{ {
GUNIT_WARN("Vif MSCALF: Stall! [%d,%d]", !!(a & 1), !!(a & 2)); GUNIT_WARN("Vif MSCALF: Stall! [%d,%d]", !!(a & 1), !!(a & 2));
vif1Regs.stat.VGW = true; vif1Regs.stat.VGW = true;
@ -469,7 +469,7 @@ vifOp(vifCode_MSCALF)
return 0; return 0;
} }
vuExecMicro(idx, (u16)(vifXRegs.code), true); vuExecMicro(idx, static_cast<u16>(vifXRegs.code), true);
vifX.cmd = 0; vifX.cmd = 0;
vifX.pass = 0; vifX.pass = 0;
vifExecQueue(idx); vifExecQueue(idx);
@ -595,7 +595,7 @@ static __fi int _vifCode_STColRow(const u32* data, u32* pmem2)
{ {
vifStruct& vifX = GetVifX; vifStruct& vifX = GetVifX;
int ret = std::min(4 - vifX.tag.addr, vifX.vifpacketsize); const int ret = std::min(4 - vifX.tag.addr, vifX.vifpacketsize);
pxAssume(vifX.tag.addr < 4); pxAssume(vifX.tag.addr < 4);
pxAssume(ret > 0); pxAssume(ret > 0);
@ -641,7 +641,7 @@ vifOp(vifCode_STCol)
} }
pass2 pass2
{ {
u32 ret = _vifCode_STColRow<idx>(data, &vifX.MaskCol._u32[vifX.tag.addr]); const u32 ret = _vifCode_STColRow<idx>(data, &vifX.MaskCol._u32[vifX.tag.addr]);
if (idx && vifX.tag.size == 0) if (idx && vifX.tag.size == 0)
vu1Thread.WriteCol(vifX); vu1Thread.WriteCol(vifX);
return ret; return ret;
@ -662,7 +662,7 @@ vifOp(vifCode_STRow)
} }
pass2 pass2
{ {
u32 ret = _vifCode_STColRow<idx>(data, &vifX.MaskRow._u32[vifX.tag.addr]); const u32 ret = _vifCode_STColRow<idx>(data, &vifX.MaskRow._u32[vifX.tag.addr]);
if (idx && vifX.tag.size == 0) if (idx && vifX.tag.size == 0)
vu1Thread.WriteRow(vifX); vu1Thread.WriteRow(vifX);
return ret; return ret;
@ -676,8 +676,8 @@ vifOp(vifCode_STCycl)
vifStruct& vifX = GetVifX; vifStruct& vifX = GetVifX;
pass1 pass1
{ {
vifXRegs.cycle.cl = (u8)(vifXRegs.code); vifXRegs.cycle.cl = static_cast<u8>(vifXRegs.code);
vifXRegs.cycle.wl = (u8)(vifXRegs.code >> 8); vifXRegs.cycle.wl = static_cast<u8>(vifXRegs.code >> 8);
vifX.cmd = 0; vifX.cmd = 0;
vifX.pass = 0; vifX.pass = 0;
} }
@ -744,9 +744,9 @@ vifOp(vifCode_Unpack)
{ {
vifStruct& vifX = GetVifX; vifStruct& vifX = GetVifX;
VIFregisters& vifRegs = vifXRegs; VIFregisters& vifRegs = vifXRegs;
uint vl = vifX.cmd & 0x03; const uint vl = vifX.cmd & 0x03;
uint vn = (vifX.cmd >> 2) & 0x3; const uint vn = (vifX.cmd >> 2) & 0x3;
bool flg = (vifRegs.code >> 15) & 1; const bool flg = (vifRegs.code >> 15) & 1;
static const char* const vntbl[] = {"S", "V2", "V3", "V4"}; static const char* const vntbl[] = {"S", "V2", "V3", "V4"};
static const uint vltbl[] = {32, 16, 8, 5}; static const uint vltbl[] = {32, 16, 8, 5};

View File

@ -46,9 +46,9 @@ __fi void VifUnpackSSE_Dynarec::SetMasks(int cS) const
const vifStruct& vif = MTVU_VifX; const vifStruct& vif = MTVU_VifX;
//This could have ended up copying the row when there was no row to write.1810080 //This could have ended up copying the row when there was no row to write.1810080
u32 m0 = vB.mask; //The actual mask example 0x03020100 const u32 m0 = vB.mask; //The actual mask example 0x03020100
u32 m3 = ((m0 & 0xaaaaaaaa) >> 1) & ~m0; //all the upper bits, so our example 0x01010000 & 0xFCFDFEFF = 0x00010000 just the cols (shifted right for maskmerge) const u32 m3 = ((m0 & 0xaaaaaaaa) >> 1) & ~m0; //all the upper bits, so our example 0x01010000 & 0xFCFDFEFF = 0x00010000 just the cols (shifted right for maskmerge)
u32 m2 = (m0 & 0x55555555) & (~m0 >> 1); // 0x1000100 & 0xFE7EFF7F = 0x00000100 Just the row const u32 m2 = (m0 & 0x55555555) & (~m0 >> 1); // 0x1000100 & 0xFE7EFF7F = 0x00000100 Just the row
if ((doMask && m2) || doMode) if ((doMask && m2) || doMode)
{ {
@ -73,7 +73,7 @@ void VifUnpackSSE_Dynarec::doMaskWrite(const xRegisterSSE& regX) const
pxAssertMsg(regX.Id <= 1, "Reg Overflow! XMM2 thru XMM6 are reserved for masking."); pxAssertMsg(regX.Id <= 1, "Reg Overflow! XMM2 thru XMM6 are reserved for masking.");
const int cc = std::min(vCL, 3); const int cc = std::min(vCL, 3);
u32 m0 = (vB.mask >> (cc * 8)) & 0xff; //The actual mask example 0xE4 (protect, col, row, clear) const u32 m0 = (vB.mask >> (cc * 8)) & 0xff; //The actual mask example 0xE4 (protect, col, row, clear)
u32 m3 = ((m0 & 0xaa) >> 1) & ~m0; //all the upper bits (cols shifted right) cancelling out any write protects 0x10 u32 m3 = ((m0 & 0xaa) >> 1) & ~m0; //all the upper bits (cols shifted right) cancelling out any write protects 0x10
u32 m2 = (m0 & 0x55) & (~m0 >> 1); // all the lower bits (rows)cancelling out any write protects 0x04 u32 m2 = (m0 & 0x55) & (~m0 >> 1); // all the lower bits (rows)cancelling out any write protects 0x04
u32 m4 = (m0 & ~((m3 << 1) | m2)) & 0x55; // = 0xC0 & 0x55 = 0x40 (for merge mask) u32 m4 = (m0 & ~((m3 << 1) | m2)) & 0x55; // = 0xC0 & 0x55 = 0x40 (for merge mask)
@ -317,8 +317,8 @@ static u16 dVifComputeLength(uint cl, uint wl, u8 num, bool isFill)
if (!isFill) if (!isFill)
{ {
uint skipSize = (cl - wl) * 16; const uint skipSize = (cl - wl) * 16;
uint blocks = (num + (wl - 1)) / wl; //Need to round up num's to calculate skip size correctly. const uint blocks = (num + (wl - 1)) / wl; //Need to round up num's to calculate skip size correctly.
length += (blocks - 1) * skipSize; length += (blocks - 1) * skipSize;
} }
@ -370,15 +370,15 @@ _vifT __fi void dVifUnpack(const u8* data, bool isFill)
// in u32 (aka x86 register). // in u32 (aka x86 register).
// //
// Warning the order of data in hash_key/key0/key1 depends on the nVifBlock struct // Warning the order of data in hash_key/key0/key1 depends on the nVifBlock struct
u32 hash_key = (u32)(upkType & 0xFF) << 8 | (vifRegs.num & 0xFF); const u32 hash_key = static_cast<u32>(upkType & 0xFF) << 8 | (vifRegs.num & 0xFF);
u32 key1 = ((u32)vifRegs.cycle.wl << 24) | ((u32)vifRegs.cycle.cl << 16) | ((u32)(vif.start_aligned & 0xFF) << 8) | ((u32)vifRegs.mode & 0xFF); u32 key1 = (static_cast<u32>(vifRegs.cycle.wl) << 24) | (static_cast<u32>(vifRegs.cycle.cl) << 16) | (static_cast<u32>(vif.start_aligned & 0xFF) << 8) | (static_cast<u32>(vifRegs.mode) & 0xFF);
if ((upkType & 0xf) != 9) if ((upkType & 0xf) != 9)
key1 &= 0xFFFF01FF; key1 &= 0xFFFF01FF;
// Zero out the mask parameter if it's unused -- games leave random junk // Zero out the mask parameter if it's unused -- games leave random junk
// values here which cause false recblock cache misses. // values here which cause false recblock cache misses.
u32 key0 = doMask ? vifRegs.mask : 0; const u32 key0 = doMask ? vifRegs.mask : 0;
block.hash_key = hash_key; block.hash_key = hash_key;
block.key0 = key0; block.key0 = key0;
@ -397,7 +397,7 @@ _vifT __fi void dVifUnpack(const u8* data, bool isFill)
{ // Execute the block { // Execute the block
const VURegs& VU = vuRegs[idx]; const VURegs& VU = vuRegs[idx];
const uint vuMemLimit = idx ? 0x4000 : 0x1000; constexpr uint vuMemLimit = idx ? 0x4000 : 0x1000;
u8* startmem = VU.Mem + (vif.tag.addr & (vuMemLimit - 0x10)); u8* startmem = VU.Mem + (vif.tag.addr & (vuMemLimit - 0x10));
u8* endmem = VU.Mem + vuMemLimit; u8* endmem = VU.Mem + vuMemLimit;

View File

@ -222,7 +222,7 @@ void VifUnpackSSE_Base::xUPK_V3_16() const
//However - IF the end of this iteration of the unpack falls on a quadword boundary, W becomes 0 //However - IF the end of this iteration of the unpack falls on a quadword boundary, W becomes 0
//IsAligned is the position through the current QW in the vif packet //IsAligned is the position through the current QW in the vif packet
//Iteration counts where we are in the packet. //Iteration counts where we are in the packet.
int result = (((UnpkLoopIteration / 4) + 1 + (4 - IsAligned)) & 0x3); const int result = (((UnpkLoopIteration / 4) + 1 + (4 - IsAligned)) & 0x3);
if ((UnpkLoopIteration & 0x1) == 0 && result == 0) if ((UnpkLoopIteration & 0x1) == 0 && result == 0)
xBLEND.PS(destReg, zeroReg, 0x8); //zero last word - tested on ps2 xBLEND.PS(destReg, zeroReg, 0x8); //zero last word - tested on ps2
@ -330,7 +330,7 @@ VifUnpackSSE_Simple::VifUnpackSSE_Simple(bool usn_, bool domask_, int curCycle_)
void VifUnpackSSE_Simple::doMaskWrite(const xRegisterSSE& regX) const void VifUnpackSSE_Simple::doMaskWrite(const xRegisterSSE& regX) const
{ {
xMOVAPS(xmm7, ptr[dstIndirect]); xMOVAPS(xmm7, ptr[dstIndirect]);
int offX = std::min(curCycle, 3); const int offX = std::min(curCycle, 3);
xPAND(regX, ptr32[nVifMask[0][offX]]); xPAND(regX, ptr32[nVifMask[0][offX]]);
xPAND(xmm7, ptr32[nVifMask[1][offX]]); xPAND(xmm7, ptr32[nVifMask[1][offX]]);
xPOR (regX, ptr32[nVifMask[2][offX]]); xPOR (regX, ptr32[nVifMask[2][offX]]);
@ -349,7 +349,7 @@ static void nVifGen(int usn, int mask, int curCycle)
for (int i = 0; i < 16; ++i) for (int i = 0; i < 16; ++i)
{ {
nVifCall& ucall(nVifUpk[((usnpart + maskpart + i) * 4) + curCycle]); nVifCall& ucall(nVifUpk[((usnpart + maskpart + i) * 4) + curCycle]);
ucall = NULL; ucall = nullptr;
if (nVifT[i] == 0) if (nVifT[i] == 0)
continue; continue;