2013-07-03 18:17:16 +02:00
|
|
|
#pragma once
|
2013-11-03 20:23:16 +01:00
|
|
|
#include "Emu/CPU/CPUDecoder.h"
|
2013-07-03 18:17:16 +02:00
|
|
|
#include "PPCInstrTable.h"
|
|
|
|
|
|
2013-11-05 19:12:18 +01:00
|
|
|
class PPCDecoder : public CPUDecoder
|
2013-07-03 18:17:16 +02:00
|
|
|
{
|
|
|
|
|
public:
|
|
|
|
|
virtual void Decode(const u32 code)=0;
|
2013-11-05 19:12:18 +01:00
|
|
|
|
2013-11-05 20:22:58 +01:00
|
|
|
virtual u8 DecodeMemory(const u64 address);
|
2014-04-15 16:12:15 +02:00
|
|
|
|
|
|
|
|
virtual ~PPCDecoder() = default;
|
2013-07-03 18:17:16 +02:00
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
2013-07-04 16:20:36 +02:00
|
|
|
template<typename TO, uint from, uint to>
|
2014-04-06 21:23:32 +02:00
|
|
|
static InstrList<(1 << (CodeField<from, to>::size)), TO>* new_list(const CodeField<from, to>& func, InstrCaller<TO>* error_func = nullptr)
|
2013-07-03 18:17:16 +02:00
|
|
|
{
|
2014-04-06 21:23:32 +02:00
|
|
|
return new InstrList<(1 << (CodeField<from, to>::size)), TO>(func, error_func);
|
2013-07-03 18:17:16 +02:00
|
|
|
}
|
|
|
|
|
|
2013-07-04 16:20:36 +02:00
|
|
|
template<int count, typename TO, uint from, uint to>
|
2014-04-06 21:23:32 +02:00
|
|
|
static InstrList<(1 << (CodeField<from, to>::size)), TO>* new_list(InstrList<count, TO>* parent, int opcode, const CodeField<from, to>& func, InstrCaller<TO>* error_func = nullptr)
|
2013-07-03 18:17:16 +02:00
|
|
|
{
|
2014-04-06 21:23:32 +02:00
|
|
|
return connect_list(parent, new InstrList<(1 << (CodeField<from, to>::size)), TO>(func, error_func), opcode);
|
2013-07-03 18:17:16 +02:00
|
|
|
}
|
|
|
|
|
|
2013-07-04 16:20:36 +02:00
|
|
|
template<int count, typename TO, uint from, uint to>
|
2014-04-06 21:23:32 +02:00
|
|
|
static InstrList<(1 << (CodeField<from, to>::size)), TO>* new_list(InstrList<count, TO>* parent, const CodeField<from, to>& func, InstrCaller<TO>* error_func = nullptr)
|
2013-07-03 18:17:16 +02:00
|
|
|
{
|
2014-04-06 21:23:32 +02:00
|
|
|
return connect_list(parent, new InstrList<(1 << (CodeField<from, to>::size)), TO>(func, error_func));
|
2013-07-03 18:17:16 +02:00
|
|
|
}
|