diff options
Diffstat (limited to 'src/lj_vm.h')
-rw-r--r-- | src/lj_vm.h | 22 |
1 files changed, 11 insertions, 11 deletions
diff --git a/src/lj_vm.h b/src/lj_vm.h index 92f65ee0..be35295d 100644 --- a/src/lj_vm.h +++ b/src/lj_vm.h | |||
@@ -43,13 +43,14 @@ LJ_ASMF void lj_vm_record(void); | |||
43 | LJ_ASMF void lj_vm_inshook(void); | 43 | LJ_ASMF void lj_vm_inshook(void); |
44 | LJ_ASMF void lj_vm_rethook(void); | 44 | LJ_ASMF void lj_vm_rethook(void); |
45 | LJ_ASMF void lj_vm_callhook(void); | 45 | LJ_ASMF void lj_vm_callhook(void); |
46 | LJ_ASMF void lj_vm_profhook(void); | ||
46 | 47 | ||
47 | /* Trace exit handling. */ | 48 | /* Trace exit handling. */ |
48 | LJ_ASMF void lj_vm_exit_handler(void); | 49 | LJ_ASMF void lj_vm_exit_handler(void); |
49 | LJ_ASMF void lj_vm_exit_interp(void); | 50 | LJ_ASMF void lj_vm_exit_interp(void); |
50 | 51 | ||
51 | /* Internal math helper functions. */ | 52 | /* Internal math helper functions. */ |
52 | #if LJ_TARGET_X86ORX64 || LJ_TARGET_PPC | 53 | #if LJ_TARGET_PPC || LJ_TARGET_ARM64 || (LJ_TARGET_MIPS && LJ_ABI_SOFTFP) |
53 | #define lj_vm_floor floor | 54 | #define lj_vm_floor floor |
54 | #define lj_vm_ceil ceil | 55 | #define lj_vm_ceil ceil |
55 | #else | 56 | #else |
@@ -60,23 +61,26 @@ LJ_ASMF double lj_vm_floor_sf(double); | |||
60 | LJ_ASMF double lj_vm_ceil_sf(double); | 61 | LJ_ASMF double lj_vm_ceil_sf(double); |
61 | #endif | 62 | #endif |
62 | #endif | 63 | #endif |
63 | #if defined(LUAJIT_NO_LOG2) || LJ_TARGET_X86ORX64 | 64 | #ifdef LUAJIT_NO_LOG2 |
64 | LJ_ASMF double lj_vm_log2(double); | 65 | LJ_ASMF double lj_vm_log2(double); |
65 | #else | 66 | #else |
66 | #define lj_vm_log2 log2 | 67 | #define lj_vm_log2 log2 |
67 | #endif | 68 | #endif |
69 | #if !(defined(_LJ_DISPATCH_H) && LJ_TARGET_MIPS) | ||
70 | LJ_ASMF int32_t LJ_FASTCALL lj_vm_modi(int32_t, int32_t); | ||
71 | #endif | ||
68 | 72 | ||
69 | #if LJ_HASJIT | 73 | #if LJ_HASJIT |
70 | #if LJ_TARGET_X86ORX64 | 74 | #if LJ_TARGET_X86ORX64 |
71 | LJ_ASMF void lj_vm_floor_sse(void); | 75 | LJ_ASMF void lj_vm_floor_sse(void); |
72 | LJ_ASMF void lj_vm_ceil_sse(void); | 76 | LJ_ASMF void lj_vm_ceil_sse(void); |
73 | LJ_ASMF void lj_vm_trunc_sse(void); | 77 | LJ_ASMF void lj_vm_trunc_sse(void); |
74 | LJ_ASMF void lj_vm_exp_x87(void); | ||
75 | LJ_ASMF void lj_vm_exp2_x87(void); | ||
76 | LJ_ASMF void lj_vm_pow_sse(void); | ||
77 | LJ_ASMF void lj_vm_powi_sse(void); | 78 | LJ_ASMF void lj_vm_powi_sse(void); |
79 | #define lj_vm_powi NULL | ||
78 | #else | 80 | #else |
79 | #if LJ_TARGET_PPC | 81 | LJ_ASMF double lj_vm_powi(double, int32_t); |
82 | #endif | ||
83 | #if LJ_TARGET_PPC || LJ_TARGET_ARM64 | ||
80 | #define lj_vm_trunc trunc | 84 | #define lj_vm_trunc trunc |
81 | #else | 85 | #else |
82 | LJ_ASMF double lj_vm_trunc(double); | 86 | LJ_ASMF double lj_vm_trunc(double); |
@@ -84,14 +88,11 @@ LJ_ASMF double lj_vm_trunc(double); | |||
84 | LJ_ASMF double lj_vm_trunc_sf(double); | 88 | LJ_ASMF double lj_vm_trunc_sf(double); |
85 | #endif | 89 | #endif |
86 | #endif | 90 | #endif |
87 | LJ_ASMF double lj_vm_powi(double, int32_t); | ||
88 | #ifdef LUAJIT_NO_EXP2 | 91 | #ifdef LUAJIT_NO_EXP2 |
89 | LJ_ASMF double lj_vm_exp2(double); | 92 | LJ_ASMF double lj_vm_exp2(double); |
90 | #else | 93 | #else |
91 | #define lj_vm_exp2 exp2 | 94 | #define lj_vm_exp2 exp2 |
92 | #endif | 95 | #endif |
93 | #endif | ||
94 | LJ_ASMF int32_t LJ_FASTCALL lj_vm_modi(int32_t, int32_t); | ||
95 | #if LJ_HASFFI | 96 | #if LJ_HASFFI |
96 | LJ_ASMF int lj_vm_errno(void); | 97 | LJ_ASMF int lj_vm_errno(void); |
97 | #endif | 98 | #endif |
@@ -104,8 +105,7 @@ LJ_ASMF void lj_cont_nop(void); /* Do nothing, just continue execution. */ | |||
104 | LJ_ASMF void lj_cont_condt(void); /* Branch if result is true. */ | 105 | LJ_ASMF void lj_cont_condt(void); /* Branch if result is true. */ |
105 | LJ_ASMF void lj_cont_condf(void); /* Branch if result is false. */ | 106 | LJ_ASMF void lj_cont_condf(void); /* Branch if result is false. */ |
106 | LJ_ASMF void lj_cont_hook(void); /* Continue from hook yield. */ | 107 | LJ_ASMF void lj_cont_hook(void); /* Continue from hook yield. */ |
107 | 108 | LJ_ASMF void lj_cont_stitch(void); /* Trace stitching. */ | |
108 | enum { LJ_CONT_TAILCALL, LJ_CONT_FFI_CALLBACK }; /* Special continuations. */ | ||
109 | 109 | ||
110 | /* Start of the ASM code. */ | 110 | /* Start of the ASM code. */ |
111 | LJ_ASMF char lj_vm_asm_begin[]; | 111 | LJ_ASMF char lj_vm_asm_begin[]; |