2009-12-08 18:46:35 +00:00
|
|
|
/*
|
|
|
|
** State and stack handling.
|
2016-03-03 11:02:22 +00:00
|
|
|
** Copyright (C) 2005-2016 Mike Pall. See Copyright Notice in luajit.h
|
2009-12-08 18:46:35 +00:00
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef _LJ_STATE_H
|
|
|
|
#define _LJ_STATE_H
|
|
|
|
|
|
|
|
#include "lj_obj.h"
|
|
|
|
|
|
|
|
#define incr_top(L) \
|
2010-09-09 10:28:17 +00:00
|
|
|
(++L->top >= tvref(L->maxstack) && (lj_state_growstack1(L), 0))
|
2009-12-08 18:46:35 +00:00
|
|
|
|
2010-09-09 10:28:17 +00:00
|
|
|
#define savestack(L, p) ((char *)(p) - mref(L->stack, char))
|
|
|
|
#define restorestack(L, n) ((TValue *)(mref(L->stack, char) + (n)))
|
2009-12-08 18:46:35 +00:00
|
|
|
|
|
|
|
LJ_FUNC void lj_state_relimitstack(lua_State *L);
|
|
|
|
LJ_FUNC void lj_state_shrinkstack(lua_State *L, MSize used);
|
2009-12-27 16:42:41 +00:00
|
|
|
LJ_FUNCA void LJ_FASTCALL lj_state_growstack(lua_State *L, MSize need);
|
|
|
|
LJ_FUNC void LJ_FASTCALL lj_state_growstack1(lua_State *L);
|
2009-12-08 18:46:35 +00:00
|
|
|
|
|
|
|
static LJ_AINLINE void lj_state_checkstack(lua_State *L, MSize need)
|
|
|
|
{
|
2011-08-09 13:56:07 +00:00
|
|
|
if ((mref(L->maxstack, char) - (char *)L->top) <=
|
2011-08-10 13:24:43 +00:00
|
|
|
(ptrdiff_t)need*(ptrdiff_t)sizeof(TValue))
|
2009-12-08 18:46:35 +00:00
|
|
|
lj_state_growstack(L, need);
|
|
|
|
}
|
|
|
|
|
|
|
|
LJ_FUNC lua_State *lj_state_new(lua_State *L);
|
|
|
|
LJ_FUNC void LJ_FASTCALL lj_state_free(global_State *g, lua_State *L);
|
2010-01-24 14:50:59 +00:00
|
|
|
#if LJ_64
|
|
|
|
LJ_FUNC lua_State *lj_state_newstate(lua_Alloc f, void *ud);
|
|
|
|
#endif
|
2009-12-08 18:46:35 +00:00
|
|
|
|
|
|
|
#endif
|