2014-04-28 04:45:14 +02:00
|
|
|
/*
|
|
|
|
** Stack frames.
|
2018-05-12 08:58:15 +02:00
|
|
|
** Copyright (C) 2005-2017 Mike Pall. See Copyright Notice in luajit.h
|
2014-04-28 04:45:14 +02:00
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef _LJ_FRAME_H
|
|
|
|
#define _LJ_FRAME_H
|
|
|
|
|
|
|
|
#include "lj_obj.h"
|
|
|
|
#include "lj_bc.h"
|
|
|
|
|
|
|
|
/* -- Lua stack frame ----------------------------------------------------- */
|
|
|
|
|
|
|
|
/* Frame type markers in callee function slot (callee base-1). */
|
|
|
|
enum {
|
|
|
|
FRAME_LUA, FRAME_C, FRAME_CONT, FRAME_VARG,
|
|
|
|
FRAME_LUAP, FRAME_CP, FRAME_PCALL, FRAME_PCALLH
|
|
|
|
};
|
|
|
|
#define FRAME_TYPE 3
|
|
|
|
#define FRAME_P 4
|
|
|
|
#define FRAME_TYPEP (FRAME_TYPE|FRAME_P)
|
|
|
|
|
|
|
|
/* Macros to access and modify Lua frames. */
|
|
|
|
#define frame_gc(f) (gcref((f)->fr.func))
|
|
|
|
#define frame_func(f) (&frame_gc(f)->fn)
|
|
|
|
#define frame_ftsz(f) ((f)->fr.tp.ftsz)
|
|
|
|
|
|
|
|
#define frame_type(f) (frame_ftsz(f) & FRAME_TYPE)
|
|
|
|
#define frame_typep(f) (frame_ftsz(f) & FRAME_TYPEP)
|
|
|
|
#define frame_islua(f) (frame_type(f) == FRAME_LUA)
|
|
|
|
#define frame_isc(f) (frame_type(f) == FRAME_C)
|
|
|
|
#define frame_iscont(f) (frame_typep(f) == FRAME_CONT)
|
|
|
|
#define frame_isvarg(f) (frame_typep(f) == FRAME_VARG)
|
|
|
|
#define frame_ispcall(f) ((frame_ftsz(f) & 6) == FRAME_PCALL)
|
|
|
|
|
|
|
|
#define frame_pc(f) (mref((f)->fr.tp.pcr, const BCIns))
|
|
|
|
#define frame_contpc(f) (frame_pc((f)-1))
|
|
|
|
#if LJ_64
|
|
|
|
#define frame_contf(f) \
|
|
|
|
((ASMFunction)(void *)((intptr_t)lj_vm_asm_begin + \
|
|
|
|
(intptr_t)(int32_t)((f)-1)->u32.lo))
|
|
|
|
#else
|
|
|
|
#define frame_contf(f) ((ASMFunction)gcrefp(((f)-1)->gcr, void))
|
|
|
|
#endif
|
|
|
|
#define frame_delta(f) (frame_ftsz(f) >> 3)
|
|
|
|
#define frame_sized(f) (frame_ftsz(f) & ~FRAME_TYPEP)
|
|
|
|
|
|
|
|
#define frame_prevl(f) ((f) - (1+bc_a(frame_pc(f)[-1])))
|
|
|
|
#define frame_prevd(f) ((TValue *)((char *)(f) - frame_sized(f)))
|
|
|
|
#define frame_prev(f) (frame_islua(f)?frame_prevl(f):frame_prevd(f))
|
|
|
|
/* Note: this macro does not skip over FRAME_VARG. */
|
|
|
|
|
|
|
|
#define setframe_pc(f, pc) (setmref((f)->fr.tp.pcr, (pc)))
|
|
|
|
#define setframe_ftsz(f, sz) ((f)->fr.tp.ftsz = (sz))
|
|
|
|
#define setframe_gc(f, p) (setgcref((f)->fr.func, (p)))
|
|
|
|
|
|
|
|
/* -- C stack frame ------------------------------------------------------- */
|
|
|
|
|
|
|
|
/* Macros to access and modify the C stack frame chain. */
|
|
|
|
|
|
|
|
/* These definitions must match with the arch-specific *.dasc files. */
|
|
|
|
#if LJ_TARGET_X86
|
|
|
|
#define CFRAME_OFS_ERRF (15*4)
|
|
|
|
#define CFRAME_OFS_NRES (14*4)
|
|
|
|
#define CFRAME_OFS_PREV (13*4)
|
|
|
|
#define CFRAME_OFS_L (12*4)
|
|
|
|
#define CFRAME_OFS_PC (6*4)
|
|
|
|
#define CFRAME_OFS_MULTRES (5*4)
|
|
|
|
#define CFRAME_SIZE (12*4)
|
|
|
|
#define CFRAME_SHIFT_MULTRES 0
|
|
|
|
#elif LJ_TARGET_X64
|
|
|
|
#if LJ_ABI_WIN
|
|
|
|
#define CFRAME_OFS_PREV (13*8)
|
|
|
|
#define CFRAME_OFS_PC (25*4)
|
|
|
|
#define CFRAME_OFS_L (24*4)
|
|
|
|
#define CFRAME_OFS_ERRF (23*4)
|
|
|
|
#define CFRAME_OFS_NRES (22*4)
|
|
|
|
#define CFRAME_OFS_MULTRES (21*4)
|
|
|
|
#define CFRAME_SIZE (10*8)
|
|
|
|
#define CFRAME_SIZE_JIT (CFRAME_SIZE + 9*16 + 4*8)
|
|
|
|
#define CFRAME_SHIFT_MULTRES 0
|
|
|
|
#else
|
|
|
|
#define CFRAME_OFS_PREV (4*8)
|
|
|
|
#define CFRAME_OFS_PC (7*4)
|
|
|
|
#define CFRAME_OFS_L (6*4)
|
|
|
|
#define CFRAME_OFS_ERRF (5*4)
|
|
|
|
#define CFRAME_OFS_NRES (4*4)
|
|
|
|
#define CFRAME_OFS_MULTRES (1*4)
|
2018-05-12 08:58:15 +02:00
|
|
|
#if LJ_NO_UNWIND
|
|
|
|
#define CFRAME_SIZE (12*8)
|
|
|
|
#else
|
2014-04-28 04:45:14 +02:00
|
|
|
#define CFRAME_SIZE (10*8)
|
2018-05-12 08:58:15 +02:00
|
|
|
#endif
|
2014-04-28 04:45:14 +02:00
|
|
|
#define CFRAME_SIZE_JIT (CFRAME_SIZE + 16)
|
|
|
|
#define CFRAME_SHIFT_MULTRES 0
|
|
|
|
#endif
|
|
|
|
#elif LJ_TARGET_ARM
|
|
|
|
#define CFRAME_OFS_ERRF 24
|
|
|
|
#define CFRAME_OFS_NRES 20
|
|
|
|
#define CFRAME_OFS_PREV 16
|
|
|
|
#define CFRAME_OFS_L 12
|
|
|
|
#define CFRAME_OFS_PC 8
|
|
|
|
#define CFRAME_OFS_MULTRES 4
|
|
|
|
#if LJ_ARCH_HASFPU
|
|
|
|
#define CFRAME_SIZE 128
|
|
|
|
#else
|
|
|
|
#define CFRAME_SIZE 64
|
|
|
|
#endif
|
|
|
|
#define CFRAME_SHIFT_MULTRES 3
|
|
|
|
#elif LJ_TARGET_PPC
|
|
|
|
#if LJ_TARGET_XBOX360
|
|
|
|
#define CFRAME_OFS_ERRF 424
|
|
|
|
#define CFRAME_OFS_NRES 420
|
|
|
|
#define CFRAME_OFS_PREV 400
|
|
|
|
#define CFRAME_OFS_L 416
|
|
|
|
#define CFRAME_OFS_PC 412
|
|
|
|
#define CFRAME_OFS_MULTRES 408
|
|
|
|
#define CFRAME_SIZE 384
|
|
|
|
#define CFRAME_SHIFT_MULTRES 3
|
|
|
|
#elif LJ_ARCH_PPC64
|
|
|
|
#define CFRAME_OFS_ERRF 472
|
|
|
|
#define CFRAME_OFS_NRES 468
|
|
|
|
#define CFRAME_OFS_PREV 448
|
|
|
|
#define CFRAME_OFS_L 464
|
|
|
|
#define CFRAME_OFS_PC 460
|
|
|
|
#define CFRAME_OFS_MULTRES 456
|
|
|
|
#define CFRAME_SIZE 400
|
|
|
|
#define CFRAME_SHIFT_MULTRES 3
|
|
|
|
#else
|
|
|
|
#define CFRAME_OFS_ERRF 48
|
|
|
|
#define CFRAME_OFS_NRES 44
|
|
|
|
#define CFRAME_OFS_PREV 40
|
|
|
|
#define CFRAME_OFS_L 36
|
|
|
|
#define CFRAME_OFS_PC 32
|
|
|
|
#define CFRAME_OFS_MULTRES 28
|
|
|
|
#define CFRAME_SIZE 272
|
|
|
|
#define CFRAME_SHIFT_MULTRES 3
|
|
|
|
#endif
|
|
|
|
#elif LJ_TARGET_PPCSPE
|
|
|
|
#define CFRAME_OFS_ERRF 28
|
|
|
|
#define CFRAME_OFS_NRES 24
|
|
|
|
#define CFRAME_OFS_PREV 20
|
|
|
|
#define CFRAME_OFS_L 16
|
|
|
|
#define CFRAME_OFS_PC 12
|
|
|
|
#define CFRAME_OFS_MULTRES 8
|
|
|
|
#define CFRAME_SIZE 184
|
|
|
|
#define CFRAME_SHIFT_MULTRES 3
|
|
|
|
#elif LJ_TARGET_MIPS
|
|
|
|
#define CFRAME_OFS_ERRF 124
|
|
|
|
#define CFRAME_OFS_NRES 120
|
|
|
|
#define CFRAME_OFS_PREV 116
|
|
|
|
#define CFRAME_OFS_L 112
|
|
|
|
#define CFRAME_OFS_PC 20
|
|
|
|
#define CFRAME_OFS_MULTRES 16
|
|
|
|
#define CFRAME_SIZE 112
|
|
|
|
#define CFRAME_SHIFT_MULTRES 3
|
|
|
|
#else
|
|
|
|
#error "Missing CFRAME_* definitions for this architecture"
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#ifndef CFRAME_SIZE_JIT
|
|
|
|
#define CFRAME_SIZE_JIT CFRAME_SIZE
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#define CFRAME_RESUME 1
|
|
|
|
#define CFRAME_UNWIND_FF 2 /* Only used in unwinder. */
|
|
|
|
#define CFRAME_RAWMASK (~(intptr_t)(CFRAME_RESUME|CFRAME_UNWIND_FF))
|
|
|
|
|
|
|
|
#define cframe_errfunc(cf) (*(int32_t *)(((char *)(cf))+CFRAME_OFS_ERRF))
|
|
|
|
#define cframe_nres(cf) (*(int32_t *)(((char *)(cf))+CFRAME_OFS_NRES))
|
|
|
|
#define cframe_prev(cf) (*(void **)(((char *)(cf))+CFRAME_OFS_PREV))
|
|
|
|
#define cframe_multres(cf) (*(uint32_t *)(((char *)(cf))+CFRAME_OFS_MULTRES))
|
|
|
|
#define cframe_multres_n(cf) (cframe_multres((cf)) >> CFRAME_SHIFT_MULTRES)
|
|
|
|
#define cframe_L(cf) \
|
|
|
|
(&gcref(*(GCRef *)(((char *)(cf))+CFRAME_OFS_L))->th)
|
|
|
|
#define cframe_pc(cf) \
|
|
|
|
(mref(*(MRef *)(((char *)(cf))+CFRAME_OFS_PC), const BCIns))
|
|
|
|
#define setcframe_L(cf, L) \
|
|
|
|
(setmref(*(MRef *)(((char *)(cf))+CFRAME_OFS_L), (L)))
|
|
|
|
#define setcframe_pc(cf, pc) \
|
|
|
|
(setmref(*(MRef *)(((char *)(cf))+CFRAME_OFS_PC), (pc)))
|
|
|
|
#define cframe_canyield(cf) ((intptr_t)(cf) & CFRAME_RESUME)
|
|
|
|
#define cframe_unwind_ff(cf) ((intptr_t)(cf) & CFRAME_UNWIND_FF)
|
|
|
|
#define cframe_raw(cf) ((void *)((intptr_t)(cf) & CFRAME_RAWMASK))
|
|
|
|
#define cframe_Lpc(L) cframe_pc(cframe_raw(L->cframe))
|
|
|
|
|
|
|
|
#endif
|