diff options
author | Mike Pall <mike> | 2016-10-02 14:24:04 +0200 |
---|---|---|
committer | Mike Pall <mike> | 2016-10-02 14:24:04 +0200 |
commit | fcc824489914bd4f23c3a49ff9f32fb23cd53c48 (patch) | |
tree | 5eb427209dec108657bf4a042acfab680978a389 /src | |
parent | 8ada57eb49fb03d4d1c3cb37e534b97fbb92a5e6 (diff) | |
download | luajit-fcc824489914bd4f23c3a49ff9f32fb23cd53c48.tar.gz luajit-fcc824489914bd4f23c3a49ff9f32fb23cd53c48.tar.bz2 luajit-fcc824489914bd4f23c3a49ff9f32fb23cd53c48.zip |
ARM: Fix BLX encoding for Thumb interworking calls.
Thanks to Charles Baylis.
Diffstat (limited to 'src')
-rw-r--r-- | src/lj_emit_arm.h | 2 |
1 files changed, 1 insertions, 1 deletions
diff --git a/src/lj_emit_arm.h b/src/lj_emit_arm.h index 7f73698d..610bc6c5 100644 --- a/src/lj_emit_arm.h +++ b/src/lj_emit_arm.h | |||
@@ -273,7 +273,7 @@ static void emit_call(ASMState *as, void *target) | |||
273 | ptrdiff_t delta = ((char *)target - (char *)p) - 8; | 273 | ptrdiff_t delta = ((char *)target - (char *)p) - 8; |
274 | if ((((delta>>2) + 0x00800000) >> 24) == 0) { | 274 | if ((((delta>>2) + 0x00800000) >> 24) == 0) { |
275 | if ((delta & 1)) | 275 | if ((delta & 1)) |
276 | *p = ARMI_BLX | ((uint32_t)(delta>>2) & 0x00ffffffu) | ((delta&2) << 27); | 276 | *p = ARMI_BLX | ((uint32_t)(delta>>2) & 0x00ffffffu) | ((delta&2) << 23); |
277 | else | 277 | else |
278 | *p = ARMI_BL | ((uint32_t)(delta>>2) & 0x00ffffffu); | 278 | *p = ARMI_BL | ((uint32_t)(delta>>2) & 0x00ffffffu); |
279 | } else { /* Target out of range: need indirect call. But don't use R0-R3. */ | 279 | } else { /* Target out of range: need indirect call. But don't use R0-R3. */ |