From 193a22df28762226b13898960fe0be25f4f33b9c Mon Sep 17 00:00:00 2001 From: cxluoshuai <398943552@qq.com> Date: Tue, 25 Jun 2024 22:21:41 +0800 Subject: [PATCH] mem_link_valid ( called by MEM_SANITY() ) need to be called under protected conditions. because, plug_holes which is called by mem_free will change data that used by mem_link_valid. --- src/core/mem.c | 4 +++- 1 file changed, 3 insertions(+), 1 deletion(-) diff --git a/src/core/mem.c b/src/core/mem.c index 0aa34a263..b253ae40c 100644 --- a/src/core/mem.c +++ b/src/core/mem.c @@ -935,6 +935,9 @@ mem_malloc(mem_size_t size_in) lfree = cur; LWIP_ASSERT("mem_malloc: !lfree->used", ((lfree == ram_end) || (!lfree->used))); } + /* mem_link_valid ( called by MEM_SANITY() ) need to be called under protected conditions. + because, plug_holes which is called by mem_free will change data that used by mem_link_valid */ + MEM_SANITY(); LWIP_MEM_ALLOC_UNPROTECT(); sys_mutex_unlock(&mem_mutex); LWIP_ASSERT("mem_malloc: allocated memory not above ram_end.", @@ -947,7 +950,6 @@ mem_malloc(mem_size_t size_in) #if MEM_OVERFLOW_CHECK mem_overflow_init_element(mem, size_in); #endif - MEM_SANITY(); return (u8_t *)mem + SIZEOF_STRUCT_MEM + MEM_SANITY_OFFSET; } }