-rw-r--r-- | lib/jit_arm.c | 18 |
diff --git a/lib/jit_arm.c b/lib/jit_arm.c index 1790225..66842ee 100644 --- a/lib/jit_arm.c +++ b/lib/jit_arm.c @@ -1589,10 +1589,7 @@ _emit_code(jit_state_t *_jit) patch_at(_jitc->patches.ptr[offset].kind & ~arm_patch_node, word, value); } -#if defined(__GNUC__) - word = sysconf(_SC_PAGE_SIZE); - __clear_cache(_jit->code.ptr, (void *)((_jit->pc.w + word) & -word)); -#endif + jit_flush(_jit->code.ptr, _jit->pc.uc); return (_jit->code.ptr); } @@ -1604,6 +1601,19 @@ _emit_code(jit_state_t *_jit) #undef CODE void +jit_flush(void *fptr, void *tptr) +{ +#if defined(__GNUC__) + jit_word_t f, t, s; + + s = sysconf(_SC_PAGE_SIZE); + f = (jit_word_t)fptr & -s; + t = (((jit_word_t)tptr) + s - 1) & -s; + __clear_cache((void *)f, (void *)t); +#endif +} + +void _emit_ldxi(jit_state_t *_jit, jit_int32_t r0, jit_int32_t r1, jit_word_t i0) { ldxi_i(rn(r0), rn(r1), i0); |