mirror of
https://github.com/LuaJIT/LuaJIT.git
synced 2025-02-07 23:24:09 +00:00
98 lines
2.9 KiB
C
98 lines
2.9 KiB
C
![]() |
/*
|
||
|
** Definitions for ARM64 CPUs.
|
||
|
** Copyright (C) 2005-2015 Mike Pall. See Copyright Notice in luajit.h
|
||
|
*/
|
||
|
|
||
|
#ifndef _LJ_TARGET_ARM64_H
|
||
|
#define _LJ_TARGET_ARM64_H
|
||
|
|
||
|
/* -- Registers IDs ------------------------------------------------------- */
|
||
|
|
||
|
#define GPRDEF(_) \
|
||
|
_(X0) _(X1) _(X2) _(X3) _(X4) _(X5) _(X6) _(X7) \
|
||
|
_(X8) _(X9) _(X10) _(X11) _(X12) _(X13) _(X14) _(X15) \
|
||
|
_(X16) _(X17) _(X18) _(X19) _(X20) _(X21) _(X22) _(X23) \
|
||
|
_(X24) _(X25) _(X26) _(X27) _(X28) _(FP) _(LR) _(SP)
|
||
|
#define FPRDEF(_) \
|
||
|
_(D0) _(D1) _(D2) _(D3) _(D4) _(D5) _(D6) _(D7) \
|
||
|
_(D8) _(D9) _(D10) _(D11) _(D12) _(D13) _(D14) _(D15) \
|
||
|
_(D16) _(D17) _(D18) _(D19) _(D20) _(D21) _(D22) _(D23) \
|
||
|
_(D24) _(D25) _(D26) _(D27) _(D28) _(D29) _(D30) _(D31)
|
||
|
#define VRIDDEF(_)
|
||
|
|
||
|
#define RIDENUM(name) RID_##name,
|
||
|
|
||
|
enum {
|
||
|
GPRDEF(RIDENUM) /* General-purpose registers (GPRs). */
|
||
|
FPRDEF(RIDENUM) /* Floating-point registers (FPRs). */
|
||
|
RID_MAX,
|
||
|
RID_TMP = RID_LR,
|
||
|
RID_ZERO = RID_SP,
|
||
|
|
||
|
/* Calling conventions. */
|
||
|
RID_RET = RID_X0,
|
||
|
RID_FPRET = RID_D0,
|
||
|
|
||
|
/* These definitions must match with the *.dasc file(s): */
|
||
|
RID_BASE = RID_X19, /* Interpreter BASE. */
|
||
|
RID_LPC = RID_X21, /* Interpreter PC. */
|
||
|
RID_GL = RID_X22, /* Interpreter GL. */
|
||
|
RID_LREG = RID_X23, /* Interpreter L. */
|
||
|
|
||
|
/* Register ranges [min, max) and number of registers. */
|
||
|
RID_MIN_GPR = RID_X0,
|
||
|
RID_MAX_GPR = RID_SP+1,
|
||
|
RID_MIN_FPR = RID_MAX_GPR,
|
||
|
RID_MAX_FPR = RID_D31+1,
|
||
|
RID_NUM_GPR = RID_MAX_GPR - RID_MIN_GPR,
|
||
|
RID_NUM_FPR = RID_MAX_FPR - RID_MIN_FPR
|
||
|
};
|
||
|
|
||
|
#define RID_NUM_KREF RID_NUM_GPR
|
||
|
#define RID_MIN_KREF RID_X0
|
||
|
|
||
|
/* -- Register sets ------------------------------------------------------- */
|
||
|
|
||
|
/* Make use of all registers, except for x18, fp, lr and sp. */
|
||
|
#define RSET_FIXED \
|
||
|
(RID2RSET(RID_X18)|RID2RSET(RID_FP)|RID2RSET(RID_LR)|RID2RSET(RID_SP))
|
||
|
#define RSET_GPR (RSET_RANGE(RID_MIN_GPR, RID_MAX_GPR) - RSET_FIXED)
|
||
|
#define RSET_FPR RSET_RANGE(RID_MIN_FPR, RID_MAX_FPR)
|
||
|
#define RSET_ALL (RSET_GPR|RSET_FPR)
|
||
|
#define RSET_INIT RSET_ALL
|
||
|
|
||
|
/* lr is an implicit scratch register. */
|
||
|
#define RSET_SCRATCH_GPR (RSET_RANGE(RID_X0, RID_X17+1))
|
||
|
#define RSET_SCRATCH_FPR \
|
||
|
(RSET_RANGE(RID_D0, RID_D7+1)|RSET_RANGE(RID_D16, RID_D31+1))
|
||
|
#define RSET_SCRATCH (RSET_SCRATCH_GPR|RSET_SCRATCH_FPR)
|
||
|
#define REGARG_FIRSTGPR RID_X0
|
||
|
#define REGARG_LASTGPR RID_X7
|
||
|
#define REGARG_NUMGPR 8
|
||
|
#define REGARG_FIRSTFPR RID_D0
|
||
|
#define REGARG_LASTFPR RID_D7
|
||
|
#define REGARG_NUMFPR 8
|
||
|
|
||
|
/* -- Instructions -------------------------------------------------------- */
|
||
|
|
||
|
/* Instruction fields. */
|
||
|
#define A64F_D(r) (r)
|
||
|
#define A64F_N(r) ((r) << 5)
|
||
|
#define A64F_A(r) ((r) << 10)
|
||
|
#define A64F_M(r) ((r) << 16)
|
||
|
#define A64F_U16(x) ((x) << 5)
|
||
|
#define A64F_S26(x) (x)
|
||
|
#define A64F_S19(x) ((x) << 5)
|
||
|
|
||
|
typedef enum A64Ins {
|
||
|
A64I_MOVZw = 0x52800000,
|
||
|
A64I_MOVZx = 0xd2800000,
|
||
|
A64I_LDRLw = 0x18000000,
|
||
|
A64I_LDRLx = 0x58000000,
|
||
|
A64I_NOP = 0xd503201f,
|
||
|
A64I_B = 0x14000000,
|
||
|
A64I_BR = 0xd61f0000,
|
||
|
} A64Ins;
|
||
|
|
||
|
#endif
|