mirror of
https://github.com/RPCS3/rpcs3.git
synced 2025-07-10 08:51:28 +12:00
75 lines
No EOL
2 KiB
C++
75 lines
No EOL
2 KiB
C++
#pragma once
|
|
#include "SPUThread.h"
|
|
#include "Emu/event.h"
|
|
|
|
enum
|
|
{
|
|
MFC_LSA_offs = 0x3004,
|
|
MFC_EAH_offs = 0x3008,
|
|
MFC_EAL_offs = 0x300C,
|
|
MFC_Size_Tag_offs = 0x3010,
|
|
MFC_Class_CMD_offs = 0x3014,
|
|
MFC_CMDStatus_offs = 0x3014,
|
|
MFC_QStatus_offs = 0x3104,
|
|
Prxy_QueryType_offs = 0x3204,
|
|
Prxy_QueryMask_offs = 0x321C,
|
|
Prxy_TagStatus_offs = 0x322C,
|
|
SPU_Out_MBox_offs = 0x4004,
|
|
SPU_In_MBox_offs = 0x400C,
|
|
SPU_MBox_Status_offs = 0x4014,
|
|
SPU_RunCntl_offs = 0x401C,
|
|
SPU_Status_offs = 0x4024,
|
|
SPU_NPC_offs = 0x4034,
|
|
SPU_RdSigNotify1_offs = 0x1400C,
|
|
SPU_RdSigNotify2_offs = 0x1C00C,
|
|
};
|
|
|
|
enum : u64
|
|
{
|
|
RAW_SPU_OFFSET = 0x0000000000100000,
|
|
RAW_SPU_BASE_ADDR = 0x00000000E0000000,
|
|
RAW_SPU_LS_OFFSET = 0x0000000000000000,
|
|
RAW_SPU_PROB_OFFSET = 0x0000000000040000,
|
|
};
|
|
|
|
__forceinline static u32 GetRawSPURegAddrByNum(int num, int offset)
|
|
{
|
|
return RAW_SPU_OFFSET * num + RAW_SPU_BASE_ADDR + RAW_SPU_PROB_OFFSET + offset;
|
|
}
|
|
|
|
__forceinline static u32 GetRawSPURegAddrById(int id, int offset)
|
|
{
|
|
return GetRawSPURegAddrByNum(Emu.GetCPU().GetThreadNumById(CPU_THREAD_RAW_SPU, id), offset);
|
|
}
|
|
|
|
class RawSPUThread
|
|
: public SPUThread
|
|
, public MemoryBlock
|
|
{
|
|
u32 m_index;
|
|
|
|
public:
|
|
RawSPUThread(u32 index, CPUThreadType type = CPU_THREAD_RAW_SPU);
|
|
virtual ~RawSPUThread();
|
|
|
|
virtual bool Read8(const u64 addr, u8* value) override;
|
|
virtual bool Read16(const u64 addr, u16* value) override;
|
|
virtual bool Read32(const u64 addr, u32* value) override;
|
|
virtual bool Read64(const u64 addr, u64* value) override;
|
|
virtual bool Read128(const u64 addr, u128* value) override;
|
|
|
|
virtual bool Write8(const u64 addr, const u8 value) override;
|
|
virtual bool Write16(const u64 addr, const u16 value) override;
|
|
virtual bool Write32(const u64 addr, const u32 value) override;
|
|
virtual bool Write64(const u64 addr, const u64 value) override;
|
|
virtual bool Write128(const u64 addr, const u128 value) override;
|
|
|
|
public:
|
|
virtual void InitRegs();
|
|
u32 GetIndex() const;
|
|
|
|
private:
|
|
virtual void Task();
|
|
};
|
|
|
|
SPUThread& GetCurrentSPUThread(); |