diff options
Diffstat (limited to 'examples')
-rw-r--r-- | examples/fib.c | 36 | ||||
-rw-r--r-- | examples/loop.c | 4 |
2 files changed, 18 insertions, 22 deletions
diff --git a/examples/fib.c b/examples/fib.c index fe2b215..308ecd1 100644 --- a/examples/fib.c +++ b/examples/fib.c @@ -3,12 +3,12 @@ #include "../include/ejit/ejit.h" -struct ejit_func *compile() +struct ejit_func *compile(bool try_jit) { struct ejit_operand args[1] = { - EJIT_OPERAND_GPR(0, EJIT_INT64) /* loc 0 contains n */ + EJIT_OPERAND_GPR(0, EJIT_INT32) /* loc 0 contains n */ }; - struct ejit_func *f = ejit_create_func(EJIT_INT64, 1, args); + struct ejit_func *f = ejit_create_func(EJIT_INT32, 1, args); struct ejit_reloc recurse = ejit_bgti(f, EJIT_GPR(0), 2); /* n <= 2 */ ejit_reti(f, 1); @@ -18,63 +18,59 @@ struct ejit_func *compile() /* fib(n - 1) */ ejit_subi(f, EJIT_GPR(0), EJIT_GPR(0), 1); struct ejit_operand arg[1] = { - EJIT_OPERAND_GPR(0, EJIT_INT64) + EJIT_OPERAND_GPR(0, EJIT_INT32) }; - ejit_calli(f, f, 1, arg); + ejit_calli_i(f, f, 1, arg); ejit_retval(f, EJIT_GPR(1)); /* loc 1 contains temp result */ /* fib(n - 2) */ ejit_subi(f, EJIT_GPR(0), EJIT_GPR(0), 1); - ejit_calli(f, f, 1, arg); + ejit_calli_i(f, f, 1, arg); ejit_retval(f, EJIT_GPR(0)); /* loc 0 now contains second temp result */ ejit_addr(f, EJIT_GPR(0), EJIT_GPR(0), EJIT_GPR(1)); /* add results */ ejit_retr(f, EJIT_GPR(0)); - bool try_jit = true; -#ifdef NOJIT - try_jit = false; -#endif - /* the highest location we used was 1, so we need to request 2 locations * for general purpose registers in total. No floating point registers, * so 0. */ - ejit_select_compile_func(f, 2, 0, true, try_jit); + ejit_select_compile_func(f, 2, 0, EJIT_USE64(int32_t), try_jit); return f; } int main(int argc, char *argv[]) { - if(argc != 3){ - fprintf(stderr, "Usage: %s compile_num loop_num\n", argv[0]); + if(argc != 4){ + fprintf(stderr, "Usage: %s compile_num loop_num jit\n", argv[0]); return -1; } + int try_jit = strtoull(argv[3], 0, 0); size_t compile_num = strtoull(argv[1], 0, 0); struct ejit_func **info = calloc(compile_num, sizeof(struct ejit_func *)); clock_t t = clock(); for(size_t i = 0; i < compile_num; ++i){ - info[i] = compile(); + info[i] = compile(try_jit); } t = clock() - t; double compile_time_total = ((double)t) / CLOCKS_PER_SEC; double compile_time_one = compile_time_total / compile_num; - printf("Compilation for n = %lu took %fs (1/%f).\n", + printf("Compilation for n = %zu took %fs (1/%f).\n", compile_num, compile_time_total, compile_time_one); size_t run_num = strtoull(argv[2], 0, 0); t = clock(); struct ejit_arg arg[1] = { - (struct ejit_arg){.type = EJIT_INT64, .l = run_num} + (struct ejit_arg){.type = EJIT_INT32, .l = run_num} }; - size_t result = ejit_run_func(info[0], 1, arg); + int32_t result = ejit_run_func_i(info[0], 1, arg); t = clock() - t; double run_time_total = ((double)t) / CLOCKS_PER_SEC; - printf("Running loop for n = %lu took %fs with res %lu\n", - run_num, run_time_total, result); + printf("Running loop for n = %zu took %fs with res %ld\n", + run_num, run_time_total, (long)result); for(size_t i = 0; i < compile_num; ++i) ejit_destroy_func(info[i]); diff --git a/examples/loop.c b/examples/loop.c index 51ba2e9..537a931 100644 --- a/examples/loop.c +++ b/examples/loop.c @@ -3,7 +3,7 @@ int main() { - struct ejit_func *f = ejit_create_func(EJIT_INT64, 0, NULL); + struct ejit_func *f = ejit_create_func(EJIT_TYPE(long), 0, NULL); ejit_movi(f, EJIT_GPR(3), 1); // location 3 just has a constant 1 for // increment @@ -21,7 +21,7 @@ int main() ejit_patch(f, r, l); ejit_compile_func(f); - long result = ejit_run_func(f, 0, NULL); // no args so this is fine + long result = ejit_run_func_i(f, 0, NULL); // no args so this is fine printf("%ld\n", result); ejit_destroy_func(f); |