2015-05-24 04:55:12 +00:00
|
|
|
// Copyright 2008 Dolphin Emulator Project
|
2021-07-05 01:22:19 +00:00
|
|
|
// SPDX-License-Identifier: GPL-2.0-or-later
|
2010-06-09 01:37:08 +00:00
|
|
|
|
2014-02-10 18:54:46 +00:00
|
|
|
#pragma once
|
2010-06-09 01:37:08 +00:00
|
|
|
|
2021-05-13 16:44:59 +00:00
|
|
|
#include <atomic>
|
|
|
|
|
2014-09-08 01:06:58 +00:00
|
|
|
#include "Common/CommonTypes.h"
|
2010-06-09 01:37:08 +00:00
|
|
|
|
2009-10-10 21:19:39 +00:00
|
|
|
class PointerWrap;
|
2014-02-02 13:16:43 +00:00
|
|
|
namespace MMIO
|
|
|
|
{
|
|
|
|
class Mapping;
|
|
|
|
}
|
2010-06-09 01:37:08 +00:00
|
|
|
|
2009-10-10 21:19:39 +00:00
|
|
|
namespace CommandProcessor
|
|
|
|
{
|
2017-01-27 08:44:31 +00:00
|
|
|
struct SCPFifoStruct
|
|
|
|
{
|
|
|
|
// fifo registers
|
2021-05-13 16:44:59 +00:00
|
|
|
std::atomic<u32> CPBase;
|
|
|
|
std::atomic<u32> CPEnd;
|
2021-09-04 04:43:19 +00:00
|
|
|
u32 CPHiWatermark = 0;
|
|
|
|
u32 CPLoWatermark = 0;
|
2021-05-13 16:44:59 +00:00
|
|
|
std::atomic<u32> CPReadWriteDistance;
|
|
|
|
std::atomic<u32> CPWritePointer;
|
|
|
|
std::atomic<u32> CPReadPointer;
|
|
|
|
std::atomic<u32> CPBreakpoint;
|
|
|
|
std::atomic<u32> SafeCPReadPointer;
|
2017-01-27 08:44:31 +00:00
|
|
|
|
2021-05-13 17:30:30 +00:00
|
|
|
std::atomic<u32> bFF_GPLinkEnable;
|
|
|
|
std::atomic<u32> bFF_GPReadEnable;
|
|
|
|
std::atomic<u32> bFF_BPEnable;
|
|
|
|
std::atomic<u32> bFF_BPInt;
|
|
|
|
std::atomic<u32> bFF_Breakpoint;
|
2017-01-27 08:44:31 +00:00
|
|
|
|
2021-05-13 17:30:30 +00:00
|
|
|
std::atomic<u32> bFF_LoWatermarkInt;
|
|
|
|
std::atomic<u32> bFF_HiWatermarkInt;
|
2017-01-27 08:44:31 +00:00
|
|
|
|
2021-05-13 17:30:30 +00:00
|
|
|
std::atomic<u32> bFF_LoWatermark;
|
|
|
|
std::atomic<u32> bFF_HiWatermark;
|
2017-11-12 16:20:59 +00:00
|
|
|
|
2021-05-17 19:55:03 +00:00
|
|
|
void Init();
|
2017-11-12 16:20:59 +00:00
|
|
|
void DoState(PointerWrap& p);
|
2017-01-27 08:44:31 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
// This one is shared between gfx thread and emulator thread.
|
|
|
|
// It is only used by the Fifo and by the CommandProcessor.
|
|
|
|
extern SCPFifoStruct fifo;
|
2013-10-29 05:23:17 +00:00
|
|
|
|
2009-10-10 21:19:39 +00:00
|
|
|
// internal hardware addresses
|
|
|
|
enum
|
|
|
|
{
|
|
|
|
STATUS_REGISTER = 0x00,
|
|
|
|
CTRL_REGISTER = 0x02,
|
|
|
|
CLEAR_REGISTER = 0x04,
|
2009-12-31 16:25:12 +00:00
|
|
|
PERF_SELECT = 0x06,
|
2009-10-10 21:19:39 +00:00
|
|
|
FIFO_TOKEN_REGISTER = 0x0E,
|
|
|
|
FIFO_BOUNDING_BOX_LEFT = 0x10,
|
|
|
|
FIFO_BOUNDING_BOX_RIGHT = 0x12,
|
|
|
|
FIFO_BOUNDING_BOX_TOP = 0x14,
|
|
|
|
FIFO_BOUNDING_BOX_BOTTOM = 0x16,
|
|
|
|
FIFO_BASE_LO = 0x20,
|
|
|
|
FIFO_BASE_HI = 0x22,
|
|
|
|
FIFO_END_LO = 0x24,
|
|
|
|
FIFO_END_HI = 0x26,
|
|
|
|
FIFO_HI_WATERMARK_LO = 0x28,
|
|
|
|
FIFO_HI_WATERMARK_HI = 0x2a,
|
|
|
|
FIFO_LO_WATERMARK_LO = 0x2c,
|
|
|
|
FIFO_LO_WATERMARK_HI = 0x2e,
|
|
|
|
FIFO_RW_DISTANCE_LO = 0x30,
|
|
|
|
FIFO_RW_DISTANCE_HI = 0x32,
|
|
|
|
FIFO_WRITE_POINTER_LO = 0x34,
|
|
|
|
FIFO_WRITE_POINTER_HI = 0x36,
|
|
|
|
FIFO_READ_POINTER_LO = 0x38,
|
|
|
|
FIFO_READ_POINTER_HI = 0x3A,
|
|
|
|
FIFO_BP_LO = 0x3C,
|
|
|
|
FIFO_BP_HI = 0x3E,
|
2009-12-31 16:25:12 +00:00
|
|
|
XF_RASBUSY_L = 0x40,
|
|
|
|
XF_RASBUSY_H = 0x42,
|
|
|
|
XF_CLKS_L = 0x44,
|
|
|
|
XF_CLKS_H = 0x46,
|
|
|
|
XF_WAIT_IN_L = 0x48,
|
|
|
|
XF_WAIT_IN_H = 0x4a,
|
|
|
|
XF_WAIT_OUT_L = 0x4c,
|
|
|
|
XF_WAIT_OUT_H = 0x4e,
|
|
|
|
VCACHE_METRIC_CHECK_L = 0x50,
|
|
|
|
VCACHE_METRIC_CHECK_H = 0x52,
|
|
|
|
VCACHE_METRIC_MISS_L = 0x54,
|
|
|
|
VCACHE_METRIC_MISS_H = 0x56,
|
|
|
|
VCACHE_METRIC_STALL_L = 0x58,
|
|
|
|
VCACHE_METRIC_STALL_H = 0x5A,
|
|
|
|
CLKS_PER_VTX_IN_L = 0x60,
|
|
|
|
CLKS_PER_VTX_IN_H = 0x62,
|
|
|
|
CLKS_PER_VTX_OUT = 0x64,
|
2009-10-10 21:19:39 +00:00
|
|
|
};
|
2010-06-09 01:37:08 +00:00
|
|
|
|
2009-12-14 15:50:31 +00:00
|
|
|
enum
|
|
|
|
{
|
|
|
|
GATHER_PIPE_SIZE = 32,
|
|
|
|
INT_CAUSE_CP = 0x800
|
|
|
|
};
|
2010-06-09 01:37:08 +00:00
|
|
|
|
2009-12-14 15:50:31 +00:00
|
|
|
// Fifo Status Register
|
2017-01-04 11:45:40 +00:00
|
|
|
union UCPStatusReg
|
|
|
|
{
|
2009-12-14 15:50:31 +00:00
|
|
|
struct
|
|
|
|
{
|
2010-09-27 04:29:51 +00:00
|
|
|
u16 OverflowHiWatermark : 1;
|
|
|
|
u16 UnderflowLoWatermark : 1;
|
|
|
|
u16 ReadIdle : 1;
|
|
|
|
u16 CommandIdle : 1;
|
|
|
|
u16 Breakpoint : 1;
|
|
|
|
u16 : 11;
|
2009-12-14 15:50:31 +00:00
|
|
|
};
|
|
|
|
u16 Hex;
|
|
|
|
UCPStatusReg() { Hex = 0; }
|
|
|
|
UCPStatusReg(u16 _hex) { Hex = _hex; }
|
|
|
|
};
|
2010-06-09 01:37:08 +00:00
|
|
|
|
2009-12-14 15:50:31 +00:00
|
|
|
// Fifo Control Register
|
2017-01-04 11:45:40 +00:00
|
|
|
union UCPCtrlReg
|
|
|
|
{
|
2009-12-14 15:50:31 +00:00
|
|
|
struct
|
|
|
|
{
|
2010-09-27 04:29:51 +00:00
|
|
|
u16 GPReadEnable : 1;
|
|
|
|
u16 BPEnable : 1;
|
|
|
|
u16 FifoOverflowIntEnable : 1;
|
|
|
|
u16 FifoUnderflowIntEnable : 1;
|
|
|
|
u16 GPLinkEnable : 1;
|
|
|
|
u16 BPInt : 1;
|
|
|
|
u16 : 10;
|
2009-12-14 15:50:31 +00:00
|
|
|
};
|
|
|
|
u16 Hex;
|
|
|
|
UCPCtrlReg() { Hex = 0; }
|
|
|
|
UCPCtrlReg(u16 _hex) { Hex = _hex; }
|
|
|
|
};
|
2010-06-09 01:37:08 +00:00
|
|
|
|
2009-12-16 17:05:30 +00:00
|
|
|
// Fifo Clear Register
|
2017-01-04 11:45:40 +00:00
|
|
|
union UCPClearReg
|
|
|
|
{
|
2009-12-14 15:50:31 +00:00
|
|
|
struct
|
|
|
|
{
|
2010-09-27 04:29:51 +00:00
|
|
|
u16 ClearFifoOverflow : 1;
|
|
|
|
u16 ClearFifoUnderflow : 1;
|
|
|
|
u16 ClearMetrices : 1;
|
|
|
|
u16 : 13;
|
2009-12-14 15:50:31 +00:00
|
|
|
};
|
|
|
|
u16 Hex;
|
|
|
|
UCPClearReg() { Hex = 0; }
|
|
|
|
UCPClearReg(u16 _hex) { Hex = _hex; }
|
|
|
|
};
|
2010-06-09 01:37:08 +00:00
|
|
|
|
2009-10-10 21:19:39 +00:00
|
|
|
// Init
|
|
|
|
void Init();
|
|
|
|
void DoState(PointerWrap& p);
|
2010-06-09 01:37:08 +00:00
|
|
|
|
2014-02-02 13:16:43 +00:00
|
|
|
void RegisterMMIO(MMIO::Mapping* mmio, u32 base);
|
|
|
|
|
2014-08-24 20:27:32 +00:00
|
|
|
void SetCPStatusFromGPU();
|
|
|
|
void SetCPStatusFromCPU();
|
2009-10-10 21:19:39 +00:00
|
|
|
void GatherPipeBursted();
|
2010-12-11 12:42:55 +00:00
|
|
|
void UpdateInterrupts(u64 userdata);
|
2011-02-14 02:18:03 +00:00
|
|
|
void UpdateInterruptsFromVideoBackend(u64 userdata);
|
2010-06-09 01:37:08 +00:00
|
|
|
|
2015-05-27 07:08:48 +00:00
|
|
|
bool IsInterruptWaiting();
|
|
|
|
|
2012-01-21 13:58:29 +00:00
|
|
|
void SetCpClearRegister();
|
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 04:25:21 +00:00
|
|
|
void SetCpControlRegister();
|
|
|
|
void SetCpStatusRegister();
|
2013-02-16 01:51:09 +00:00
|
|
|
|
2017-01-27 08:44:31 +00:00
|
|
|
void HandleUnknownOpcode(u8 cmd_byte, void* buffer, bool preprocess);
|
|
|
|
|
2019-05-31 06:46:17 +00:00
|
|
|
u32 GetPhysicalAddressMask();
|
|
|
|
|
2009-10-10 21:19:39 +00:00
|
|
|
} // namespace CommandProcessor
|