2014-04-28 04:45:14 +02:00
|
|
|
/*
|
|
|
|
** Trace management.
|
2019-09-15 00:33:59 +02:00
|
|
|
** Copyright (C) 2005-2017 Mike Pall. See Copyright Notice in luajit.h
|
2014-04-28 04:45:14 +02:00
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef _LJ_TRACE_H
|
|
|
|
#define _LJ_TRACE_H
|
|
|
|
|
|
|
|
#include "lj_obj.h"
|
|
|
|
|
|
|
|
#if LJ_HASJIT
|
|
|
|
#include "lj_jit.h"
|
|
|
|
#include "lj_dispatch.h"
|
|
|
|
|
|
|
|
/* Trace errors. */
|
|
|
|
typedef enum {
|
|
|
|
#define TREDEF(name, msg) LJ_TRERR_##name,
|
|
|
|
#include "lj_traceerr.h"
|
|
|
|
LJ_TRERR__MAX
|
|
|
|
} TraceError;
|
|
|
|
|
|
|
|
LJ_FUNC_NORET void lj_trace_err(jit_State *J, TraceError e);
|
|
|
|
LJ_FUNC_NORET void lj_trace_err_info(jit_State *J, TraceError e);
|
|
|
|
|
|
|
|
/* Trace management. */
|
2019-09-15 00:33:59 +02:00
|
|
|
LJ_FUNC GCtrace * LJ_FASTCALL lj_trace_alloc(lua_State *L, GCtrace *T);
|
2014-04-28 04:45:14 +02:00
|
|
|
LJ_FUNC void LJ_FASTCALL lj_trace_free(global_State *g, GCtrace *T);
|
|
|
|
LJ_FUNC void lj_trace_reenableproto(GCproto *pt);
|
|
|
|
LJ_FUNC void lj_trace_flushproto(global_State *g, GCproto *pt);
|
|
|
|
LJ_FUNC void lj_trace_flush(jit_State *J, TraceNo traceno);
|
|
|
|
LJ_FUNC int lj_trace_flushall(lua_State *L);
|
|
|
|
LJ_FUNC void lj_trace_initstate(global_State *g);
|
|
|
|
LJ_FUNC void lj_trace_freestate(global_State *g);
|
|
|
|
|
|
|
|
/* Event handling. */
|
|
|
|
LJ_FUNC void lj_trace_ins(jit_State *J, const BCIns *pc);
|
|
|
|
LJ_FUNCA void LJ_FASTCALL lj_trace_hot(jit_State *J, const BCIns *pc);
|
2019-09-15 00:33:59 +02:00
|
|
|
LJ_FUNCA void LJ_FASTCALL lj_trace_stitch(jit_State *J, const BCIns *pc);
|
2014-04-28 04:45:14 +02:00
|
|
|
LJ_FUNCA int LJ_FASTCALL lj_trace_exit(jit_State *J, void *exptr);
|
|
|
|
|
|
|
|
/* Signal asynchronous abort of trace or end of trace. */
|
|
|
|
#define lj_trace_abort(g) (G2J(g)->state &= ~LJ_TRACE_ACTIVE)
|
|
|
|
#define lj_trace_end(J) (J->state = LJ_TRACE_END)
|
|
|
|
|
|
|
|
#else
|
|
|
|
|
|
|
|
#define lj_trace_flushall(L) (UNUSED(L), 0)
|
|
|
|
#define lj_trace_initstate(g) UNUSED(g)
|
|
|
|
#define lj_trace_freestate(g) UNUSED(g)
|
|
|
|
#define lj_trace_abort(g) UNUSED(g)
|
|
|
|
#define lj_trace_end(J) UNUSED(J)
|
|
|
|
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#endif
|