2013-04-18 05:09:55 +02:00
|
|
|
// Copyright 2013 Dolphin Emulator Project
|
|
|
|
// Licensed under GPLv2
|
|
|
|
// Refer to the license.txt file included.
|
2010-06-09 03:37:08 +02:00
|
|
|
|
2014-02-19 02:27:20 +01:00
|
|
|
#include "Common/Atomic.h"
|
|
|
|
#include "Common/ChunkFile.h"
|
2014-02-18 12:18:47 +01:00
|
|
|
#include "Common/Common.h"
|
|
|
|
#include "Common/MathUtil.h"
|
|
|
|
#include "Common/Thread.h"
|
|
|
|
#include "Core/ConfigManager.h"
|
|
|
|
#include "Core/Core.h"
|
|
|
|
#include "Core/CoreTiming.h"
|
|
|
|
#include "Core/HW/GPFifo.h"
|
|
|
|
#include "Core/HW/Memmap.h"
|
|
|
|
#include "Core/HW/MMIO.h"
|
|
|
|
#include "Core/HW/ProcessorInterface.h"
|
|
|
|
#include "Core/HW/SystemTimers.h"
|
|
|
|
#include "VideoCommon/CommandProcessor.h"
|
|
|
|
#include "VideoCommon/Fifo.h"
|
|
|
|
#include "VideoCommon/PixelEngine.h"
|
|
|
|
#include "VideoCommon/VideoCommon.h"
|
|
|
|
#include "VideoCommon/VideoConfig.h"
|
2010-06-09 03:37:08 +02:00
|
|
|
|
|
|
|
namespace CommandProcessor
|
|
|
|
{
|
|
|
|
|
|
|
|
int et_UpdateInterrupts;
|
|
|
|
|
|
|
|
// TODO(ector): Warn on bbox read/write
|
|
|
|
|
|
|
|
// STATE_TO_SAVE
|
|
|
|
SCPFifoStruct fifo;
|
|
|
|
UCPStatusReg m_CPStatusReg;
|
2014-02-17 05:51:41 +01:00
|
|
|
UCPCtrlReg m_CPCtrlReg;
|
|
|
|
UCPClearReg m_CPClearReg;
|
2010-06-09 03:37:08 +02:00
|
|
|
|
2014-02-02 14:16:43 +01:00
|
|
|
u16 m_bboxleft;
|
|
|
|
u16 m_bboxtop;
|
|
|
|
u16 m_bboxright;
|
|
|
|
u16 m_bboxbottom;
|
2010-06-09 03:37:08 +02:00
|
|
|
u16 m_tokenReg;
|
|
|
|
|
2011-02-08 11:37:47 +01:00
|
|
|
static bool bProcessFifoToLoWatermark = false;
|
2010-12-13 08:56:54 +01:00
|
|
|
static bool bProcessFifoAllDistance = false;
|
2010-06-09 03:37:08 +02:00
|
|
|
|
Big Fifo Commit Part2: Now the fifo is more stable than my first commit, so is time...
- ReImplementing Single Core Mode like Dual Core Mode Style.
- Stage 1: My goal is, we have the Fifo, CommandProccessor code the more clear, maintenible and documented possible. When I quit dolphin I want any developer can continue with the work only reading the code.
* Big Refactoring: A lot of functions was changed the names, and modularized.
Now the FifoLoop and CatchUpGPU does not exist, was replaced by RunGpu() and RunGpuLoop().
The general idea is modeling the code like the real HW. The fifo is only a buffer where the Write Gather Pipe write the commands and from the Graphic Processor read these.
* Big Clean UP a lot of obsolete code and comments was deleted, like DcFakeWachDog, "Fifo very soon hack", etc.
In the stage 2, I will refactoring more code doing emphasis in the division of CommandProcessor, Fifo, Gpu Emulation. Beside I will comment all functions and variables in the code (Don't worry I will ask for English help for this part ;) )
Please test a lot SC mode and DC mode :)
Thank you so much for testing always and the patience. I don't like broke your favorite game but... you must believe me this part is very sensible, I only try to contribute for have a better and stable dolphin emulator.
git-svn-id: https://dolphin-emu.googlecode.com/svn/trunk@7185 8ced0084-cf51-0410-be5f-012b33b47a6e
2011-02-17 05:25:21 +01:00
|
|
|
volatile bool isPossibleWaitingSetDrawDone = false;
|
2012-03-05 06:40:10 +01:00
|
|
|
volatile bool isHiWatermarkActive = false;
|
2013-01-25 10:04:31 +01:00
|
|
|
volatile bool isLoWatermarkActive = false;
|
2010-12-11 13:42:55 +01:00
|
|
|
volatile bool interruptSet= false;
|
|
|
|
volatile bool interruptWaiting= false;
|
2010-12-13 08:56:54 +01:00
|
|
|
volatile bool interruptTokenWaiting = false;
|
|
|
|
volatile bool interruptFinishWaiting = false;
|
2010-06-24 15:28:54 +02:00
|
|
|
|
2013-02-16 02:51:09 +01:00
|
|
|
volatile u32 VITicks = CommandProcessor::m_cpClockOrigin;
|
|
|
|
|
2011-02-08 11:37:47 +01:00
|
|
|
bool IsOnThread()
|
|
|
|
{
|
|
|
|
return SConfig::GetInstance().m_LocalCoreStartupParameter.bCPUThread;
|
|
|
|
}
|
|
|
|
|
|
|
|
void UpdateInterrupts_Wrapper(u64 userdata, int cyclesLate)
|
|
|
|
{
|
|
|
|
UpdateInterrupts(userdata);
|
|
|
|
}
|
|
|
|
|
2010-06-09 03:37:08 +02:00
|
|
|
void DoState(PointerWrap &p)
|
|
|
|
{
|
2013-04-10 01:57:39 +02:00
|
|
|
p.DoPOD(m_CPStatusReg);
|
|
|
|
p.DoPOD(m_CPCtrlReg);
|
|
|
|
p.DoPOD(m_CPClearReg);
|
2010-06-09 03:37:08 +02:00
|
|
|
p.Do(m_bboxleft);
|
|
|
|
p.Do(m_bboxtop);
|
|
|
|
p.Do(m_bboxright);
|
|
|
|
p.Do(m_bboxbottom);
|
|
|
|
p.Do(m_tokenReg);
|
|
|
|
p.Do(fifo);
|
2011-02-08 11:37:47 +01:00
|
|
|
|
|
|
|
p.Do(bProcessFifoToLoWatermark);
|
|
|
|
p.Do(bProcessFifoAllDistance);
|
2012-03-05 06:40:10 +01:00
|
|
|
p.Do(isHiWatermarkActive);
|
2013-01-25 10:04:31 +01:00
|
|
|
p.Do(isLoWatermarkActive);
|
2011-02-10 05:47:02 +01:00
|
|
|
p.Do(isPossibleWaitingSetDrawDone);
|
2011-02-08 11:37:47 +01:00
|
|
|
p.Do(interruptSet);
|
|
|
|
p.Do(interruptWaiting);
|
|
|
|
p.Do(interruptTokenWaiting);
|
|
|
|
p.Do(interruptFinishWaiting);
|
2010-06-09 03:37:08 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
inline void WriteLow (volatile u32& _reg, u16 lowbits) {Common::AtomicStore(_reg,(_reg & 0xFFFF0000) | lowbits);}
|
|
|
|
inline void WriteHigh(volatile u32& _reg, u16 highbits) {Common::AtomicStore(_reg,(_reg & 0x0000FFFF) | ((u32)highbits << 16));}
|
|
|
|
|
|
|
|
inline u16 ReadLow (u32 _reg) {return (u16)(_reg & 0xFFFF);}
|
|
|
|
inline u16 ReadHigh (u32 _reg) {return (u16)(_reg >> 16);}
|
|
|
|
|
|
|
|
void Init()
|
|
|
|
{
|
|
|
|
m_CPStatusReg.Hex = 0;
|
2010-06-14 23:55:40 +02:00
|
|
|
m_CPStatusReg.CommandIdle = 1;
|
2010-06-09 03:37:08 +02:00
|
|
|
m_CPStatusReg.ReadIdle = 1;
|
|
|
|
|
|
|
|
m_CPCtrlReg.Hex = 0;
|
|
|
|
|
2012-01-02 11:20:22 +01:00
|
|
|
m_CPClearReg.Hex = 0;
|
|
|
|
|
2010-06-09 03:37:08 +02:00
|
|
|
m_bboxleft = 0;
|
|
|
|
m_bboxtop = 0;
|
|
|
|
m_bboxright = 640;
|
|
|
|
m_bboxbottom = 480;
|
|
|
|
|
|
|
|
m_tokenReg = 0;
|
2013-10-29 06:23:17 +01:00
|
|
|
|
2010-06-09 03:37:08 +02:00
|
|
|
memset(&fifo,0,sizeof(fifo));
|
2013-01-25 10:04:31 +01:00
|
|
|
fifo.CPCmdIdle = 1;
|
2010-12-11 13:42:55 +01:00
|
|
|
fifo.CPReadIdle = 1;
|
2010-06-14 23:55:40 +02:00
|
|
|
fifo.bFF_Breakpoint = 0;
|
2013-04-24 15:21:54 +02:00
|
|
|
fifo.bFF_HiWatermark = 0;
|
2010-12-11 13:42:55 +01:00
|
|
|
fifo.bFF_HiWatermarkInt = 0;
|
2013-04-24 15:21:54 +02:00
|
|
|
fifo.bFF_LoWatermark = 0;
|
2010-12-11 13:42:55 +01:00
|
|
|
fifo.bFF_LoWatermarkInt = 0;
|
|
|
|
|
|
|
|
interruptSet = false;
|
2013-04-24 15:21:54 +02:00
|
|
|
interruptWaiting = false;
|
2010-12-13 08:56:54 +01:00
|
|
|
interruptFinishWaiting = false;
|
|
|
|
interruptTokenWaiting = false;
|
2010-06-09 03:37:08 +02:00
|
|
|
|
2012-01-02 11:20:22 +01:00
|
|
|
bProcessFifoToLoWatermark = false;
|
|
|
|
bProcessFifoAllDistance = false;
|
|
|
|
isPossibleWaitingSetDrawDone = false;
|
2012-03-05 06:40:10 +01:00
|
|
|
isHiWatermarkActive = false;
|
2013-01-25 10:04:31 +01:00
|
|
|
isLoWatermarkActive = false;
|
2012-01-02 11:20:22 +01:00
|
|
|
|
2013-04-24 15:21:54 +02:00
|
|
|
et_UpdateInterrupts = CoreTiming::RegisterEvent("CPInterrupt", UpdateInterrupts_Wrapper);
|
2010-06-09 03:37:08 +02:00
|
|
|
}
|
|
|
|
|
2014-02-02 14:16:43 +01:00
|
|
|
void RegisterMMIO(MMIO::Mapping* mmio, u32 base)
|
2010-06-09 03:37:08 +02:00
|
|
|
{
|
2014-02-02 14:16:43 +01:00
|
|
|
struct {
|
|
|
|
u32 addr;
|
|
|
|
u16* ptr;
|
|
|
|
bool readonly;
|
|
|
|
bool writes_align_to_32_bytes;
|
|
|
|
} directly_mapped_vars[] = {
|
|
|
|
{ FIFO_TOKEN_REGISTER, &m_tokenReg },
|
|
|
|
|
|
|
|
// Bounding box registers are read only.
|
|
|
|
{ FIFO_BOUNDING_BOX_LEFT, &m_bboxleft, true },
|
|
|
|
{ FIFO_BOUNDING_BOX_RIGHT, &m_bboxright, true },
|
|
|
|
{ FIFO_BOUNDING_BOX_TOP, &m_bboxtop, true },
|
|
|
|
{ FIFO_BOUNDING_BOX_BOTTOM, &m_bboxbottom, true },
|
|
|
|
|
|
|
|
// Some FIFO addresses need to be aligned on 32 bytes on write - only
|
|
|
|
// the high part can be written directly without a mask.
|
|
|
|
{ FIFO_BASE_LO, MMIO::Utils::LowPart(&fifo.CPBase), false, true },
|
|
|
|
{ FIFO_BASE_HI, MMIO::Utils::HighPart(&fifo.CPBase) },
|
|
|
|
{ FIFO_END_LO, MMIO::Utils::LowPart(&fifo.CPEnd), false, true },
|
|
|
|
{ FIFO_END_HI, MMIO::Utils::HighPart(&fifo.CPEnd) },
|
|
|
|
{ FIFO_HI_WATERMARK_LO, MMIO::Utils::LowPart(&fifo.CPHiWatermark) },
|
|
|
|
{ FIFO_HI_WATERMARK_HI, MMIO::Utils::HighPart(&fifo.CPHiWatermark) },
|
|
|
|
{ FIFO_LO_WATERMARK_LO, MMIO::Utils::LowPart(&fifo.CPLoWatermark) },
|
|
|
|
{ FIFO_LO_WATERMARK_HI, MMIO::Utils::HighPart(&fifo.CPLoWatermark) },
|
|
|
|
// FIFO_RW_DISTANCE has some complex read code different for
|
|
|
|
// single/dual core.
|
|
|
|
{ FIFO_WRITE_POINTER_LO, MMIO::Utils::LowPart(&fifo.CPWritePointer), false, true },
|
|
|
|
{ FIFO_WRITE_POINTER_HI, MMIO::Utils::HighPart(&fifo.CPWritePointer) },
|
|
|
|
// FIFO_READ_POINTER has different code for single/dual core.
|
|
|
|
{ FIFO_BP_LO, MMIO::Utils::LowPart(&fifo.CPBreakpoint), false, true },
|
|
|
|
{ FIFO_BP_HI, MMIO::Utils::HighPart(&fifo.CPBreakpoint) },
|
|
|
|
};
|
|
|
|
for (auto& mapped_var : directly_mapped_vars)
|
2010-06-09 03:37:08 +02:00
|
|
|
{
|
2014-02-02 14:16:43 +01:00
|
|
|
u16 wmask = mapped_var.writes_align_to_32_bytes ? 0xFFE0 : 0xFFFF;
|
|
|
|
mmio->Register(base | mapped_var.addr,
|
|
|
|
MMIO::DirectRead<u16>(mapped_var.ptr),
|
|
|
|
mapped_var.readonly
|
|
|
|
? MMIO::InvalidWrite<u16>()
|
|
|
|
: MMIO::DirectWrite<u16>(mapped_var.ptr, wmask)
|
|
|
|
);
|
2010-06-09 03:37:08 +02:00
|
|
|
}
|
2010-06-15 16:24:01 +02:00
|
|
|
|
2014-02-02 14:16:43 +01:00
|
|
|
// Timing and metrics MMIOs are stubbed with fixed values.
|
|
|
|
struct {
|
|
|
|
u32 addr;
|
|
|
|
u16 value;
|
|
|
|
} metrics_mmios[] = {
|
|
|
|
{ XF_RASBUSY_L, 0 },
|
|
|
|
{ XF_RASBUSY_H, 0 },
|
|
|
|
{ XF_CLKS_L, 0 },
|
|
|
|
{ XF_CLKS_H, 0 },
|
|
|
|
{ XF_WAIT_IN_L, 0 },
|
|
|
|
{ XF_WAIT_IN_H, 0 },
|
|
|
|
{ XF_WAIT_OUT_L, 0 },
|
|
|
|
{ XF_WAIT_OUT_H, 0 },
|
|
|
|
{ VCACHE_METRIC_CHECK_L, 0 },
|
|
|
|
{ VCACHE_METRIC_CHECK_H, 0 },
|
|
|
|
{ VCACHE_METRIC_MISS_L, 0 },
|
|
|
|
{ VCACHE_METRIC_MISS_H, 0 },
|
|
|
|
{ VCACHE_METRIC_STALL_L, 0 },
|
|
|
|
{ VCACHE_METRIC_STALL_H, 0 },
|
|
|
|
{ CLKS_PER_VTX_OUT, 4 },
|
|
|
|
};
|
|
|
|
for (auto& metrics_mmio : metrics_mmios)
|
2010-06-09 03:37:08 +02:00
|
|
|
{
|
2014-02-02 14:16:43 +01:00
|
|
|
mmio->Register(base | metrics_mmio.addr,
|
|
|
|
MMIO::Constant<u16>(metrics_mmio.value),
|
|
|
|
MMIO::InvalidWrite<u16>()
|
|
|
|
);
|
|
|
|
}
|
2010-06-09 03:37:08 +02:00
|
|
|
|
2014-02-02 14:16:43 +01:00
|
|
|
mmio->Register(base | STATUS_REGISTER,
|
|
|
|
MMIO::ComplexRead<u16>([](u32) {
|
|
|
|
SetCpStatusRegister();
|
|
|
|
return m_CPStatusReg.Hex;
|
|
|
|
}),
|
|
|
|
MMIO::InvalidWrite<u16>()
|
|
|
|
);
|
|
|
|
|
|
|
|
mmio->Register(base | CTRL_REGISTER,
|
|
|
|
MMIO::DirectRead<u16>(&m_CPCtrlReg.Hex),
|
|
|
|
MMIO::ComplexWrite<u16>([](u32, u16 val) {
|
|
|
|
UCPCtrlReg tmp(val);
|
|
|
|
m_CPCtrlReg.Hex = tmp.Hex;
|
Big Fifo Commit Part2: Now the fifo is more stable than my first commit, so is time...
- ReImplementing Single Core Mode like Dual Core Mode Style.
- Stage 1: My goal is, we have the Fifo, CommandProccessor code the more clear, maintenible and documented possible. When I quit dolphin I want any developer can continue with the work only reading the code.
* Big Refactoring: A lot of functions was changed the names, and modularized.
Now the FifoLoop and CatchUpGPU does not exist, was replaced by RunGpu() and RunGpuLoop().
The general idea is modeling the code like the real HW. The fifo is only a buffer where the Write Gather Pipe write the commands and from the Graphic Processor read these.
* Big Clean UP a lot of obsolete code and comments was deleted, like DcFakeWachDog, "Fifo very soon hack", etc.
In the stage 2, I will refactoring more code doing emphasis in the division of CommandProcessor, Fifo, Gpu Emulation. Beside I will comment all functions and variables in the code (Don't worry I will ask for English help for this part ;) )
Please test a lot SC mode and DC mode :)
Thank you so much for testing always and the patience. I don't like broke your favorite game but... you must believe me this part is very sensible, I only try to contribute for have a better and stable dolphin emulator.
git-svn-id: https://dolphin-emu.googlecode.com/svn/trunk@7185 8ced0084-cf51-0410-be5f-012b33b47a6e
2011-02-17 05:25:21 +01:00
|
|
|
SetCpControlRegister();
|
2014-02-02 14:16:43 +01:00
|
|
|
if (!IsOnThread())
|
|
|
|
RunGpu();
|
|
|
|
})
|
|
|
|
);
|
|
|
|
|
|
|
|
mmio->Register(base | CLEAR_REGISTER,
|
|
|
|
MMIO::DirectRead<u16>(&m_CPClearReg.Hex),
|
|
|
|
MMIO::ComplexWrite<u16>([](u32, u16 val) {
|
|
|
|
UCPClearReg tmp(val);
|
|
|
|
m_CPClearReg.Hex = tmp.Hex;
|
2012-01-21 14:58:29 +01:00
|
|
|
SetCpClearRegister();
|
2014-02-02 14:16:43 +01:00
|
|
|
if (!IsOnThread())
|
|
|
|
RunGpu();
|
|
|
|
})
|
|
|
|
);
|
|
|
|
|
|
|
|
mmio->Register(base | PERF_SELECT,
|
|
|
|
MMIO::InvalidRead<u16>(),
|
|
|
|
MMIO::Nop<u16>()
|
|
|
|
);
|
|
|
|
|
|
|
|
// Some MMIOs have different handlers for single core vs. dual core mode.
|
|
|
|
mmio->Register(base | FIFO_RW_DISTANCE_LO,
|
|
|
|
IsOnThread()
|
|
|
|
? MMIO::ComplexRead<u16>([](u32) {
|
|
|
|
if (fifo.CPWritePointer >= fifo.SafeCPReadPointer)
|
|
|
|
return ReadLow(fifo.CPWritePointer - fifo.SafeCPReadPointer);
|
|
|
|
else
|
|
|
|
return ReadLow(fifo.CPEnd - fifo.SafeCPReadPointer + fifo.CPWritePointer - fifo.CPBase + 32);
|
|
|
|
})
|
|
|
|
: MMIO::DirectRead<u16>(MMIO::Utils::LowPart(&fifo.CPReadWriteDistance)),
|
|
|
|
MMIO::DirectWrite<u16>(MMIO::Utils::LowPart(&fifo.CPReadWriteDistance), 0xFFE0)
|
|
|
|
);
|
|
|
|
mmio->Register(base | FIFO_RW_DISTANCE_HI,
|
|
|
|
IsOnThread()
|
|
|
|
? MMIO::ComplexRead<u16>([](u32) {
|
|
|
|
if (fifo.CPWritePointer >= fifo.SafeCPReadPointer)
|
|
|
|
return ReadHigh(fifo.CPWritePointer - fifo.SafeCPReadPointer);
|
|
|
|
else
|
|
|
|
return ReadHigh(fifo.CPEnd - fifo.SafeCPReadPointer + fifo.CPWritePointer - fifo.CPBase + 32);
|
|
|
|
})
|
|
|
|
: MMIO::DirectRead<u16>(MMIO::Utils::HighPart(&fifo.CPReadWriteDistance)),
|
|
|
|
MMIO::ComplexWrite<u16>([](u32, u16 val) {
|
|
|
|
WriteHigh(fifo.CPReadWriteDistance, val);
|
|
|
|
if (fifo.CPReadWriteDistance == 0)
|
|
|
|
{
|
|
|
|
GPFifo::ResetGatherPipe();
|
|
|
|
ResetVideoBuffer();
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
ResetVideoBuffer();
|
|
|
|
}
|
|
|
|
if (!IsOnThread())
|
|
|
|
RunGpu();
|
|
|
|
})
|
|
|
|
);
|
|
|
|
mmio->Register(base | FIFO_READ_POINTER_LO,
|
|
|
|
IsOnThread()
|
|
|
|
? MMIO::DirectRead<u16>(MMIO::Utils::LowPart(&fifo.SafeCPReadPointer))
|
|
|
|
: MMIO::DirectRead<u16>(MMIO::Utils::LowPart(&fifo.CPReadPointer)),
|
|
|
|
MMIO::DirectWrite<u16>(MMIO::Utils::LowPart(&fifo.CPReadPointer), 0xFFE0)
|
|
|
|
);
|
|
|
|
mmio->Register(base | FIFO_READ_POINTER_HI,
|
|
|
|
IsOnThread()
|
|
|
|
? MMIO::DirectRead<u16>(MMIO::Utils::HighPart(&fifo.SafeCPReadPointer))
|
|
|
|
: MMIO::DirectRead<u16>(MMIO::Utils::HighPart(&fifo.CPReadPointer)),
|
|
|
|
IsOnThread()
|
|
|
|
? MMIO::ComplexWrite<u16>([](u32, u16 val) {
|
|
|
|
WriteHigh(fifo.CPReadPointer, val);
|
|
|
|
fifo.SafeCPReadPointer = fifo.CPReadPointer;
|
|
|
|
})
|
|
|
|
: MMIO::DirectWrite<u16>(MMIO::Utils::HighPart(&fifo.CPReadPointer))
|
|
|
|
);
|
|
|
|
}
|
2010-06-09 03:37:08 +02:00
|
|
|
|
|
|
|
void STACKALIGN GatherPipeBursted()
|
|
|
|
{
|
2012-03-19 02:54:58 +01:00
|
|
|
ProcessFifoEvents();
|
2010-06-09 03:37:08 +02:00
|
|
|
// if we aren't linked, we don't care about gather pipe data
|
2010-06-14 23:55:40 +02:00
|
|
|
if (!m_CPCtrlReg.GPLinkEnable)
|
2010-06-15 16:24:01 +02:00
|
|
|
{
|
2011-01-31 02:28:32 +01:00
|
|
|
if (!IsOnThread())
|
2013-04-24 15:21:54 +02:00
|
|
|
{
|
Big Fifo Commit Part2: Now the fifo is more stable than my first commit, so is time...
- ReImplementing Single Core Mode like Dual Core Mode Style.
- Stage 1: My goal is, we have the Fifo, CommandProccessor code the more clear, maintenible and documented possible. When I quit dolphin I want any developer can continue with the work only reading the code.
* Big Refactoring: A lot of functions was changed the names, and modularized.
Now the FifoLoop and CatchUpGPU does not exist, was replaced by RunGpu() and RunGpuLoop().
The general idea is modeling the code like the real HW. The fifo is only a buffer where the Write Gather Pipe write the commands and from the Graphic Processor read these.
* Big Clean UP a lot of obsolete code and comments was deleted, like DcFakeWachDog, "Fifo very soon hack", etc.
In the stage 2, I will refactoring more code doing emphasis in the division of CommandProcessor, Fifo, Gpu Emulation. Beside I will comment all functions and variables in the code (Don't worry I will ask for English help for this part ;) )
Please test a lot SC mode and DC mode :)
Thank you so much for testing always and the patience. I don't like broke your favorite game but... you must believe me this part is very sensible, I only try to contribute for have a better and stable dolphin emulator.
git-svn-id: https://dolphin-emu.googlecode.com/svn/trunk@7185 8ced0084-cf51-0410-be5f-012b33b47a6e
2011-02-17 05:25:21 +01:00
|
|
|
RunGpu();
|
2013-04-24 15:21:54 +02:00
|
|
|
}
|
2012-03-19 02:54:58 +01:00
|
|
|
else
|
|
|
|
{
|
2013-04-01 01:10:21 +02:00
|
|
|
// In multibuffer mode is not allowed write in the same FIFO attached to the GPU.
|
2012-03-19 02:54:58 +01:00
|
|
|
// Fix Pokemon XD in DC mode.
|
2014-03-10 12:30:55 +01:00
|
|
|
if ((ProcessorInterface::Fifo_CPUEnd == fifo.CPEnd) &&
|
|
|
|
(ProcessorInterface::Fifo_CPUBase == fifo.CPBase) &&
|
|
|
|
fifo.CPReadWriteDistance > 0)
|
2012-03-19 02:54:58 +01:00
|
|
|
{
|
|
|
|
ProcessFifoAllDistance();
|
|
|
|
}
|
|
|
|
}
|
2010-06-09 03:37:08 +02:00
|
|
|
return;
|
2010-06-15 16:24:01 +02:00
|
|
|
}
|
2010-06-09 03:37:08 +02:00
|
|
|
|
2011-01-31 02:28:32 +01:00
|
|
|
if (IsOnThread())
|
2013-03-14 07:08:26 +01:00
|
|
|
SetCpStatus(true);
|
2010-12-11 13:42:55 +01:00
|
|
|
|
2013-04-01 01:10:21 +02:00
|
|
|
// update the fifo pointer
|
2010-06-15 16:24:01 +02:00
|
|
|
if (fifo.CPWritePointer >= fifo.CPEnd)
|
|
|
|
fifo.CPWritePointer = fifo.CPBase;
|
2010-06-09 03:37:08 +02:00
|
|
|
else
|
2010-06-15 16:24:01 +02:00
|
|
|
fifo.CPWritePointer += GATHER_PIPE_SIZE;
|
2010-06-09 03:37:08 +02:00
|
|
|
|
2010-06-15 16:24:01 +02:00
|
|
|
Common::AtomicAdd(fifo.CPReadWriteDistance, GATHER_PIPE_SIZE);
|
2010-06-14 23:55:40 +02:00
|
|
|
|
2011-01-31 02:28:32 +01:00
|
|
|
if (!IsOnThread())
|
Big Fifo Commit Part2: Now the fifo is more stable than my first commit, so is time...
- ReImplementing Single Core Mode like Dual Core Mode Style.
- Stage 1: My goal is, we have the Fifo, CommandProccessor code the more clear, maintenible and documented possible. When I quit dolphin I want any developer can continue with the work only reading the code.
* Big Refactoring: A lot of functions was changed the names, and modularized.
Now the FifoLoop and CatchUpGPU does not exist, was replaced by RunGpu() and RunGpuLoop().
The general idea is modeling the code like the real HW. The fifo is only a buffer where the Write Gather Pipe write the commands and from the Graphic Processor read these.
* Big Clean UP a lot of obsolete code and comments was deleted, like DcFakeWachDog, "Fifo very soon hack", etc.
In the stage 2, I will refactoring more code doing emphasis in the division of CommandProcessor, Fifo, Gpu Emulation. Beside I will comment all functions and variables in the code (Don't worry I will ask for English help for this part ;) )
Please test a lot SC mode and DC mode :)
Thank you so much for testing always and the patience. I don't like broke your favorite game but... you must believe me this part is very sensible, I only try to contribute for have a better and stable dolphin emulator.
git-svn-id: https://dolphin-emu.googlecode.com/svn/trunk@7185 8ced0084-cf51-0410-be5f-012b33b47a6e
2011-02-17 05:25:21 +01:00
|
|
|
RunGpu();
|
2010-06-15 16:24:01 +02:00
|
|
|
|
2013-04-24 15:21:54 +02:00
|
|
|
_assert_msg_(COMMANDPROCESSOR, fifo.CPReadWriteDistance <= fifo.CPEnd - fifo.CPBase,
|
2013-04-01 01:10:21 +02:00
|
|
|
"FIFO is overflowed by GatherPipe !\nCPU thread is too fast!");
|
2010-06-16 09:22:47 +02:00
|
|
|
|
2010-06-15 16:24:01 +02:00
|
|
|
// check if we are in sync
|
2014-02-16 21:30:18 +01:00
|
|
|
_assert_msg_(COMMANDPROCESSOR, fifo.CPWritePointer == ProcessorInterface::Fifo_CPUWritePointer, "FIFOs linked but out of sync");
|
|
|
|
_assert_msg_(COMMANDPROCESSOR, fifo.CPBase == ProcessorInterface::Fifo_CPUBase, "FIFOs linked but out of sync");
|
|
|
|
_assert_msg_(COMMANDPROCESSOR, fifo.CPEnd == ProcessorInterface::Fifo_CPUEnd, "FIFOs linked but out of sync");
|
2010-06-09 03:37:08 +02:00
|
|
|
}
|
|
|
|
|
2010-12-11 13:42:55 +01:00
|
|
|
void UpdateInterrupts(u64 userdata)
|
|
|
|
{
|
2013-03-20 02:51:12 +01:00
|
|
|
if (userdata)
|
2010-12-11 13:42:55 +01:00
|
|
|
{
|
|
|
|
interruptSet = true;
|
2013-03-20 02:51:12 +01:00
|
|
|
INFO_LOG(COMMANDPROCESSOR,"Interrupt set");
|
2013-04-24 15:21:54 +02:00
|
|
|
ProcessorInterface::SetInterrupt(INT_CAUSE_CP, true);
|
2010-12-11 13:42:55 +01:00
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
2010-12-13 05:44:33 +01:00
|
|
|
interruptSet = false;
|
|
|
|
INFO_LOG(COMMANDPROCESSOR,"Interrupt cleared");
|
2013-04-24 15:21:54 +02:00
|
|
|
ProcessorInterface::SetInterrupt(INT_CAUSE_CP, false);
|
2010-12-11 13:42:55 +01:00
|
|
|
}
|
2013-03-20 02:51:12 +01:00
|
|
|
interruptWaiting = false;
|
2010-12-11 13:42:55 +01:00
|
|
|
}
|
|
|
|
|
2011-02-14 03:18:03 +01:00
|
|
|
void UpdateInterruptsFromVideoBackend(u64 userdata)
|
2010-06-09 03:37:08 +02:00
|
|
|
{
|
2011-01-31 02:28:32 +01:00
|
|
|
CoreTiming::ScheduleEvent_Threadsafe(0, et_UpdateInterrupts, userdata);
|
2010-06-09 03:37:08 +02:00
|
|
|
}
|
|
|
|
|
2010-11-24 07:02:03 +01:00
|
|
|
// This is called by the ProcessorInterface when PI_FIFO_RESET is written to.
|
2010-08-10 09:25:35 +02:00
|
|
|
void AbortFrame()
|
|
|
|
{
|
Big Fifo Commit Part2: Now the fifo is more stable than my first commit, so is time...
- ReImplementing Single Core Mode like Dual Core Mode Style.
- Stage 1: My goal is, we have the Fifo, CommandProccessor code the more clear, maintenible and documented possible. When I quit dolphin I want any developer can continue with the work only reading the code.
* Big Refactoring: A lot of functions was changed the names, and modularized.
Now the FifoLoop and CatchUpGPU does not exist, was replaced by RunGpu() and RunGpuLoop().
The general idea is modeling the code like the real HW. The fifo is only a buffer where the Write Gather Pipe write the commands and from the Graphic Processor read these.
* Big Clean UP a lot of obsolete code and comments was deleted, like DcFakeWachDog, "Fifo very soon hack", etc.
In the stage 2, I will refactoring more code doing emphasis in the division of CommandProcessor, Fifo, Gpu Emulation. Beside I will comment all functions and variables in the code (Don't worry I will ask for English help for this part ;) )
Please test a lot SC mode and DC mode :)
Thank you so much for testing always and the patience. I don't like broke your favorite game but... you must believe me this part is very sensible, I only try to contribute for have a better and stable dolphin emulator.
git-svn-id: https://dolphin-emu.googlecode.com/svn/trunk@7185 8ced0084-cf51-0410-be5f-012b33b47a6e
2011-02-17 05:25:21 +01:00
|
|
|
|
2010-08-10 09:25:35 +02:00
|
|
|
}
|
|
|
|
|
2013-03-14 07:08:26 +01:00
|
|
|
void SetCpStatus(bool isCPUThread)
|
2010-12-11 13:42:55 +01:00
|
|
|
{
|
2013-03-20 02:51:12 +01:00
|
|
|
// overflow & underflow check
|
2010-12-11 13:42:55 +01:00
|
|
|
fifo.bFF_HiWatermark = (fifo.CPReadWriteDistance > fifo.CPHiWatermark);
|
2013-03-20 02:51:12 +01:00
|
|
|
fifo.bFF_LoWatermark = (fifo.CPReadWriteDistance < fifo.CPLoWatermark);
|
2013-03-14 07:08:26 +01:00
|
|
|
|
2013-04-24 15:21:54 +02:00
|
|
|
// breakpoint
|
2013-03-14 07:08:26 +01:00
|
|
|
if (!isCPUThread)
|
2013-02-16 02:51:09 +01:00
|
|
|
{
|
|
|
|
if (fifo.bFF_BPEnable)
|
|
|
|
{
|
|
|
|
if (fifo.CPBreakpoint == fifo.CPReadPointer)
|
2011-02-08 13:00:41 +01:00
|
|
|
{
|
2013-02-16 02:51:09 +01:00
|
|
|
if (!fifo.bFF_Breakpoint)
|
|
|
|
{
|
|
|
|
INFO_LOG(COMMANDPROCESSOR, "Hit breakpoint at %i", fifo.CPReadPointer);
|
|
|
|
fifo.bFF_Breakpoint = true;
|
|
|
|
}
|
2011-02-08 13:00:41 +01:00
|
|
|
}
|
2013-02-16 02:51:09 +01:00
|
|
|
else
|
|
|
|
{
|
|
|
|
if (fifo.bFF_Breakpoint)
|
|
|
|
INFO_LOG(COMMANDPROCESSOR, "Cleared breakpoint at %i", fifo.CPReadPointer);
|
|
|
|
fifo.bFF_Breakpoint = false;
|
|
|
|
}
|
|
|
|
}
|
2010-12-11 13:42:55 +01:00
|
|
|
else
|
|
|
|
{
|
|
|
|
if (fifo.bFF_Breakpoint)
|
2010-12-12 16:25:03 +01:00
|
|
|
INFO_LOG(COMMANDPROCESSOR, "Cleared breakpoint at %i", fifo.CPReadPointer);
|
2013-02-16 02:51:09 +01:00
|
|
|
fifo.bFF_Breakpoint = false;
|
2010-12-11 13:42:55 +01:00
|
|
|
}
|
2013-02-16 02:51:09 +01:00
|
|
|
}
|
2010-12-11 13:42:55 +01:00
|
|
|
|
|
|
|
bool bpInt = fifo.bFF_Breakpoint && fifo.bFF_BPInt;
|
|
|
|
bool ovfInt = fifo.bFF_HiWatermark && fifo.bFF_HiWatermarkInt;
|
|
|
|
bool undfInt = fifo.bFF_LoWatermark && fifo.bFF_LoWatermarkInt;
|
2013-03-14 07:08:26 +01:00
|
|
|
|
2010-12-13 05:44:33 +01:00
|
|
|
bool interrupt = (bpInt || ovfInt || undfInt) && m_CPCtrlReg.GPReadEnable;
|
2010-12-11 13:42:55 +01:00
|
|
|
|
2013-01-25 10:04:31 +01:00
|
|
|
isHiWatermarkActive = ovfInt && m_CPCtrlReg.GPReadEnable;
|
|
|
|
isLoWatermarkActive = undfInt && m_CPCtrlReg.GPReadEnable;
|
2012-03-05 06:40:10 +01:00
|
|
|
|
2013-03-20 02:51:12 +01:00
|
|
|
if (interrupt != interruptSet && !interruptWaiting)
|
|
|
|
{
|
|
|
|
u64 userdata = interrupt?1:0;
|
|
|
|
if (IsOnThread())
|
|
|
|
{
|
|
|
|
if (!interrupt || bpInt || undfInt || ovfInt)
|
2012-03-05 06:40:10 +01:00
|
|
|
{
|
2013-03-14 07:08:26 +01:00
|
|
|
if (!isCPUThread)
|
2013-02-16 02:51:09 +01:00
|
|
|
{
|
2013-03-14 07:08:26 +01:00
|
|
|
// GPU thread:
|
2013-02-16 02:51:09 +01:00
|
|
|
interruptWaiting = true;
|
|
|
|
CommandProcessor::UpdateInterruptsFromVideoBackend(userdata);
|
|
|
|
}
|
2013-03-14 07:08:26 +01:00
|
|
|
else
|
2013-02-16 02:51:09 +01:00
|
|
|
{
|
2013-03-14 07:08:26 +01:00
|
|
|
// CPU thread:
|
2013-02-16 02:51:09 +01:00
|
|
|
interruptSet = interrupt;
|
2013-03-20 02:51:12 +01:00
|
|
|
INFO_LOG(COMMANDPROCESSOR,"Interrupt set");
|
|
|
|
ProcessorInterface::SetInterrupt(INT_CAUSE_CP, interrupt);
|
2013-02-16 02:51:09 +01:00
|
|
|
}
|
2012-03-05 06:40:10 +01:00
|
|
|
}
|
2013-03-20 02:51:12 +01:00
|
|
|
}
|
|
|
|
else
|
2013-04-24 15:21:54 +02:00
|
|
|
{
|
2013-03-20 02:51:12 +01:00
|
|
|
CommandProcessor::UpdateInterrupts(userdata);
|
2013-04-24 15:21:54 +02:00
|
|
|
}
|
2013-03-20 02:51:12 +01:00
|
|
|
}
|
2010-12-11 13:42:55 +01:00
|
|
|
}
|
|
|
|
|
2011-02-08 11:37:47 +01:00
|
|
|
void ProcessFifoToLoWatermark()
|
2010-12-11 13:42:55 +01:00
|
|
|
{
|
2011-01-31 02:28:32 +01:00
|
|
|
if (IsOnThread())
|
2010-12-11 13:42:55 +01:00
|
|
|
{
|
|
|
|
while (!CommandProcessor::interruptWaiting && fifo.bFF_GPReadEnable &&
|
|
|
|
fifo.CPReadWriteDistance > fifo.CPLoWatermark && !AtBreakpoint())
|
|
|
|
Common::YieldCPU();
|
|
|
|
}
|
2011-02-08 11:37:47 +01:00
|
|
|
bProcessFifoToLoWatermark = false;
|
2010-12-11 13:42:55 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
void ProcessFifoAllDistance()
|
|
|
|
{
|
2011-01-31 02:28:32 +01:00
|
|
|
if (IsOnThread())
|
2010-12-11 13:42:55 +01:00
|
|
|
{
|
|
|
|
while (!CommandProcessor::interruptWaiting && fifo.bFF_GPReadEnable &&
|
2013-02-16 02:51:09 +01:00
|
|
|
fifo.CPReadWriteDistance && !AtBreakpoint())
|
2010-12-11 13:42:55 +01:00
|
|
|
Common::YieldCPU();
|
|
|
|
}
|
2010-12-13 08:56:54 +01:00
|
|
|
bProcessFifoAllDistance = false;
|
|
|
|
}
|
|
|
|
|
|
|
|
void ProcessFifoEvents()
|
|
|
|
{
|
2011-01-31 02:28:32 +01:00
|
|
|
if (IsOnThread() && (interruptWaiting || interruptFinishWaiting || interruptTokenWaiting))
|
|
|
|
CoreTiming::ProcessFifoWaitEvents();
|
2010-12-11 13:42:55 +01:00
|
|
|
}
|
|
|
|
|
Big Fifo Commit Part2: Now the fifo is more stable than my first commit, so is time...
- ReImplementing Single Core Mode like Dual Core Mode Style.
- Stage 1: My goal is, we have the Fifo, CommandProccessor code the more clear, maintenible and documented possible. When I quit dolphin I want any developer can continue with the work only reading the code.
* Big Refactoring: A lot of functions was changed the names, and modularized.
Now the FifoLoop and CatchUpGPU does not exist, was replaced by RunGpu() and RunGpuLoop().
The general idea is modeling the code like the real HW. The fifo is only a buffer where the Write Gather Pipe write the commands and from the Graphic Processor read these.
* Big Clean UP a lot of obsolete code and comments was deleted, like DcFakeWachDog, "Fifo very soon hack", etc.
In the stage 2, I will refactoring more code doing emphasis in the division of CommandProcessor, Fifo, Gpu Emulation. Beside I will comment all functions and variables in the code (Don't worry I will ask for English help for this part ;) )
Please test a lot SC mode and DC mode :)
Thank you so much for testing always and the patience. I don't like broke your favorite game but... you must believe me this part is very sensible, I only try to contribute for have a better and stable dolphin emulator.
git-svn-id: https://dolphin-emu.googlecode.com/svn/trunk@7185 8ced0084-cf51-0410-be5f-012b33b47a6e
2011-02-17 05:25:21 +01:00
|
|
|
void Shutdown()
|
|
|
|
{
|
2013-10-29 06:23:17 +01:00
|
|
|
|
Big Fifo Commit Part2: Now the fifo is more stable than my first commit, so is time...
- ReImplementing Single Core Mode like Dual Core Mode Style.
- Stage 1: My goal is, we have the Fifo, CommandProccessor code the more clear, maintenible and documented possible. When I quit dolphin I want any developer can continue with the work only reading the code.
* Big Refactoring: A lot of functions was changed the names, and modularized.
Now the FifoLoop and CatchUpGPU does not exist, was replaced by RunGpu() and RunGpuLoop().
The general idea is modeling the code like the real HW. The fifo is only a buffer where the Write Gather Pipe write the commands and from the Graphic Processor read these.
* Big Clean UP a lot of obsolete code and comments was deleted, like DcFakeWachDog, "Fifo very soon hack", etc.
In the stage 2, I will refactoring more code doing emphasis in the division of CommandProcessor, Fifo, Gpu Emulation. Beside I will comment all functions and variables in the code (Don't worry I will ask for English help for this part ;) )
Please test a lot SC mode and DC mode :)
Thank you so much for testing always and the patience. I don't like broke your favorite game but... you must believe me this part is very sensible, I only try to contribute for have a better and stable dolphin emulator.
git-svn-id: https://dolphin-emu.googlecode.com/svn/trunk@7185 8ced0084-cf51-0410-be5f-012b33b47a6e
2011-02-17 05:25:21 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
void SetCpStatusRegister()
|
|
|
|
{
|
|
|
|
// Here always there is one fifo attached to the GPU
|
|
|
|
m_CPStatusReg.Breakpoint = fifo.bFF_Breakpoint;
|
2013-02-16 02:51:09 +01:00
|
|
|
m_CPStatusReg.ReadIdle = !fifo.CPReadWriteDistance || AtBreakpoint() || (fifo.CPReadPointer == fifo.CPWritePointer);
|
|
|
|
m_CPStatusReg.CommandIdle = !fifo.CPReadWriteDistance || AtBreakpoint() || !fifo.bFF_GPReadEnable;
|
Big Fifo Commit Part2: Now the fifo is more stable than my first commit, so is time...
- ReImplementing Single Core Mode like Dual Core Mode Style.
- Stage 1: My goal is, we have the Fifo, CommandProccessor code the more clear, maintenible and documented possible. When I quit dolphin I want any developer can continue with the work only reading the code.
* Big Refactoring: A lot of functions was changed the names, and modularized.
Now the FifoLoop and CatchUpGPU does not exist, was replaced by RunGpu() and RunGpuLoop().
The general idea is modeling the code like the real HW. The fifo is only a buffer where the Write Gather Pipe write the commands and from the Graphic Processor read these.
* Big Clean UP a lot of obsolete code and comments was deleted, like DcFakeWachDog, "Fifo very soon hack", etc.
In the stage 2, I will refactoring more code doing emphasis in the division of CommandProcessor, Fifo, Gpu Emulation. Beside I will comment all functions and variables in the code (Don't worry I will ask for English help for this part ;) )
Please test a lot SC mode and DC mode :)
Thank you so much for testing always and the patience. I don't like broke your favorite game but... you must believe me this part is very sensible, I only try to contribute for have a better and stable dolphin emulator.
git-svn-id: https://dolphin-emu.googlecode.com/svn/trunk@7185 8ced0084-cf51-0410-be5f-012b33b47a6e
2011-02-17 05:25:21 +01:00
|
|
|
m_CPStatusReg.UnderflowLoWatermark = fifo.bFF_LoWatermark;
|
|
|
|
m_CPStatusReg.OverflowHiWatermark = fifo.bFF_HiWatermark;
|
2012-03-13 12:35:11 +01:00
|
|
|
|
Big Fifo Commit Part2: Now the fifo is more stable than my first commit, so is time...
- ReImplementing Single Core Mode like Dual Core Mode Style.
- Stage 1: My goal is, we have the Fifo, CommandProccessor code the more clear, maintenible and documented possible. When I quit dolphin I want any developer can continue with the work only reading the code.
* Big Refactoring: A lot of functions was changed the names, and modularized.
Now the FifoLoop and CatchUpGPU does not exist, was replaced by RunGpu() and RunGpuLoop().
The general idea is modeling the code like the real HW. The fifo is only a buffer where the Write Gather Pipe write the commands and from the Graphic Processor read these.
* Big Clean UP a lot of obsolete code and comments was deleted, like DcFakeWachDog, "Fifo very soon hack", etc.
In the stage 2, I will refactoring more code doing emphasis in the division of CommandProcessor, Fifo, Gpu Emulation. Beside I will comment all functions and variables in the code (Don't worry I will ask for English help for this part ;) )
Please test a lot SC mode and DC mode :)
Thank you so much for testing always and the patience. I don't like broke your favorite game but... you must believe me this part is very sensible, I only try to contribute for have a better and stable dolphin emulator.
git-svn-id: https://dolphin-emu.googlecode.com/svn/trunk@7185 8ced0084-cf51-0410-be5f-012b33b47a6e
2011-02-17 05:25:21 +01:00
|
|
|
INFO_LOG(COMMANDPROCESSOR,"\t Read from STATUS_REGISTER : %04x", m_CPStatusReg.Hex);
|
|
|
|
DEBUG_LOG(COMMANDPROCESSOR, "(r) status: iBP %s | fReadIdle %s | fCmdIdle %s | iOvF %s | iUndF %s"
|
2014-02-16 21:30:18 +01:00
|
|
|
, m_CPStatusReg.Breakpoint ? "ON" : "OFF"
|
|
|
|
, m_CPStatusReg.ReadIdle ? "ON" : "OFF"
|
|
|
|
, m_CPStatusReg.CommandIdle ? "ON" : "OFF"
|
|
|
|
, m_CPStatusReg.OverflowHiWatermark ? "ON" : "OFF"
|
|
|
|
, m_CPStatusReg.UnderflowLoWatermark ? "ON" : "OFF"
|
Big Fifo Commit Part2: Now the fifo is more stable than my first commit, so is time...
- ReImplementing Single Core Mode like Dual Core Mode Style.
- Stage 1: My goal is, we have the Fifo, CommandProccessor code the more clear, maintenible and documented possible. When I quit dolphin I want any developer can continue with the work only reading the code.
* Big Refactoring: A lot of functions was changed the names, and modularized.
Now the FifoLoop and CatchUpGPU does not exist, was replaced by RunGpu() and RunGpuLoop().
The general idea is modeling the code like the real HW. The fifo is only a buffer where the Write Gather Pipe write the commands and from the Graphic Processor read these.
* Big Clean UP a lot of obsolete code and comments was deleted, like DcFakeWachDog, "Fifo very soon hack", etc.
In the stage 2, I will refactoring more code doing emphasis in the division of CommandProcessor, Fifo, Gpu Emulation. Beside I will comment all functions and variables in the code (Don't worry I will ask for English help for this part ;) )
Please test a lot SC mode and DC mode :)
Thank you so much for testing always and the patience. I don't like broke your favorite game but... you must believe me this part is very sensible, I only try to contribute for have a better and stable dolphin emulator.
git-svn-id: https://dolphin-emu.googlecode.com/svn/trunk@7185 8ced0084-cf51-0410-be5f-012b33b47a6e
2011-02-17 05:25:21 +01:00
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
void SetCpControlRegister()
|
|
|
|
{
|
2013-03-25 22:23:20 +01:00
|
|
|
// If the new fifo is being attached, force an exception check
|
|
|
|
// This fixes the hang while booting Eternal Darkness
|
Big Fifo Commit Part2: Now the fifo is more stable than my first commit, so is time...
- ReImplementing Single Core Mode like Dual Core Mode Style.
- Stage 1: My goal is, we have the Fifo, CommandProccessor code the more clear, maintenible and documented possible. When I quit dolphin I want any developer can continue with the work only reading the code.
* Big Refactoring: A lot of functions was changed the names, and modularized.
Now the FifoLoop and CatchUpGPU does not exist, was replaced by RunGpu() and RunGpuLoop().
The general idea is modeling the code like the real HW. The fifo is only a buffer where the Write Gather Pipe write the commands and from the Graphic Processor read these.
* Big Clean UP a lot of obsolete code and comments was deleted, like DcFakeWachDog, "Fifo very soon hack", etc.
In the stage 2, I will refactoring more code doing emphasis in the division of CommandProcessor, Fifo, Gpu Emulation. Beside I will comment all functions and variables in the code (Don't worry I will ask for English help for this part ;) )
Please test a lot SC mode and DC mode :)
Thank you so much for testing always and the patience. I don't like broke your favorite game but... you must believe me this part is very sensible, I only try to contribute for have a better and stable dolphin emulator.
git-svn-id: https://dolphin-emu.googlecode.com/svn/trunk@7185 8ced0084-cf51-0410-be5f-012b33b47a6e
2011-02-17 05:25:21 +01:00
|
|
|
if (!fifo.bFF_GPReadEnable && m_CPCtrlReg.GPReadEnable && !m_CPCtrlReg.BPEnable)
|
|
|
|
{
|
2013-03-25 22:23:20 +01:00
|
|
|
CoreTiming::ForceExceptionCheck(0);
|
Big Fifo Commit Part2: Now the fifo is more stable than my first commit, so is time...
- ReImplementing Single Core Mode like Dual Core Mode Style.
- Stage 1: My goal is, we have the Fifo, CommandProccessor code the more clear, maintenible and documented possible. When I quit dolphin I want any developer can continue with the work only reading the code.
* Big Refactoring: A lot of functions was changed the names, and modularized.
Now the FifoLoop and CatchUpGPU does not exist, was replaced by RunGpu() and RunGpuLoop().
The general idea is modeling the code like the real HW. The fifo is only a buffer where the Write Gather Pipe write the commands and from the Graphic Processor read these.
* Big Clean UP a lot of obsolete code and comments was deleted, like DcFakeWachDog, "Fifo very soon hack", etc.
In the stage 2, I will refactoring more code doing emphasis in the division of CommandProcessor, Fifo, Gpu Emulation. Beside I will comment all functions and variables in the code (Don't worry I will ask for English help for this part ;) )
Please test a lot SC mode and DC mode :)
Thank you so much for testing always and the patience. I don't like broke your favorite game but... you must believe me this part is very sensible, I only try to contribute for have a better and stable dolphin emulator.
git-svn-id: https://dolphin-emu.googlecode.com/svn/trunk@7185 8ced0084-cf51-0410-be5f-012b33b47a6e
2011-02-17 05:25:21 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
fifo.bFF_BPInt = m_CPCtrlReg.BPInt;
|
|
|
|
fifo.bFF_BPEnable = m_CPCtrlReg.BPEnable;
|
|
|
|
fifo.bFF_HiWatermarkInt = m_CPCtrlReg.FifoOverflowIntEnable;
|
|
|
|
fifo.bFF_LoWatermarkInt = m_CPCtrlReg.FifoUnderflowIntEnable;
|
|
|
|
fifo.bFF_GPLinkEnable = m_CPCtrlReg.GPLinkEnable;
|
|
|
|
|
2014-03-10 12:30:55 +01:00
|
|
|
if (m_CPCtrlReg.GPReadEnable && m_CPCtrlReg.GPLinkEnable)
|
Big Fifo Commit Part2: Now the fifo is more stable than my first commit, so is time...
- ReImplementing Single Core Mode like Dual Core Mode Style.
- Stage 1: My goal is, we have the Fifo, CommandProccessor code the more clear, maintenible and documented possible. When I quit dolphin I want any developer can continue with the work only reading the code.
* Big Refactoring: A lot of functions was changed the names, and modularized.
Now the FifoLoop and CatchUpGPU does not exist, was replaced by RunGpu() and RunGpuLoop().
The general idea is modeling the code like the real HW. The fifo is only a buffer where the Write Gather Pipe write the commands and from the Graphic Processor read these.
* Big Clean UP a lot of obsolete code and comments was deleted, like DcFakeWachDog, "Fifo very soon hack", etc.
In the stage 2, I will refactoring more code doing emphasis in the division of CommandProcessor, Fifo, Gpu Emulation. Beside I will comment all functions and variables in the code (Don't worry I will ask for English help for this part ;) )
Please test a lot SC mode and DC mode :)
Thank you so much for testing always and the patience. I don't like broke your favorite game but... you must believe me this part is very sensible, I only try to contribute for have a better and stable dolphin emulator.
git-svn-id: https://dolphin-emu.googlecode.com/svn/trunk@7185 8ced0084-cf51-0410-be5f-012b33b47a6e
2011-02-17 05:25:21 +01:00
|
|
|
{
|
|
|
|
ProcessorInterface::Fifo_CPUWritePointer = fifo.CPWritePointer;
|
|
|
|
ProcessorInterface::Fifo_CPUBase = fifo.CPBase;
|
|
|
|
ProcessorInterface::Fifo_CPUEnd = fifo.CPEnd;
|
|
|
|
}
|
2013-10-29 06:23:17 +01:00
|
|
|
|
2014-03-10 12:30:55 +01:00
|
|
|
if (fifo.bFF_GPReadEnable && !m_CPCtrlReg.GPReadEnable)
|
Big Fifo Commit Part2: Now the fifo is more stable than my first commit, so is time...
- ReImplementing Single Core Mode like Dual Core Mode Style.
- Stage 1: My goal is, we have the Fifo, CommandProccessor code the more clear, maintenible and documented possible. When I quit dolphin I want any developer can continue with the work only reading the code.
* Big Refactoring: A lot of functions was changed the names, and modularized.
Now the FifoLoop and CatchUpGPU does not exist, was replaced by RunGpu() and RunGpuLoop().
The general idea is modeling the code like the real HW. The fifo is only a buffer where the Write Gather Pipe write the commands and from the Graphic Processor read these.
* Big Clean UP a lot of obsolete code and comments was deleted, like DcFakeWachDog, "Fifo very soon hack", etc.
In the stage 2, I will refactoring more code doing emphasis in the division of CommandProcessor, Fifo, Gpu Emulation. Beside I will comment all functions and variables in the code (Don't worry I will ask for English help for this part ;) )
Please test a lot SC mode and DC mode :)
Thank you so much for testing always and the patience. I don't like broke your favorite game but... you must believe me this part is very sensible, I only try to contribute for have a better and stable dolphin emulator.
git-svn-id: https://dolphin-emu.googlecode.com/svn/trunk@7185 8ced0084-cf51-0410-be5f-012b33b47a6e
2011-02-17 05:25:21 +01:00
|
|
|
{
|
|
|
|
fifo.bFF_GPReadEnable = m_CPCtrlReg.GPReadEnable;
|
2014-03-10 12:30:55 +01:00
|
|
|
while (fifo.isGpuReadingData) Common::YieldCPU();
|
Big Fifo Commit Part2: Now the fifo is more stable than my first commit, so is time...
- ReImplementing Single Core Mode like Dual Core Mode Style.
- Stage 1: My goal is, we have the Fifo, CommandProccessor code the more clear, maintenible and documented possible. When I quit dolphin I want any developer can continue with the work only reading the code.
* Big Refactoring: A lot of functions was changed the names, and modularized.
Now the FifoLoop and CatchUpGPU does not exist, was replaced by RunGpu() and RunGpuLoop().
The general idea is modeling the code like the real HW. The fifo is only a buffer where the Write Gather Pipe write the commands and from the Graphic Processor read these.
* Big Clean UP a lot of obsolete code and comments was deleted, like DcFakeWachDog, "Fifo very soon hack", etc.
In the stage 2, I will refactoring more code doing emphasis in the division of CommandProcessor, Fifo, Gpu Emulation. Beside I will comment all functions and variables in the code (Don't worry I will ask for English help for this part ;) )
Please test a lot SC mode and DC mode :)
Thank you so much for testing always and the patience. I don't like broke your favorite game but... you must believe me this part is very sensible, I only try to contribute for have a better and stable dolphin emulator.
git-svn-id: https://dolphin-emu.googlecode.com/svn/trunk@7185 8ced0084-cf51-0410-be5f-012b33b47a6e
2011-02-17 05:25:21 +01:00
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
fifo.bFF_GPReadEnable = m_CPCtrlReg.GPReadEnable;
|
|
|
|
}
|
|
|
|
|
|
|
|
DEBUG_LOG(COMMANDPROCESSOR, "\t GPREAD %s | BP %s | Int %s | OvF %s | UndF %s | LINK %s"
|
2014-02-16 21:30:18 +01:00
|
|
|
, fifo.bFF_GPReadEnable ? "ON" : "OFF"
|
|
|
|
, fifo.bFF_BPEnable ? "ON" : "OFF"
|
|
|
|
, fifo.bFF_BPInt ? "ON" : "OFF"
|
|
|
|
, m_CPCtrlReg.FifoOverflowIntEnable ? "ON" : "OFF"
|
|
|
|
, m_CPCtrlReg.FifoUnderflowIntEnable ? "ON" : "OFF"
|
|
|
|
, m_CPCtrlReg.GPLinkEnable ? "ON" : "OFF"
|
Big Fifo Commit Part2: Now the fifo is more stable than my first commit, so is time...
- ReImplementing Single Core Mode like Dual Core Mode Style.
- Stage 1: My goal is, we have the Fifo, CommandProccessor code the more clear, maintenible and documented possible. When I quit dolphin I want any developer can continue with the work only reading the code.
* Big Refactoring: A lot of functions was changed the names, and modularized.
Now the FifoLoop and CatchUpGPU does not exist, was replaced by RunGpu() and RunGpuLoop().
The general idea is modeling the code like the real HW. The fifo is only a buffer where the Write Gather Pipe write the commands and from the Graphic Processor read these.
* Big Clean UP a lot of obsolete code and comments was deleted, like DcFakeWachDog, "Fifo very soon hack", etc.
In the stage 2, I will refactoring more code doing emphasis in the division of CommandProcessor, Fifo, Gpu Emulation. Beside I will comment all functions and variables in the code (Don't worry I will ask for English help for this part ;) )
Please test a lot SC mode and DC mode :)
Thank you so much for testing always and the patience. I don't like broke your favorite game but... you must believe me this part is very sensible, I only try to contribute for have a better and stable dolphin emulator.
git-svn-id: https://dolphin-emu.googlecode.com/svn/trunk@7185 8ced0084-cf51-0410-be5f-012b33b47a6e
2011-02-17 05:25:21 +01:00
|
|
|
);
|
|
|
|
|
|
|
|
}
|
|
|
|
|
2012-01-21 14:58:29 +01:00
|
|
|
// NOTE: The implementation of this function should be correct, but we intentionally aren't using it at the moment.
|
|
|
|
// We don't emulate proper GP timing anyway at the moment, so this code would just slow down emulation.
|
Big Fifo Commit Part2: Now the fifo is more stable than my first commit, so is time...
- ReImplementing Single Core Mode like Dual Core Mode Style.
- Stage 1: My goal is, we have the Fifo, CommandProccessor code the more clear, maintenible and documented possible. When I quit dolphin I want any developer can continue with the work only reading the code.
* Big Refactoring: A lot of functions was changed the names, and modularized.
Now the FifoLoop and CatchUpGPU does not exist, was replaced by RunGpu() and RunGpuLoop().
The general idea is modeling the code like the real HW. The fifo is only a buffer where the Write Gather Pipe write the commands and from the Graphic Processor read these.
* Big Clean UP a lot of obsolete code and comments was deleted, like DcFakeWachDog, "Fifo very soon hack", etc.
In the stage 2, I will refactoring more code doing emphasis in the division of CommandProcessor, Fifo, Gpu Emulation. Beside I will comment all functions and variables in the code (Don't worry I will ask for English help for this part ;) )
Please test a lot SC mode and DC mode :)
Thank you so much for testing always and the patience. I don't like broke your favorite game but... you must believe me this part is very sensible, I only try to contribute for have a better and stable dolphin emulator.
git-svn-id: https://dolphin-emu.googlecode.com/svn/trunk@7185 8ced0084-cf51-0410-be5f-012b33b47a6e
2011-02-17 05:25:21 +01:00
|
|
|
void SetCpClearRegister()
|
|
|
|
{
|
2014-02-17 05:51:41 +01:00
|
|
|
// if (IsOnThread())
|
|
|
|
// {
|
|
|
|
// if (!m_CPClearReg.ClearFifoUnderflow && m_CPClearReg.ClearFifoOverflow)
|
|
|
|
// bProcessFifoToLoWatermark = true;
|
|
|
|
// }
|
Big Fifo Commit Part2: Now the fifo is more stable than my first commit, so is time...
- ReImplementing Single Core Mode like Dual Core Mode Style.
- Stage 1: My goal is, we have the Fifo, CommandProccessor code the more clear, maintenible and documented possible. When I quit dolphin I want any developer can continue with the work only reading the code.
* Big Refactoring: A lot of functions was changed the names, and modularized.
Now the FifoLoop and CatchUpGPU does not exist, was replaced by RunGpu() and RunGpuLoop().
The general idea is modeling the code like the real HW. The fifo is only a buffer where the Write Gather Pipe write the commands and from the Graphic Processor read these.
* Big Clean UP a lot of obsolete code and comments was deleted, like DcFakeWachDog, "Fifo very soon hack", etc.
In the stage 2, I will refactoring more code doing emphasis in the division of CommandProcessor, Fifo, Gpu Emulation. Beside I will comment all functions and variables in the code (Don't worry I will ask for English help for this part ;) )
Please test a lot SC mode and DC mode :)
Thank you so much for testing always and the patience. I don't like broke your favorite game but... you must believe me this part is very sensible, I only try to contribute for have a better and stable dolphin emulator.
git-svn-id: https://dolphin-emu.googlecode.com/svn/trunk@7185 8ced0084-cf51-0410-be5f-012b33b47a6e
2011-02-17 05:25:21 +01:00
|
|
|
}
|
2010-12-11 13:42:55 +01:00
|
|
|
|
2013-02-16 02:51:09 +01:00
|
|
|
void Update()
|
|
|
|
{
|
|
|
|
while (VITicks > m_cpClockOrigin && fifo.isGpuReadingData && IsOnThread())
|
|
|
|
Common::YieldCPU();
|
|
|
|
|
|
|
|
if (fifo.isGpuReadingData)
|
|
|
|
Common::AtomicAdd(VITicks, SystemTimers::GetTicksPerSecond() / 10000);
|
|
|
|
}
|
2010-06-09 03:37:08 +02:00
|
|
|
} // end of namespace CommandProcessor
|