From b3df3f842c80a3191038873c1c03b696c20dbe6a Mon Sep 17 00:00:00 2001 From: Aapo Talvensaari Date: Mon, 17 Jun 2024 13:11:55 +0300 Subject: [PATCH] chore(patches): fix luajit segment release check in internal memory allocator ### Summary See: https://github.com/LuaJIT/LuaJIT/commit/9b5e837ac2dfdc0638830c048a47ca9378c504d3 Signed-off-by: Aapo Talvensaari --- ...-2.1-20231117_03_fix-segment-release.patch | 23 +++++++++++++++++++ t/01-pdk/16-rl-ctx.t | 1 + 2 files changed, 24 insertions(+) create mode 100644 build/openresty/patches/LuaJIT-2.1-20231117_03_fix-segment-release.patch diff --git a/build/openresty/patches/LuaJIT-2.1-20231117_03_fix-segment-release.patch b/build/openresty/patches/LuaJIT-2.1-20231117_03_fix-segment-release.patch new file mode 100644 index 000000000000..1fd9eefba23a --- /dev/null +++ b/build/openresty/patches/LuaJIT-2.1-20231117_03_fix-segment-release.patch @@ -0,0 +1,23 @@ +From 9b5e837ac2dfdc0638830c048a47ca9378c504d3 Mon Sep 17 00:00:00 2001 +From: Mike Pall +Date: Fri, 19 Apr 2024 01:44:19 +0200 +Subject: [PATCH] Fix segment release check in internal memory allocator. + +Thanks to Jinji Zeng. #1179 #1157 +--- + src/lj_alloc.c | 2 +- + 1 file changed, 1 insertion(+), 1 deletion(-) + +diff --git a/bundle/LuaJIT-2.1-20231117/src/lj_alloc.c b/bundle/LuaJIT-2.1-20231117/src/lj_alloc.c +index 9adaa0e5bd..0c0c0c4f4c 100644 +--- a/bundle/LuaJIT-2.1-20231117/src/lj_alloc.c ++++ b/bundle/LuaJIT-2.1-20231117/src/lj_alloc.c +@@ -1057,7 +1057,7 @@ static size_t release_unused_segments(mstate m) + mchunkptr p = align_as_chunk(base); + size_t psize = chunksize(p); + /* Can unmap if first chunk holds entire segment and not pinned */ +- if (!cinuse(p) && (char *)p + psize >= base + size - TOP_FOOT_SIZE) { ++ if (!cinuse(p) && (char *)p + psize == (char *)mem2chunk(sp)) { + tchunkptr tp = (tchunkptr)p; + if (p == m->dv) { + m->dv = 0; diff --git a/t/01-pdk/16-rl-ctx.t b/t/01-pdk/16-rl-ctx.t index 2c233fd9c01f..f7d933cf9085 100644 --- a/t/01-pdk/16-rl-ctx.t +++ b/t/01-pdk/16-rl-ctx.t @@ -92,6 +92,7 @@ X-2: 2 [error] + === TEST 3: should work in header_filter phase --- http_config eval: $t::Util::HttpConfig --- config