pcsx2/pcsx2/VUmicro.cpp

81 lines
2.0 KiB
C++

// SPDX-FileCopyrightText: 2002-2023 PCSX2 Dev Team
// SPDX-License-Identifier: LGPL-3.0+
#include "Common.h"
#include "VUmicro.h"
#include "MTVU.h"
#include "GS.h"
#include "Gif_Unit.h"
BaseVUmicroCPU* CpuVU0 = nullptr;
BaseVUmicroCPU* CpuVU1 = nullptr;
__inline u32 CalculateMinRunCycles(u32 cycles, bool requiresAccurateCycles)
{
// If we're running an interlocked COP2 operation
// run for an exact amount of cycles
if(requiresAccurateCycles)
return cycles;
// Allow a minimum of 16 cycles to avoid running small blocks
// Running a block of like 3 cycles is highly inefficient
// so while sync isn't tight, it's okay to run ahead a little bit.
return std::max(16U, cycles);
}
// Executes a Block based on EE delta time
void BaseVUmicroCPU::ExecuteBlock(bool startUp)
{
const u32& stat = VU0.VI[REG_VPU_STAT].UL;
const int test = m_Idx ? 0x100 : 1;
if (m_Idx && THREAD_VU1)
{
vu1Thread.Get_MTVUChanges();
return;
}
if (!(stat & test))
{
// VU currently flushes XGKICK on VU1 end so no need for this, yet
/*if (m_Idx == 1 && VU1.xgkickenable)
{
_vuXGKICKTransfer((cpuRegs.cycle - VU1.xgkicklastcycle), false);
}*/
return;
}
if (startUp)
{
Execute(CalculateMinRunCycles(0, false));
}
else // Continue Executing
{
u32 cycle = m_Idx ? VU1.cycle : VU0.cycle;
s32 delta = (s32)(u32)(cpuRegs.cycle - cycle);
if (delta > 0)
Execute(CalculateMinRunCycles(delta, false));
}
}
// This function is called by VU0 Macro (COP2) after transferring some
// EE data to VU0's registers. We want to run VU0 Micro right after this
// to ensure that the register is used at the correct time.
// This fixes spinning/hanging in some games like Ratchet and Clank's Intro.
void BaseVUmicroCPU::ExecuteBlockJIT(BaseVUmicroCPU* cpu, bool interlocked)
{
const u32& stat = VU0.VI[REG_VPU_STAT].UL;
constexpr int test = 1;
if (stat & test)
{ // VU is running
s32 delta = (s32)(u32)(cpuRegs.cycle - VU0.cycle);
if (delta > 0)
{
cpu->Execute(CalculateMinRunCycles(delta, interlocked)); // Execute the time since the last call
}
}
}