diff options
author | Kimplul <kimi.h.kuparinen@gmail.com> | 2024-06-26 22:47:06 +0300 |
---|---|---|
committer | Kimplul <kimi.h.kuparinen@gmail.com> | 2024-06-26 22:47:06 +0300 |
commit | 0dd8d9d6f07201bcbbaa677b8bfa2db227236898 (patch) | |
tree | cbce33db0f2b4a903fc5783ad91b4d901185b84e /src/ejit.c | |
parent | 892d0f16b2e69bc527b576ee896c39484216338f (diff) | |
download | ejit-0dd8d9d6f07201bcbbaa677b8bfa2db227236898.tar.gz ejit-0dd8d9d6f07201bcbbaa677b8bfa2db227236898.zip |
allow toggling between jit and bytecode
Diffstat (limited to 'src/ejit.c')
-rw-r--r-- | src/ejit.c | 7 |
1 files changed, 6 insertions, 1 deletions
@@ -55,6 +55,11 @@ struct ejit_func *ejit_create_func(enum ejit_type rtype, size_t argc, const stru void ejit_compile_func(struct ejit_func *f, size_t gpr, size_t fpr) { + ejit_select_compile_func(f, gpr, fpr, true); +} + +void ejit_select_compile_func(struct ejit_func *f, size_t gpr, size_t fpr, bool try_jit) +{ /* emit a final end instruction in case user didn't do a return */ emit_insn_i(f, END, 0, 0, 0); @@ -62,7 +67,7 @@ void ejit_compile_func(struct ejit_func *f, size_t gpr, size_t fpr) f->fpr = fpr; /* try to jit compile if possible */ - if (ejit_compile(f)) + if (try_jit && ejit_compile(f)) return; /* otherwise, convert opcodes to address labels */ |