2016-08-24 20:07:08 +01:00
|
|
|
/* This file is part of the dynarmic project.
|
|
|
|
* Copyright (c) 2016 MerryMage
|
2020-04-23 15:25:11 +01:00
|
|
|
* SPDX-License-Identifier: 0BSD
|
2016-08-24 20:07:08 +01:00
|
|
|
*/
|
|
|
|
#pragma once
|
|
|
|
|
|
|
|
#include <array>
|
|
|
|
|
2018-08-14 19:13:47 +01:00
|
|
|
#include "backend/x64/hostloc.h"
|
2021-04-21 22:21:36 +01:00
|
|
|
#include "common/common_types.h"
|
2016-08-24 20:07:08 +01:00
|
|
|
|
2020-04-08 11:46:36 +01:00
|
|
|
namespace Dynarmic::Backend::X64 {
|
2016-08-24 20:07:08 +01:00
|
|
|
|
2018-09-28 21:12:17 +01:00
|
|
|
class BlockOfCode;
|
|
|
|
|
2016-08-24 20:07:08 +01:00
|
|
|
#ifdef _WIN32
|
|
|
|
|
|
|
|
constexpr HostLoc ABI_RETURN = HostLoc::RAX;
|
|
|
|
|
2021-04-21 18:25:04 +01:00
|
|
|
constexpr size_t ABI_PARAM_COUNT = 4;
|
|
|
|
|
2016-08-24 20:07:08 +01:00
|
|
|
constexpr HostLoc ABI_PARAM1 = HostLoc::RCX;
|
|
|
|
constexpr HostLoc ABI_PARAM2 = HostLoc::RDX;
|
|
|
|
constexpr HostLoc ABI_PARAM3 = HostLoc::R8;
|
|
|
|
constexpr HostLoc ABI_PARAM4 = HostLoc::R9;
|
|
|
|
|
2018-02-12 18:17:39 +00:00
|
|
|
constexpr std::array<HostLoc, 13> ABI_ALL_CALLER_SAVE = {
|
|
|
|
HostLoc::RAX,
|
2016-08-24 20:07:08 +01:00
|
|
|
HostLoc::RCX,
|
|
|
|
HostLoc::RDX,
|
|
|
|
HostLoc::R8,
|
|
|
|
HostLoc::R9,
|
|
|
|
HostLoc::R10,
|
|
|
|
HostLoc::R11,
|
|
|
|
HostLoc::XMM0,
|
|
|
|
HostLoc::XMM1,
|
|
|
|
HostLoc::XMM2,
|
|
|
|
HostLoc::XMM3,
|
|
|
|
HostLoc::XMM4,
|
|
|
|
HostLoc::XMM5,
|
|
|
|
};
|
|
|
|
|
|
|
|
constexpr std::array<HostLoc, 18> ABI_ALL_CALLEE_SAVE = {
|
|
|
|
HostLoc::RBX,
|
|
|
|
HostLoc::RSI,
|
|
|
|
HostLoc::RDI,
|
|
|
|
HostLoc::RBP,
|
|
|
|
HostLoc::R12,
|
|
|
|
HostLoc::R13,
|
|
|
|
HostLoc::R14,
|
|
|
|
HostLoc::R15,
|
|
|
|
HostLoc::XMM6,
|
|
|
|
HostLoc::XMM7,
|
|
|
|
HostLoc::XMM8,
|
|
|
|
HostLoc::XMM9,
|
|
|
|
HostLoc::XMM10,
|
|
|
|
HostLoc::XMM11,
|
|
|
|
HostLoc::XMM12,
|
|
|
|
HostLoc::XMM13,
|
|
|
|
HostLoc::XMM14,
|
|
|
|
HostLoc::XMM15,
|
|
|
|
};
|
|
|
|
|
|
|
|
constexpr size_t ABI_SHADOW_SPACE = 32; // bytes
|
|
|
|
|
|
|
|
#else
|
|
|
|
|
|
|
|
constexpr HostLoc ABI_RETURN = HostLoc::RAX;
|
2021-04-21 18:25:04 +01:00
|
|
|
constexpr HostLoc ABI_RETURN2 = HostLoc::RDX;
|
|
|
|
|
|
|
|
constexpr size_t ABI_PARAM_COUNT = 6;
|
2016-08-24 20:07:08 +01:00
|
|
|
|
|
|
|
constexpr HostLoc ABI_PARAM1 = HostLoc::RDI;
|
|
|
|
constexpr HostLoc ABI_PARAM2 = HostLoc::RSI;
|
|
|
|
constexpr HostLoc ABI_PARAM3 = HostLoc::RDX;
|
|
|
|
constexpr HostLoc ABI_PARAM4 = HostLoc::RCX;
|
2021-04-21 18:25:04 +01:00
|
|
|
constexpr HostLoc ABI_PARAM5 = HostLoc::R8;
|
|
|
|
constexpr HostLoc ABI_PARAM6 = HostLoc::R9;
|
2016-08-24 20:07:08 +01:00
|
|
|
|
2018-02-12 18:17:39 +00:00
|
|
|
constexpr std::array<HostLoc, 25> ABI_ALL_CALLER_SAVE = {
|
|
|
|
HostLoc::RAX,
|
2016-08-24 20:07:08 +01:00
|
|
|
HostLoc::RCX,
|
|
|
|
HostLoc::RDX,
|
|
|
|
HostLoc::RDI,
|
|
|
|
HostLoc::RSI,
|
|
|
|
HostLoc::R8,
|
|
|
|
HostLoc::R9,
|
|
|
|
HostLoc::R10,
|
|
|
|
HostLoc::R11,
|
|
|
|
HostLoc::XMM0,
|
|
|
|
HostLoc::XMM1,
|
|
|
|
HostLoc::XMM2,
|
|
|
|
HostLoc::XMM3,
|
|
|
|
HostLoc::XMM4,
|
|
|
|
HostLoc::XMM5,
|
|
|
|
HostLoc::XMM6,
|
|
|
|
HostLoc::XMM7,
|
|
|
|
HostLoc::XMM8,
|
|
|
|
HostLoc::XMM9,
|
|
|
|
HostLoc::XMM10,
|
|
|
|
HostLoc::XMM11,
|
|
|
|
HostLoc::XMM12,
|
|
|
|
HostLoc::XMM13,
|
|
|
|
HostLoc::XMM14,
|
|
|
|
HostLoc::XMM15,
|
|
|
|
};
|
|
|
|
|
|
|
|
constexpr std::array<HostLoc, 6> ABI_ALL_CALLEE_SAVE = {
|
|
|
|
HostLoc::RBX,
|
|
|
|
HostLoc::RBP,
|
|
|
|
HostLoc::R12,
|
|
|
|
HostLoc::R13,
|
|
|
|
HostLoc::R14,
|
|
|
|
HostLoc::R15,
|
|
|
|
};
|
|
|
|
|
|
|
|
constexpr size_t ABI_SHADOW_SPACE = 0; // bytes
|
|
|
|
|
|
|
|
#endif
|
|
|
|
|
2018-02-12 18:17:39 +00:00
|
|
|
static_assert(ABI_ALL_CALLER_SAVE.size() + ABI_ALL_CALLEE_SAVE.size() == 31, "Invalid total number of registers");
|
2016-08-24 20:07:08 +01:00
|
|
|
|
2018-09-28 21:12:17 +01:00
|
|
|
void ABI_PushCalleeSaveRegistersAndAdjustStack(BlockOfCode& code, size_t frame_size = 0);
|
|
|
|
void ABI_PopCalleeSaveRegistersAndAdjustStack(BlockOfCode& code, size_t frame_size = 0);
|
|
|
|
void ABI_PushCallerSaveRegistersAndAdjustStack(BlockOfCode& code, size_t frame_size = 0);
|
|
|
|
void ABI_PopCallerSaveRegistersAndAdjustStack(BlockOfCode& code, size_t frame_size = 0);
|
2016-08-24 20:07:08 +01:00
|
|
|
|
2018-09-28 21:12:17 +01:00
|
|
|
void ABI_PushCallerSaveRegistersAndAdjustStackExcept(BlockOfCode& code, HostLoc exception);
|
|
|
|
void ABI_PopCallerSaveRegistersAndAdjustStackExcept(BlockOfCode& code, HostLoc exception);
|
2018-02-12 18:17:39 +00:00
|
|
|
|
2020-04-08 11:46:36 +01:00
|
|
|
} // namespace Dynarmic::Backend::X64
|