2013-04-17 23:09:55 -04:00
|
|
|
// Copyright 2013 Dolphin Emulator Project
|
|
|
|
// Licensed under GPLv2
|
|
|
|
// Refer to the license.txt file included.
|
2010-06-09 01:37:08 +00:00
|
|
|
|
|
|
|
#ifndef _COMMANDPROCESSOR_H
|
|
|
|
#define _COMMANDPROCESSOR_H
|
|
|
|
|
|
|
|
#include "Common.h"
|
2011-01-31 01:28:32 +00:00
|
|
|
#include "VideoBackendBase.h"
|
2010-06-09 01:37:08 +00:00
|
|
|
|
|
|
|
class PointerWrap;
|
|
|
|
|
|
|
|
extern bool MT;
|
|
|
|
|
|
|
|
namespace CommandProcessor
|
|
|
|
{
|
|
|
|
|
2010-06-24 13:28:54 +00:00
|
|
|
extern SCPFifoStruct fifo; //This one is shared between gfx thread and emulator thread.
|
2011-02-10 04:47:02 +00:00
|
|
|
extern volatile bool isPossibleWaitingSetDrawDone; //This one is used for sync gfx thread and emulator thread.
|
2012-03-05 02:40:10 -03:00
|
|
|
extern volatile bool isHiWatermarkActive;
|
2013-01-25 20:04:31 +11:00
|
|
|
extern volatile bool isLoWatermarkActive;
|
2010-12-11 12:42:55 +00:00
|
|
|
extern volatile bool interruptSet;
|
|
|
|
extern volatile bool interruptWaiting;
|
2010-12-13 07:56:54 +00:00
|
|
|
extern volatile bool interruptTokenWaiting;
|
|
|
|
extern volatile bool interruptFinishWaiting;
|
2012-03-18 22:54:58 -03:00
|
|
|
extern volatile bool waitingForPEInterruptDisable;
|
|
|
|
|
2010-06-09 01:37:08 +00:00
|
|
|
// internal hardware addresses
|
|
|
|
enum
|
|
|
|
{
|
|
|
|
STATUS_REGISTER = 0x00,
|
|
|
|
CTRL_REGISTER = 0x02,
|
|
|
|
CLEAR_REGISTER = 0x04,
|
|
|
|
PERF_SELECT = 0x06,
|
|
|
|
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,
|
|
|
|
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,
|
|
|
|
};
|
|
|
|
|
|
|
|
enum
|
|
|
|
{
|
|
|
|
GATHER_PIPE_SIZE = 32,
|
2013-04-24 09:21:54 -04:00
|
|
|
INT_CAUSE_CP = 0x800
|
2010-06-09 01:37:08 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
// Fifo Status Register
|
|
|
|
union UCPStatusReg
|
|
|
|
{
|
|
|
|
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;
|
2010-06-09 01:37:08 +00:00
|
|
|
};
|
|
|
|
u16 Hex;
|
|
|
|
UCPStatusReg() {Hex = 0; }
|
|
|
|
UCPStatusReg(u16 _hex) {Hex = _hex; }
|
|
|
|
};
|
|
|
|
|
|
|
|
// Fifo Control Register
|
|
|
|
union UCPCtrlReg
|
|
|
|
{
|
|
|
|
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;
|
2010-06-09 01:37:08 +00:00
|
|
|
};
|
|
|
|
u16 Hex;
|
|
|
|
UCPCtrlReg() {Hex = 0; }
|
|
|
|
UCPCtrlReg(u16 _hex) {Hex = _hex; }
|
|
|
|
};
|
|
|
|
|
|
|
|
// Fifo Clear Register
|
|
|
|
union UCPClearReg
|
|
|
|
{
|
|
|
|
struct
|
|
|
|
{
|
2010-09-27 04:29:51 +00:00
|
|
|
u16 ClearFifoOverflow : 1;
|
|
|
|
u16 ClearFifoUnderflow : 1;
|
|
|
|
u16 ClearMetrices : 1;
|
|
|
|
u16 : 13;
|
2010-06-09 01:37:08 +00:00
|
|
|
};
|
|
|
|
u16 Hex;
|
|
|
|
UCPClearReg() {Hex = 0; }
|
|
|
|
UCPClearReg(u16 _hex) {Hex = _hex; }
|
|
|
|
};
|
|
|
|
|
2013-02-16 12:51:09 +11:00
|
|
|
// Can be any number, low enough to not be below the number of clocks executed by the GPU per CP_PERIOD
|
|
|
|
const static u32 m_cpClockOrigin = 200000;
|
|
|
|
|
2010-06-09 01:37:08 +00:00
|
|
|
// Init
|
|
|
|
void Init();
|
|
|
|
void Shutdown();
|
|
|
|
void DoState(PointerWrap &p);
|
|
|
|
|
|
|
|
// Read
|
|
|
|
void Read16(u16& _rReturnValue, const u32 _Address);
|
|
|
|
void Write16(const u16 _Data, const u32 _Address);
|
|
|
|
void Read32(u32& _rReturnValue, const u32 _Address);
|
|
|
|
void Write32(const u32 _Data, const u32 _Address);
|
|
|
|
|
2013-03-14 01:08:26 -05:00
|
|
|
void SetCpStatus(bool isCPUThread = false);
|
2010-06-09 01:37:08 +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
|
|
|
|
|
|
|
bool AllowIdleSkipping();
|
|
|
|
|
2012-01-21 14:58:29 +01: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();
|
2011-02-08 10:37:47 +00:00
|
|
|
void ProcessFifoToLoWatermark();
|
2010-12-11 12:42:55 +00:00
|
|
|
void ProcessFifoAllDistance();
|
2010-12-13 07:56:54 +00:00
|
|
|
void ProcessFifoEvents();
|
2010-08-10 07:25:35 +00:00
|
|
|
void AbortFrame();
|
2013-02-16 12:51:09 +11:00
|
|
|
|
|
|
|
void Update();
|
|
|
|
extern volatile u32 VITicks;
|
|
|
|
|
2010-06-09 01:37:08 +00:00
|
|
|
} // namespace CommandProcessor
|
|
|
|
|
|
|
|
#endif // _COMMANDPROCESSOR_H
|
|
|
|
|
|
|
|
|