One Level Up
Top Level
src/lj_target_arm64.h - luajit-2.0-src
Data types defined
Macros defined
Source code
- #ifndef _LJ_TARGET_ARM64_H
- #define _LJ_TARGET_ARM64_H
- #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)
- FPRDEF(RIDENUM)
- RID_MAX,
- RID_TMP = RID_LR,
- RID_ZERO = RID_SP,
-
- RID_RET = RID_X0,
- RID_FPRET = RID_D0,
-
- RID_BASE = RID_X19,
- RID_LPC = RID_X21,
- RID_GL = RID_X22,
- RID_LREG = RID_X23,
-
- 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
- #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
- #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
- #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
One Level Up
Top Level