Do not hold the JIT lock when materializing a function and verify if the
authorNicolas Geoffray <nicolas.geoffray@lip6.fr>
Sun, 20 Apr 2008 08:33:02 +0000 (08:33 +0000)
committerNicolas Geoffray <nicolas.geoffray@lip6.fr>
Sun, 20 Apr 2008 08:33:02 +0000 (08:33 +0000)
function has already been codegen'd. This is required by the Java class loading
mechanism which executes Java code when materializing a function.

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

lib/ExecutionEngine/JIT/JIT.cpp

index 281869ad1bfedb2db6c4ab50f096a3057043d20a..9e89e3c0e1d93c8eab9f57344a7b2b33e006bd06 100644 (file)
@@ -301,7 +301,6 @@ void JIT::runJITOnFunction(Function *F) {
 /// specified function, compiling it if neccesary.
 ///
 void *JIT::getPointerToFunction(Function *F) {
-  MutexGuard locked(lock);
 
   if (void *Addr = getPointerToGlobalIfAvailable(F))
     return Addr;   // Check if function already code gen'd
@@ -326,7 +325,13 @@ void *JIT::getPointerToFunction(Function *F) {
       abort();
     }
   }
+  
+  if (void *Addr = getPointerToGlobalIfAvailable(F)) {
+    return Addr;
+  }
 
+  MutexGuard locked(lock);
+  
   if (F->isDeclaration()) {
     void *Addr = getPointerToNamedFunction(F->getName());
     addGlobalMapping(F, Addr);