2016-08-12 19:17:31 +02:00
|
|
|
/* This file is part of the dynarmic project.
|
|
|
|
* Copyright (c) 2016 MerryMage
|
|
|
|
* This software may be used and distributed according to the terms of the GNU
|
|
|
|
* General Public License version 2 or any later version.
|
|
|
|
*/
|
|
|
|
|
2016-08-17 14:29:05 +02:00
|
|
|
#include <array>
|
2016-08-12 19:17:31 +02:00
|
|
|
#include <map>
|
|
|
|
#include <vector>
|
|
|
|
|
|
|
|
#include "frontend/ir/opcodes.h"
|
|
|
|
|
|
|
|
namespace Dynarmic {
|
|
|
|
namespace IR {
|
|
|
|
|
|
|
|
// Opcode information
|
|
|
|
|
|
|
|
namespace OpcodeInfo {
|
|
|
|
|
|
|
|
using T = Dynarmic::IR::Type;
|
|
|
|
|
|
|
|
struct Meta {
|
|
|
|
const char* name;
|
|
|
|
Type type;
|
|
|
|
std::vector<Type> arg_types;
|
|
|
|
};
|
|
|
|
|
|
|
|
static const std::map<Opcode, Meta> opcode_info {{
|
|
|
|
#define OPCODE(name, type, ...) { Opcode::name, { #name, type, { __VA_ARGS__ } } },
|
2018-01-01 17:19:43 +01:00
|
|
|
#define A32OPC(name, type, ...) { Opcode::A32##name, { #name, type, { __VA_ARGS__ } } },
|
2018-01-07 01:11:57 +01:00
|
|
|
#define A64OPC(name, type, ...) { Opcode::A64##name, { #name, type, { __VA_ARGS__ } } },
|
2016-08-12 19:17:31 +02:00
|
|
|
#include "opcodes.inc"
|
|
|
|
#undef OPCODE
|
2018-01-01 17:19:43 +01:00
|
|
|
#undef A32OPC
|
2018-01-07 01:11:57 +01:00
|
|
|
#undef A64OPC
|
2016-12-31 11:46:13 +01:00
|
|
|
}};
|
2016-08-12 19:17:31 +02:00
|
|
|
|
|
|
|
} // namespace OpcodeInfo
|
|
|
|
|
|
|
|
Type GetTypeOf(Opcode op) {
|
|
|
|
return OpcodeInfo::opcode_info.at(op).type;
|
|
|
|
}
|
|
|
|
|
|
|
|
size_t GetNumArgsOf(Opcode op) {
|
|
|
|
return OpcodeInfo::opcode_info.at(op).arg_types.size();
|
|
|
|
}
|
|
|
|
|
|
|
|
Type GetArgTypeOf(Opcode op, size_t arg_index) {
|
|
|
|
return OpcodeInfo::opcode_info.at(op).arg_types.at(arg_index);
|
|
|
|
}
|
|
|
|
|
|
|
|
const char* GetNameOf(Opcode op) {
|
|
|
|
return OpcodeInfo::opcode_info.at(op).name;
|
|
|
|
}
|
|
|
|
|
2016-08-17 14:29:05 +02:00
|
|
|
const char* GetNameOf(Type type) {
|
2018-01-05 21:30:41 +01:00
|
|
|
static const std::array<const char*, 14> names = {
|
|
|
|
"Void", "A32Reg", "A32ExtReg", "A64Reg", "A64Vec", "Opaque", "U1", "U8", "U16", "U32", "U64", "F32", "F64", "CoprocInfo"
|
2016-08-17 14:29:05 +02:00
|
|
|
};
|
|
|
|
return names.at(static_cast<size_t>(type));
|
|
|
|
}
|
|
|
|
|
2016-08-19 02:34:14 +02:00
|
|
|
bool AreTypesCompatible(Type t1, Type t2) {
|
|
|
|
return t1 == t2 || t1 == Type::Opaque || t2 == Type::Opaque;
|
|
|
|
}
|
|
|
|
|
2016-08-12 19:17:31 +02:00
|
|
|
} // namespace IR
|
|
|
|
} // namespace Dynarmic
|