Set FnEnd in JITEmitter::finishFunction to point strictly to the end of function...
authorArgyrios Kyrtzidis <akyrtzi@gmail.com>
Thu, 30 Apr 2009 23:01:58 +0000 (23:01 +0000)
committerArgyrios Kyrtzidis <akyrtzi@gmail.com>
Thu, 30 Apr 2009 23:01:58 +0000 (23:01 +0000)
Don't include memory allocated for global variables during relocations resolution.

git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@70517 91177308-0d34-0410-b5e6-96231b3b80d8

lib/ExecutionEngine/JIT/JITEmitter.cpp

index afb89e7fb3876c692e937286e03b20f3f9eaa408..7356df4e4f7be1c5053cfc73aa4f0918ff4a9e42 100644 (file)
@@ -1051,6 +1051,9 @@ bool JITEmitter::finishFunction(MachineFunction &F) {
   unsigned char *FnStart =
     (unsigned char *)TheJIT->getPointerToGlobalIfAvailable(F.getFunction());
 
+  // FnEnd is the end of the function's machine code.
+  unsigned char *FnEnd = CurBufferPtr;
+
   if (!Relocations.empty()) {
     CurFn = F.getFunction();
     NumRelos += Relocations.size();
@@ -1128,9 +1131,9 @@ bool JITEmitter::finishFunction(MachineFunction &F) {
     }
   }
 
-  unsigned char *FnEnd = CurBufferPtr;
-
-  MemMgr->endFunctionBody(F.getFunction(), BufferBegin, FnEnd);
+  // CurBufferPtr may have moved beyond FnEnd, due to memory allocation for
+  // global variables that were referenced in the relocations.
+  MemMgr->endFunctionBody(F.getFunction(), BufferBegin, CurBufferPtr);
 
   if (CurBufferPtr == BufferEnd) {
     // FIXME: Allocate more space, then try again.