2013-07-12 14:42:17 +02:00
|
|
|
#pragma once
|
|
|
|
|
#include "SPUThread.h"
|
|
|
|
|
|
|
|
|
|
__forceinline static u32 GetRawSPURegAddrByNum(int num, int offset)
|
|
|
|
|
{
|
|
|
|
|
return RAW_SPU_OFFSET * num + RAW_SPU_BASE_ADDR + RAW_SPU_PROB_OFFSET + offset;
|
|
|
|
|
}
|
|
|
|
|
|
2013-11-03 20:23:16 +01:00
|
|
|
class RawSPUThread
|
|
|
|
|
: public SPUThread
|
|
|
|
|
, public MemoryBlock
|
2013-07-12 14:42:17 +02:00
|
|
|
{
|
2013-11-03 20:23:16 +01:00
|
|
|
u32 m_index;
|
|
|
|
|
|
2013-07-12 14:42:17 +02:00
|
|
|
public:
|
2014-07-16 14:06:58 +02:00
|
|
|
RawSPUThread(CPUThreadType type = CPU_THREAD_RAW_SPU);
|
2014-02-02 20:42:32 +01:00
|
|
|
virtual ~RawSPUThread();
|
2013-07-12 14:42:17 +02:00
|
|
|
|
2015-03-02 03:10:41 +01:00
|
|
|
void start();
|
|
|
|
|
|
2015-02-12 21:10:25 +01:00
|
|
|
bool Read32(const u32 addr, u32* value);
|
|
|
|
|
bool Write32(const u32 addr, const u32 value);
|
2013-07-12 14:42:17 +02:00
|
|
|
|
|
|
|
|
public:
|
|
|
|
|
virtual void InitRegs();
|
2013-11-03 20:23:16 +01:00
|
|
|
u32 GetIndex() const;
|
2013-07-12 14:42:17 +02:00
|
|
|
|
|
|
|
|
private:
|
|
|
|
|
virtual void Task();
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
SPUThread& GetCurrentSPUThread();
|