From 1b10d798d742860e677b13db13162ead8db647b1 Mon Sep 17 00:00:00 2001 From: Nicolas Geoffray Date: Wed, 29 Jul 2009 22:55:02 +0000 Subject: [PATCH] In TrimAllocationToSize, if a block is below the minimum allocation size, there is no new block added to the free list. Therefore on the next startFunctionBody call, a new slab must be allocated. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@77520 91177308-0d34-0410-b5e6-96231b3b80d8 --- lib/ExecutionEngine/JIT/JITMemoryManager.cpp | 5 ++++- 1 file changed, 4 insertions(+), 1 deletion(-) diff --git a/lib/ExecutionEngine/JIT/JITMemoryManager.cpp b/lib/ExecutionEngine/JIT/JITMemoryManager.cpp index 2d64fcfa490..3f38f9c241a 100644 --- a/lib/ExecutionEngine/JIT/JITMemoryManager.cpp +++ b/lib/ExecutionEngine/JIT/JITMemoryManager.cpp @@ -351,9 +351,12 @@ namespace { iter = iter->Next; } + largest = largest - sizeof(MemoryRangeHeader); + // If this block isn't big enough for the allocation desired, allocate // another block of memory and add it to the free list. - if (largest - sizeof(MemoryRangeHeader) < ActualSize) { + if (largest < ActualSize || + largest <= FreeRangeHeader::getMinBlockSize()) { DOUT << "JIT: Allocating another slab of memory for function."; candidateBlock = allocateNewCodeSlab((size_t)ActualSize); }