#ifndef V8_WASM_BASELINE_LIFTOFF_ASSEMBLER_DEFS_H_
#define V8_WASM_BASELINE_LIFTOFF_ASSEMBLER_DEFS_H_
#include "src/codegen/assembler-arch.h"
#include "src/codegen/reglist.h"
namespace v8 {
namespace internal {
namespace wasm {
#if V8_TARGET_ARCH_IA32
constexpr RegList kLiftoffAssemblerGpCacheRegs = {eax, ecx, edx, esi, edi};
constexpr DoubleRegList kLiftoffAssemblerFpCacheRegs = {xmm1, xmm2, xmm3,
xmm4, xmm5, xmm6};
constexpr Register kLiftoffFrameSetupFunctionReg = edi;
#elif V8_TARGET_ARCH_X64
constexpr RegList kLiftoffAssemblerGpCacheRegs = {rax, rcx, rdx, rbx, rsi,
rdi, r8, r9, r12, r15};
constexpr DoubleRegList kLiftoffAssemblerFpCacheRegs = {xmm0, xmm1, xmm2, xmm3,
xmm4, xmm5, xmm6, xmm7};
constexpr Register kLiftoffFrameSetupFunctionReg = …;
#elif V8_TARGET_ARCH_MIPS
constexpr RegList kLiftoffAssemblerGpCacheRegs = {a0, a1, a2, a3, t0, t1, t2,
t3, t4, t5, t6, s7, v0, v1};
constexpr DoubleRegList kLiftoffAssemblerFpCacheRegs = {
f0, f2, f4, f6, f8, f10, f12, f14, f16, f18, f20, f22, f24};
#elif V8_TARGET_ARCH_MIPS64
constexpr RegList kLiftoffAssemblerGpCacheRegs = {a0, a1, a2, a3, a4, a5, a6,
a7, t0, t1, t2, s7, v0, v1};
constexpr DoubleRegList kLiftoffAssemblerFpCacheRegs = {
f0, f2, f4, f6, f8, f10, f12, f14, f16, f18, f20, f22, f24, f26};
constexpr Register kLiftoffFrameSetupFunctionReg = t0;
#elif V8_TARGET_ARCH_LOONG64
constexpr RegList kLiftoffAssemblerGpCacheRegs = {a0, a1, a2, a3, a4, a5, a6,
a7, t0, t1, t2, t3, t4, t5,
s0, s1, s2, s5, s7};
constexpr DoubleRegList kLiftoffAssemblerFpCacheRegs = {
f0, f1, f2, f3, f4, f5, f6, f7, f8, f9, f10, f11, f12, f13, f14,
f15, f16, f17, f18, f19, f20, f21, f22, f23, f24, f25, f26, f27, f28};
constexpr Register kLiftoffFrameSetupFunctionReg = t0;
#elif V8_TARGET_ARCH_ARM
constexpr RegList kLiftoffAssemblerGpCacheRegs = {r0, r1, r2, r3, r4,
r5, r6, r7, r8, r9};
constexpr DoubleRegList kLiftoffAssemblerFpCacheRegs = {
d0, d1, d2, d3, d4, d5, d6, d7, d8, d9, d10, d11, d12};
constexpr Register kLiftoffFrameSetupFunctionReg = r4;
#elif V8_TARGET_ARCH_ARM64
constexpr RegList kLiftoffAssemblerGpCacheRegs = {
x0, x1, x2, x3, x4, x5, x6, x7, x8, x9, x10, x11,
x12, x13, x14, x15, x19, x20, x21, x22, x23, x24, x25, x27};
constexpr DoubleRegList kLiftoffAssemblerFpCacheRegs = {
d0, d1, d2, d3, d4, d5, d6, d7, d8, d9, d10, d11, d12, d13,
d14, d16, d17, d18, d19, d20, d21, d22, d23, d24, d25, d26, d27};
constexpr Register kLiftoffFrameSetupFunctionReg = x8;
#elif V8_TARGET_ARCH_S390X
constexpr RegList kLiftoffAssemblerGpCacheRegs = {r2, r3, r4, r5,
r6, r7, r8, cp};
constexpr DoubleRegList kLiftoffAssemblerFpCacheRegs = {
d0, d1, d2, d3, d4, d5, d6, d7, d8, d9, d10, d11, d12};
constexpr Register kLiftoffFrameSetupFunctionReg = r7;
#elif V8_TARGET_ARCH_PPC64
constexpr RegList kLiftoffAssemblerGpCacheRegs = {r3, r4, r5, r6, r7, r8,
r9, r10, r11, r15, cp};
constexpr DoubleRegList kLiftoffAssemblerFpCacheRegs = {
d0, d1, d2, d3, d4, d5, d6, d7, d8, d9, d10, d11, d12};
constexpr Register kLiftoffFrameSetupFunctionReg = r15;
#elif V8_TARGET_ARCH_RISCV32 || V8_TARGET_ARCH_RISCV64
constexpr RegList kLiftoffAssemblerGpCacheRegs = {a0, a1, a2, a3, a4, a5,
a6, a7, t0, t1, t2, s7};
constexpr DoubleRegList kLiftoffAssemblerFpCacheRegs = {
ft1, ft2, ft3, ft4, ft5, ft6, ft7, fa0, fa1, fa2,
fa3, fa4, fa5, fa6, fa7, ft8, ft9, ft10, ft11};
constexpr Register kLiftoffFrameSetupFunctionReg = t0;
#else
constexpr RegList kLiftoffAssemblerGpCacheRegs = RegList::FromBits(0xff);
constexpr DoubleRegList kLiftoffAssemblerFpCacheRegs =
DoubleRegList::FromBits(0xff);
#endif
static_assert …;
static_assert …;
#ifdef V8_COMPRESS_POINTERS
static_assert …;
#endif
}
}
}
#endif