From 5ceba0133df15ef3d9064fcbe9cb14d9f9d8b128 Mon Sep 17 00:00:00 2001 From: Zhongwei Yao Date: Fri, 7 Jul 2023 11:20:48 -0700 Subject: [PATCH] fix(luajit): fix LuaJIT arm64 SIGILL crash. This fix removes the blocker to enable JIT on arm64 platform like MacOS M1/M2 chips. And the patch is under up-streaming processing. Once the LuaJIT-2.1-20220411_05_arm64_sigill.patch has been merged in upstream, we can pull the latest upstream and remove this internal maintained patch. (cherry picked from commit 8e122cc5c1c28167e86448028c45ee5a643e9f39) --- .../LuaJIT-2.1-20220411_05_arm64_sigill.patch | 26 +++++++++++++++++++ 1 file changed, 26 insertions(+) create mode 100644 build/openresty/patches/LuaJIT-2.1-20220411_05_arm64_sigill.patch diff --git a/build/openresty/patches/LuaJIT-2.1-20220411_05_arm64_sigill.patch b/build/openresty/patches/LuaJIT-2.1-20220411_05_arm64_sigill.patch new file mode 100644 index 000000000000..32ab57b8ad83 --- /dev/null +++ b/build/openresty/patches/LuaJIT-2.1-20220411_05_arm64_sigill.patch @@ -0,0 +1,26 @@ +From 56f0ff1a7bcb3bacdefa3c0f4b0a6a3efcf90bd5 Mon Sep 17 00:00:00 2001 +From: Zhongwei Yao +Date: Tue, 4 Jul 2023 15:20:19 -0800 +Subject: [PATCH] Fix fuse case for LDP instuction on Arm64 when offset is + negative. + +--- + src/lj_emit_arm64.h | 2 +- + 1 file changed, 1 insertion(+), 1 deletion(-) + +diff --git a/bundle/LuaJIT-2.1-20220411/src/lj_emit_arm64.h b/bundle/LuaJIT-2.1-20220411/src/lj_emit_arm64.h +index 0ddba4a3..e19a8e4a 100644 +--- a/bundle/LuaJIT-2.1-20220411/src/lj_emit_arm64.h ++++ b/bundle/LuaJIT-2.1-20220411/src/lj_emit_arm64.h +@@ -143,7 +143,7 @@ static void emit_lso(ASMState *as, A64Ins ai, Reg rd, Reg rn, int64_t ofs) + goto nopair; + } + if (ofsm >= (int)((unsigned int)-64<mcp = aip | A64F_N(rn) | ((ofsm >> sc) << 15) | ++ *as->mcp = aip | A64F_N(rn) | (((ofsm >> sc)&0x7f) << 15) | + (ai ^ ((ai == A64I_LDRx || ai == A64I_STRx) ? 0x50000000 : 0x90000000)); + return; + } +-- +2.41.0 +