mirror of
https://github.com/LuaJIT/LuaJIT.git
synced 2025-02-07 23:24:09 +00:00
Untangle some target dependencies.
This commit is contained in:
parent
a6b7952f7e
commit
33ef1fa524
@ -391,7 +391,10 @@ depend:
|
|||||||
@test -f buildvm_x86.h || touch buildvm_x86.h
|
@test -f buildvm_x86.h || touch buildvm_x86.h
|
||||||
@test -f buildvm_x64.h || touch buildvm_x64.h
|
@test -f buildvm_x64.h || touch buildvm_x64.h
|
||||||
@test -f buildvm_x64win.h || touch buildvm_x64win.h
|
@test -f buildvm_x64win.h || touch buildvm_x64win.h
|
||||||
@$(HOST_CC) $(HOST_ACFLAGS) -MM *.c | sed "s|$(DASM_DIR)|\$$(DASM_DIR)|g" >Makefile.dep
|
@$(HOST_CC) $(HOST_ACFLAGS) -MM *.c | \
|
||||||
|
sed -e "s| [^ ]*/dasm_\S*\.h||g" \
|
||||||
|
-e "s| buildvm_\S*\.h||g" \
|
||||||
|
-e "s| lj_target_\S*\.h| lj_target_*.h|g" >Makefile.dep
|
||||||
@test -s lj_bcdef.h || $(HOST_RM) lj_bcdef.h
|
@test -s lj_bcdef.h || $(HOST_RM) lj_bcdef.h
|
||||||
@test -s lj_ffdef.h || $(HOST_RM) lj_ffdef.h
|
@test -s lj_ffdef.h || $(HOST_RM) lj_ffdef.h
|
||||||
@test -s lj_libdef.h || $(HOST_RM) lj_libdef.h
|
@test -s lj_libdef.h || $(HOST_RM) lj_libdef.h
|
||||||
@ -419,7 +422,7 @@ buildvm_x64win.h: buildvm_x86.dasc
|
|||||||
$(E) "DYNASM $@"
|
$(E) "DYNASM $@"
|
||||||
$(Q)$(DASM) $(DASM_FLAGS) $(DASM_FLAGS_X64WIN) -o $@ buildvm_x86.dasc
|
$(Q)$(DASM) $(DASM_FLAGS) $(DASM_FLAGS_X64WIN) -o $@ buildvm_x86.dasc
|
||||||
|
|
||||||
buildvm.o: buildvm_x86.h buildvm_x64.h buildvm_x64win.h
|
buildvm.o: buildvm_x86.h buildvm_x64.h buildvm_x64win.h $(DASM_DIR)/dasm_*.h
|
||||||
|
|
||||||
$(BUILDVM_T): $(BUILDVM_O)
|
$(BUILDVM_T): $(BUILDVM_O)
|
||||||
$(E) "HOSTLINK $@"
|
$(E) "HOSTLINK $@"
|
||||||
|
@ -1,7 +1,6 @@
|
|||||||
buildvm.o: buildvm.c lua.h luaconf.h luajit.h lj_obj.h lj_def.h lj_arch.h \
|
buildvm.o: buildvm.c lua.h luaconf.h luajit.h lj_obj.h lj_def.h lj_arch.h \
|
||||||
lj_gc.h lj_bc.h lj_ir.h lj_frame.h lj_dispatch.h lj_jit.h lj_target.h \
|
lj_gc.h lj_bc.h lj_ir.h lj_frame.h lj_dispatch.h lj_jit.h buildvm.h \
|
||||||
lj_target_x86.h buildvm.h $(DASM_DIR)/dasm_proto.h $(DASM_DIR)/dasm_x86.h \
|
lj_traceerr.h
|
||||||
buildvm_x86.h lj_traceerr.h
|
|
||||||
buildvm_asm.o: buildvm_asm.c buildvm.h lj_def.h lua.h luaconf.h lj_arch.h \
|
buildvm_asm.o: buildvm_asm.c buildvm.h lj_def.h lua.h luaconf.h lj_arch.h \
|
||||||
lj_bc.h
|
lj_bc.h
|
||||||
buildvm_fold.o: buildvm_fold.c lj_obj.h lua.h luaconf.h lj_def.h \
|
buildvm_fold.o: buildvm_fold.c lj_obj.h lua.h luaconf.h lj_def.h \
|
||||||
@ -23,12 +22,12 @@ lib_debug.o: lib_debug.c lua.h luaconf.h lauxlib.h lualib.h lj_obj.h \
|
|||||||
lib_init.o: lib_init.c lua.h luaconf.h lauxlib.h lualib.h
|
lib_init.o: lib_init.c lua.h luaconf.h lauxlib.h lualib.h
|
||||||
lib_io.o: lib_io.c lua.h luaconf.h lauxlib.h lualib.h lj_obj.h lj_def.h \
|
lib_io.o: lib_io.c lua.h luaconf.h lauxlib.h lualib.h lj_obj.h lj_def.h \
|
||||||
lj_arch.h lj_gc.h lj_err.h lj_errmsg.h lj_str.h lj_ff.h lj_ffdef.h \
|
lj_arch.h lj_gc.h lj_err.h lj_errmsg.h lj_str.h lj_ff.h lj_ffdef.h \
|
||||||
lj_trace.h lj_jit.h lj_ir.h lj_dispatch.h lj_bc.h lj_traceerr.h \
|
lj_trace.h lj_jit.h lj_ir.h lj_dispatch.h lj_bc.h lj_traceerr.h lj_lib.h \
|
||||||
lj_lib.h lj_libdef.h
|
lj_libdef.h
|
||||||
lib_jit.o: lib_jit.c lua.h luaconf.h lauxlib.h lualib.h lj_arch.h \
|
lib_jit.o: lib_jit.c lua.h luaconf.h lauxlib.h lualib.h lj_arch.h \
|
||||||
lj_obj.h lj_def.h lj_err.h lj_errmsg.h lj_str.h lj_tab.h lj_bc.h \
|
lj_obj.h lj_def.h lj_err.h lj_errmsg.h lj_str.h lj_tab.h lj_bc.h lj_ir.h \
|
||||||
lj_ir.h lj_jit.h lj_iropt.h lj_dispatch.h lj_vm.h lj_vmevent.h lj_lib.h \
|
lj_jit.h lj_iropt.h lj_dispatch.h lj_vm.h lj_vmevent.h lj_lib.h luajit.h \
|
||||||
luajit.h lj_libdef.h
|
lj_libdef.h
|
||||||
lib_math.o: lib_math.c lua.h luaconf.h lauxlib.h lualib.h lj_obj.h \
|
lib_math.o: lib_math.c lua.h luaconf.h lauxlib.h lualib.h lj_obj.h \
|
||||||
lj_def.h lj_arch.h lj_lib.h lj_libdef.h
|
lj_def.h lj_arch.h lj_lib.h lj_libdef.h
|
||||||
lib_os.o: lib_os.c lua.h luaconf.h lauxlib.h lualib.h lj_obj.h lj_def.h \
|
lib_os.o: lib_os.c lua.h luaconf.h lauxlib.h lualib.h lj_obj.h lj_def.h \
|
||||||
@ -49,14 +48,13 @@ lj_api.o: lj_api.c lj_obj.h lua.h luaconf.h lj_def.h lj_arch.h lj_gc.h \
|
|||||||
lj_asm.o: lj_asm.c lj_obj.h lua.h luaconf.h lj_def.h lj_arch.h lj_gc.h \
|
lj_asm.o: lj_asm.c lj_obj.h lua.h luaconf.h lj_def.h lj_arch.h lj_gc.h \
|
||||||
lj_str.h lj_tab.h lj_frame.h lj_bc.h lj_ir.h lj_jit.h lj_iropt.h \
|
lj_str.h lj_tab.h lj_frame.h lj_bc.h lj_ir.h lj_jit.h lj_iropt.h \
|
||||||
lj_mcode.h lj_trace.h lj_dispatch.h lj_traceerr.h lj_snap.h lj_asm.h \
|
lj_mcode.h lj_trace.h lj_dispatch.h lj_traceerr.h lj_snap.h lj_asm.h \
|
||||||
lj_vm.h lj_target.h lj_target_x86.h
|
lj_vm.h lj_target.h lj_target_*.h
|
||||||
lj_bc.o: lj_bc.c lj_obj.h lua.h luaconf.h lj_def.h lj_arch.h lj_bc.h \
|
lj_bc.o: lj_bc.c lj_obj.h lua.h luaconf.h lj_def.h lj_arch.h lj_bc.h \
|
||||||
lj_bcdef.h
|
lj_bcdef.h
|
||||||
lj_ctype.o: lj_ctype.c lj_ctype.h lj_def.h lua.h luaconf.h
|
lj_ctype.o: lj_ctype.c lj_ctype.h lj_def.h lua.h luaconf.h
|
||||||
lj_dispatch.o: lj_dispatch.c lj_obj.h lua.h luaconf.h lj_def.h lj_arch.h \
|
lj_dispatch.o: lj_dispatch.c lj_obj.h lua.h luaconf.h lj_def.h lj_arch.h \
|
||||||
lj_err.h lj_errmsg.h lj_state.h lj_frame.h lj_bc.h lj_ff.h lj_ffdef.h \
|
lj_err.h lj_errmsg.h lj_state.h lj_frame.h lj_bc.h lj_ff.h lj_ffdef.h \
|
||||||
lj_jit.h lj_ir.h lj_trace.h lj_dispatch.h lj_traceerr.h lj_vm.h \
|
lj_jit.h lj_ir.h lj_trace.h lj_dispatch.h lj_traceerr.h lj_vm.h luajit.h
|
||||||
luajit.h
|
|
||||||
lj_err.o: lj_err.c lj_obj.h lua.h luaconf.h lj_def.h lj_arch.h lj_err.h \
|
lj_err.o: lj_err.c lj_obj.h lua.h luaconf.h lj_def.h lj_arch.h lj_err.h \
|
||||||
lj_errmsg.h lj_str.h lj_tab.h lj_func.h lj_state.h lj_frame.h lj_bc.h \
|
lj_errmsg.h lj_str.h lj_tab.h lj_func.h lj_state.h lj_frame.h lj_bc.h \
|
||||||
lj_trace.h lj_jit.h lj_ir.h lj_dispatch.h lj_traceerr.h lj_vm.h
|
lj_trace.h lj_jit.h lj_ir.h lj_dispatch.h lj_traceerr.h lj_vm.h
|
||||||
@ -68,8 +66,8 @@ lj_gc.o: lj_gc.c lj_obj.h lua.h luaconf.h lj_def.h lj_arch.h lj_gc.h \
|
|||||||
lj_state.h lj_frame.h lj_bc.h lj_trace.h lj_jit.h lj_ir.h lj_dispatch.h \
|
lj_state.h lj_frame.h lj_bc.h lj_trace.h lj_jit.h lj_ir.h lj_dispatch.h \
|
||||||
lj_traceerr.h lj_vm.h
|
lj_traceerr.h lj_vm.h
|
||||||
lj_gdbjit.o: lj_gdbjit.c lj_obj.h lua.h luaconf.h lj_def.h lj_arch.h \
|
lj_gdbjit.o: lj_gdbjit.c lj_obj.h lua.h luaconf.h lj_def.h lj_arch.h \
|
||||||
lj_gc.h lj_err.h lj_errmsg.h lj_frame.h lj_bc.h lj_jit.h \
|
lj_gc.h lj_err.h lj_errmsg.h lj_frame.h lj_bc.h lj_jit.h lj_ir.h \
|
||||||
lj_ir.h lj_dispatch.h
|
lj_dispatch.h
|
||||||
lj_ir.o: lj_ir.c lj_obj.h lua.h luaconf.h lj_def.h lj_arch.h lj_gc.h \
|
lj_ir.o: lj_ir.c lj_obj.h lua.h luaconf.h lj_def.h lj_arch.h lj_gc.h \
|
||||||
lj_str.h lj_tab.h lj_ir.h lj_jit.h lj_iropt.h lj_trace.h lj_dispatch.h \
|
lj_str.h lj_tab.h lj_ir.h lj_jit.h lj_iropt.h lj_trace.h lj_dispatch.h \
|
||||||
lj_bc.h lj_traceerr.h lj_lib.h
|
lj_bc.h lj_traceerr.h lj_lib.h
|
||||||
@ -107,7 +105,7 @@ lj_record.o: lj_record.c lj_obj.h lua.h luaconf.h lj_def.h lj_arch.h \
|
|||||||
lj_recdef.h
|
lj_recdef.h
|
||||||
lj_snap.o: lj_snap.c lj_obj.h lua.h luaconf.h lj_def.h lj_arch.h lj_gc.h \
|
lj_snap.o: lj_snap.c lj_obj.h lua.h luaconf.h lj_def.h lj_arch.h lj_gc.h \
|
||||||
lj_state.h lj_frame.h lj_bc.h lj_ir.h lj_jit.h lj_iropt.h lj_trace.h \
|
lj_state.h lj_frame.h lj_bc.h lj_ir.h lj_jit.h lj_iropt.h lj_trace.h \
|
||||||
lj_dispatch.h lj_traceerr.h lj_snap.h lj_target.h lj_target_x86.h
|
lj_dispatch.h lj_traceerr.h lj_snap.h lj_target.h lj_target_*.h
|
||||||
lj_state.o: lj_state.c lj_obj.h lua.h luaconf.h lj_def.h lj_arch.h \
|
lj_state.o: lj_state.c lj_obj.h lua.h luaconf.h lj_def.h lj_arch.h \
|
||||||
lj_gc.h lj_err.h lj_errmsg.h lj_str.h lj_tab.h lj_func.h lj_meta.h \
|
lj_gc.h lj_err.h lj_errmsg.h lj_str.h lj_tab.h lj_func.h lj_meta.h \
|
||||||
lj_state.h lj_frame.h lj_bc.h lj_mcode.h lj_jit.h lj_ir.h lj_trace.h \
|
lj_state.h lj_frame.h lj_bc.h lj_mcode.h lj_jit.h lj_ir.h lj_trace.h \
|
||||||
@ -120,7 +118,7 @@ lj_trace.o: lj_trace.c lj_obj.h lua.h luaconf.h lj_def.h lj_arch.h \
|
|||||||
lj_gc.h lj_err.h lj_errmsg.h lj_str.h lj_frame.h lj_bc.h lj_state.h \
|
lj_gc.h lj_err.h lj_errmsg.h lj_str.h lj_frame.h lj_bc.h lj_state.h \
|
||||||
lj_ir.h lj_jit.h lj_iropt.h lj_mcode.h lj_trace.h lj_dispatch.h \
|
lj_ir.h lj_jit.h lj_iropt.h lj_mcode.h lj_trace.h lj_dispatch.h \
|
||||||
lj_traceerr.h lj_snap.h lj_gdbjit.h lj_record.h lj_asm.h lj_vm.h \
|
lj_traceerr.h lj_snap.h lj_gdbjit.h lj_record.h lj_asm.h lj_vm.h \
|
||||||
lj_vmevent.h lj_target.h lj_target_x86.h
|
lj_vmevent.h lj_target.h lj_target_*.h
|
||||||
lj_udata.o: lj_udata.c lj_obj.h lua.h luaconf.h lj_def.h lj_arch.h \
|
lj_udata.o: lj_udata.c lj_obj.h lua.h luaconf.h lj_def.h lj_arch.h \
|
||||||
lj_gc.h lj_udata.h
|
lj_gc.h lj_udata.h
|
||||||
lj_vmevent.o: lj_vmevent.c lj_obj.h lua.h luaconf.h lj_def.h lj_arch.h \
|
lj_vmevent.o: lj_vmevent.c lj_obj.h lua.h luaconf.h lj_def.h lj_arch.h \
|
||||||
@ -136,7 +134,7 @@ ljamalg.o: ljamalg.c lua.h luaconf.h lauxlib.h lj_gc.c lj_obj.h lj_def.h \
|
|||||||
lj_api.c lj_parse.h lj_lex.c lj_parse.c lj_lib.c lj_lib.h lj_ir.c \
|
lj_api.c lj_parse.h lj_lex.c lj_parse.c lj_lib.c lj_lib.h lj_ir.c \
|
||||||
lj_iropt.h lj_opt_mem.c lj_opt_fold.c lj_folddef.h lj_opt_narrow.c \
|
lj_iropt.h lj_opt_mem.c lj_opt_fold.c lj_folddef.h lj_opt_narrow.c \
|
||||||
lj_opt_dce.c lj_opt_loop.c lj_snap.h lj_mcode.c lj_snap.c lj_target.h \
|
lj_opt_dce.c lj_opt_loop.c lj_snap.h lj_mcode.c lj_snap.c lj_target.h \
|
||||||
lj_target_x86.h lj_record.c lj_record.h lj_asm.h lj_recdef.h lj_asm.c \
|
lj_target_*.h lj_record.c lj_record.h lj_asm.h lj_recdef.h lj_asm.c \
|
||||||
lj_trace.c lj_gdbjit.h lj_gdbjit.c lj_alloc.c lib_aux.c lib_base.c \
|
lj_trace.c lj_gdbjit.h lj_gdbjit.c lj_alloc.c lib_aux.c lib_base.c \
|
||||||
lualib.h lj_libdef.h lib_math.c lib_string.c lib_table.c lib_io.c \
|
lualib.h lj_libdef.h lib_math.c lib_string.c lib_table.c lib_io.c \
|
||||||
lib_os.c lib_package.c lib_debug.c lib_bit.c lib_jit.c lib_init.c
|
lib_os.c lib_package.c lib_debug.c lib_bit.c lib_jit.c lib_init.c
|
||||||
|
@ -28,7 +28,6 @@
|
|||||||
#include "lj_ir.h"
|
#include "lj_ir.h"
|
||||||
#include "lj_frame.h"
|
#include "lj_frame.h"
|
||||||
#include "lj_dispatch.h"
|
#include "lj_dispatch.h"
|
||||||
#include "lj_target.h"
|
|
||||||
|
|
||||||
#include "buildvm.h"
|
#include "buildvm.h"
|
||||||
|
|
||||||
|
@ -38,14 +38,8 @@
|
|||||||
struct dasm_State;
|
struct dasm_State;
|
||||||
|
|
||||||
/* Build modes. */
|
/* Build modes. */
|
||||||
#if LJ_TARGET_X86ORX64
|
|
||||||
#define BUILDDEFX(_) _(peobj)
|
|
||||||
#else
|
|
||||||
#define BUILDDEFX(_)
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#define BUILDDEF(_) \
|
#define BUILDDEF(_) \
|
||||||
_(elfasm) _(coffasm) _(machasm) BUILDDEFX(_) _(raw) \
|
_(elfasm) _(coffasm) _(machasm) _(peobj) _(raw) \
|
||||||
_(bcdef) _(ffdef) _(libdef) _(recdef) _(vmdef) \
|
_(bcdef) _(ffdef) _(libdef) _(recdef) _(vmdef) \
|
||||||
_(folddef)
|
_(folddef)
|
||||||
|
|
||||||
|
@ -322,4 +322,13 @@ void emit_peobj(BuildCtx *ctx)
|
|||||||
owrite(ctx, strtab, strtabofs);
|
owrite(ctx, strtab, strtabofs);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#else
|
||||||
|
|
||||||
|
void emit_peobj(BuildCtx *ctx)
|
||||||
|
{
|
||||||
|
UNUSED(ctx);
|
||||||
|
fprintf(stderr, "Error: no PE object support for this target\n");
|
||||||
|
exit(1);
|
||||||
|
}
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
@ -1049,7 +1049,6 @@ static const char *const extnames[] = {
|
|||||||
#define DtB(_V) (int)(ptrdiff_t)&(((Node *)0)_V)
|
#define DtB(_V) (int)(ptrdiff_t)&(((Node *)0)_V)
|
||||||
#define DtC(_V) (int)(ptrdiff_t)&(((int *)0)_V)
|
#define DtC(_V) (int)(ptrdiff_t)&(((int *)0)_V)
|
||||||
#define DtD(_V) (int)(ptrdiff_t)&(((GCtrace *)0)_V)
|
#define DtD(_V) (int)(ptrdiff_t)&(((GCtrace *)0)_V)
|
||||||
#define DtE(_V) (int)(ptrdiff_t)&(((ExitInfo *)0)_V)
|
|
||||||
#define DISPATCH_GL(field) (GG_DISP2G + (int)offsetof(global_State, field))
|
#define DISPATCH_GL(field) (GG_DISP2G + (int)offsetof(global_State, field))
|
||||||
#define DISPATCH_J(field) (GG_DISP2J + (int)offsetof(jit_State, field))
|
#define DISPATCH_J(field) (GG_DISP2J + (int)offsetof(jit_State, field))
|
||||||
#define PC2PROTO(field) ((int)offsetof(GCproto, field)-(int)sizeof(GCproto))
|
#define PC2PROTO(field) ((int)offsetof(GCproto, field)-(int)sizeof(GCproto))
|
||||||
|
@ -1050,7 +1050,6 @@ static const char *const extnames[] = {
|
|||||||
#define DtB(_V) (int)(ptrdiff_t)&(((Node *)0)_V)
|
#define DtB(_V) (int)(ptrdiff_t)&(((Node *)0)_V)
|
||||||
#define DtC(_V) (int)(ptrdiff_t)&(((int *)0)_V)
|
#define DtC(_V) (int)(ptrdiff_t)&(((int *)0)_V)
|
||||||
#define DtD(_V) (int)(ptrdiff_t)&(((GCtrace *)0)_V)
|
#define DtD(_V) (int)(ptrdiff_t)&(((GCtrace *)0)_V)
|
||||||
#define DtE(_V) (int)(ptrdiff_t)&(((ExitInfo *)0)_V)
|
|
||||||
#define DISPATCH_GL(field) (GG_DISP2G + (int)offsetof(global_State, field))
|
#define DISPATCH_GL(field) (GG_DISP2G + (int)offsetof(global_State, field))
|
||||||
#define DISPATCH_J(field) (GG_DISP2J + (int)offsetof(jit_State, field))
|
#define DISPATCH_J(field) (GG_DISP2J + (int)offsetof(jit_State, field))
|
||||||
#define PC2PROTO(field) ((int)offsetof(GCproto, field)-(int)sizeof(GCproto))
|
#define PC2PROTO(field) ((int)offsetof(GCproto, field)-(int)sizeof(GCproto))
|
||||||
|
@ -108,7 +108,6 @@
|
|||||||
|.type NODE, Node
|
|.type NODE, Node
|
||||||
|.type NARGS, int
|
|.type NARGS, int
|
||||||
|.type TRACE, GCtrace
|
|.type TRACE, GCtrace
|
||||||
|.type EXITINFO, ExitInfo
|
|
||||||
|
|
|
|
||||||
|// Stack layout while in interpreter. Must match with lj_frame.h.
|
|// Stack layout while in interpreter. Must match with lj_frame.h.
|
||||||
|//-----------------------------------------------------------------------
|
|//-----------------------------------------------------------------------
|
||||||
|
@ -1104,7 +1104,6 @@ static const char *const extnames[] = {
|
|||||||
#define DtB(_V) (int)(ptrdiff_t)&(((Node *)0)_V)
|
#define DtB(_V) (int)(ptrdiff_t)&(((Node *)0)_V)
|
||||||
#define DtC(_V) (int)(ptrdiff_t)&(((int *)0)_V)
|
#define DtC(_V) (int)(ptrdiff_t)&(((int *)0)_V)
|
||||||
#define DtD(_V) (int)(ptrdiff_t)&(((GCtrace *)0)_V)
|
#define DtD(_V) (int)(ptrdiff_t)&(((GCtrace *)0)_V)
|
||||||
#define DtE(_V) (int)(ptrdiff_t)&(((ExitInfo *)0)_V)
|
|
||||||
#define DISPATCH_GL(field) (GG_DISP2G + (int)offsetof(global_State, field))
|
#define DISPATCH_GL(field) (GG_DISP2G + (int)offsetof(global_State, field))
|
||||||
#define DISPATCH_J(field) (GG_DISP2J + (int)offsetof(jit_State, field))
|
#define DISPATCH_J(field) (GG_DISP2J + (int)offsetof(jit_State, field))
|
||||||
#define PC2PROTO(field) ((int)offsetof(GCproto, field)-(int)sizeof(GCproto))
|
#define PC2PROTO(field) ((int)offsetof(GCproto, field)-(int)sizeof(GCproto))
|
||||||
|
@ -950,7 +950,7 @@ static MCode *asm_exitstub_gen(ASMState *as, ExitNo group)
|
|||||||
}
|
}
|
||||||
/* Push the high byte of the exitno for each exit stub group. */
|
/* Push the high byte of the exitno for each exit stub group. */
|
||||||
*mxp++ = XI_PUSHi8; *mxp++ = (MCode)((group*EXITSTUBS_PER_GROUP)>>8);
|
*mxp++ = XI_PUSHi8; *mxp++ = (MCode)((group*EXITSTUBS_PER_GROUP)>>8);
|
||||||
/* Store DISPATCH in ExitInfo->dispatch. Account for the two push ops. */
|
/* Store DISPATCH at original stack slot 0. Account for the two push ops. */
|
||||||
*mxp++ = XI_MOVmi;
|
*mxp++ = XI_MOVmi;
|
||||||
*mxp++ = MODRM(XM_OFS8, 0, RID_ESP);
|
*mxp++ = MODRM(XM_OFS8, 0, RID_ESP);
|
||||||
*mxp++ = MODRM(XM_SCALE1, RID_ESP, RID_ESP);
|
*mxp++ = MODRM(XM_SCALE1, RID_ESP, RID_ESP);
|
||||||
|
@ -140,7 +140,12 @@ static LJ_AINLINE uint32_t lj_fls(uint32_t x)
|
|||||||
#define lj_fls(x) ((uint32_t)(__builtin_clz(x)^31))
|
#define lj_fls(x) ((uint32_t)(__builtin_clz(x)^31))
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#if defined(__i386__) || defined(__x86_64__)
|
#if __GNUC__ >= 4 && __GNUC_MINOR__ >= 3
|
||||||
|
static LJ_AINLINE uint32_t lj_bswap(uint32_t x)
|
||||||
|
{
|
||||||
|
return (uint32_t)__builtin_bswap32((int32_t)x);
|
||||||
|
}
|
||||||
|
#elif defined(__i386__) || defined(__x86_64__)
|
||||||
static LJ_AINLINE uint32_t lj_bswap(uint32_t x)
|
static LJ_AINLINE uint32_t lj_bswap(uint32_t x)
|
||||||
{
|
{
|
||||||
uint32_t r; __asm__("bswap %0" : "=r" (r) : "0" (x)); return r;
|
uint32_t r; __asm__("bswap %0" : "=r" (r) : "0" (x)); return r;
|
||||||
|
Loading…
Reference in New Issue
Block a user