mirror of
https://github.com/open-goal/jak-project.git
synced 2024-10-20 21:27:52 -04:00
345b8e30d8
Mostly revolved around the new MSVC check for functions that don't cover all paths (ie. a switch statement without a default case). It appears to not see an assert as a valid default case. I switched assert(false) to exceptions in these cases. I believe this should also abort the program, but will also provide a hopefully useful message? Hopefully this is an improvement. Resolves #32
67 lines
2.4 KiB
C++
67 lines
2.4 KiB
C++
#include "Register.h"
|
|
#include <stdexcept>
|
|
|
|
namespace emitter {
|
|
RegisterInfo RegisterInfo::make_register_info() {
|
|
RegisterInfo info;
|
|
|
|
info.m_info[RAX] = {-1, false, false, "rax"}; // temp
|
|
info.m_info[RCX] = {3, false, false, "rcx"}; // temp
|
|
info.m_info[RDX] = {2, false, false, "rdx"}; // temp
|
|
info.m_info[RBX] = {-1, true, false, "rbx"}; //
|
|
info.m_info[RSP] = {-1, false, true, "rsp"};
|
|
info.m_info[RBP] = {-1, true, false, "rbp"};
|
|
info.m_info[RSI] = {1, false, false, "rsi"};
|
|
info.m_info[RDI] = {0, false, false, "rdi"};
|
|
|
|
info.m_info[R8] = {4, false, false, "r8"};
|
|
info.m_info[R9] = {5, false, false, "r9"};
|
|
info.m_info[R10] = {6, true, false, "r10"};
|
|
info.m_info[R11] = {7, true, false, "r11"};
|
|
info.m_info[R12] = {-1, true, false, "r12"};
|
|
info.m_info[R13] = {-1, false, true, "r13"}; // pp?
|
|
info.m_info[R14] = {-1, false, true, "r14"}; // st?
|
|
info.m_info[R15] = {-1, false, true, "r15"}; // offset.
|
|
|
|
info.m_arg_regs = std::array<Register, N_ARGS>({RDI, RSI, RDX, RCX, R8, R9, R10, R11});
|
|
info.m_saved_gprs = std::array<Register, N_SAVED_GPRS>({RBX, RBP, R10, R11, R12});
|
|
info.m_saved_xmms =
|
|
std::array<Register, N_SAVED_XMMS>({XMM8, XMM9, XMM10, XMM11, XMM12, XMM13, XMM14, XMM15});
|
|
|
|
for (size_t i = 0; i < N_SAVED_GPRS; i++) {
|
|
info.m_saved_all[i] = info.m_saved_gprs[i];
|
|
}
|
|
for (size_t i = 0; i < N_SAVED_XMMS; i++) {
|
|
info.m_saved_all[i + N_SAVED_GPRS] = info.m_saved_xmms[i];
|
|
}
|
|
|
|
// todo - experiment with better orders for allocation.
|
|
info.m_gpr_alloc_order = {RAX, RCX, RDX, RBX, RBP, RSI, RDI, R8, R9, R10, R11}; // arbitrary
|
|
info.m_xmm_alloc_order = {XMM0, XMM1, XMM2, XMM3, XMM4, XMM5, XMM6, XMM7,
|
|
XMM8, XMM9, XMM10, XMM11, XMM12, XMM13, XMM14};
|
|
|
|
info.m_gpr_spill_temp_alloc_order = {RAX, RCX, RDX, RBX, RBP, RSI,
|
|
RDI, R8, R9, R10, R11, R12}; // arbitrary
|
|
info.m_xmm_spill_temp_alloc_order = {XMM0, XMM1, XMM2, XMM3, XMM4, XMM5, XMM6, XMM7,
|
|
XMM8, XMM9, XMM10, XMM11, XMM12, XMM13, XMM14, XMM15};
|
|
return info;
|
|
}
|
|
|
|
RegisterInfo gRegInfo = RegisterInfo::make_register_info();
|
|
|
|
std::string to_string(RegKind kind) {
|
|
switch (kind) {
|
|
case RegKind::GPR:
|
|
return "gpr";
|
|
case RegKind::XMM:
|
|
return "xmm";
|
|
default:
|
|
throw std::runtime_error("Unsupported RegKind");
|
|
}
|
|
}
|
|
|
|
std::string Register::print() const {
|
|
return gRegInfo.get_info(*this).name;
|
|
}
|
|
|
|
} // namespace emitter
|