Teach the interpreter to handle global variables that are added to a module after
authorJeff Cohen <jeffc@jolt-lang.org>
Tue, 7 Feb 2006 05:11:57 +0000 (05:11 +0000)
committerJeff Cohen <jeffc@jolt-lang.org>
Tue, 7 Feb 2006 05:11:57 +0000 (05:11 +0000)
interpretation has begun.  The JIT already handles this situation correctly, and
the interpreter can already handle new functions being added.

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

lib/ExecutionEngine/ExecutionEngine.cpp

index 53587bff5a077c413e1925812c394957e55c7577..95610e65b60d4545e54f2dd00a028da1b980de53 100644 (file)
@@ -171,7 +171,16 @@ void *ExecutionEngine::getPointerToGlobal(const GlobalValue *GV) {
     return getPointerToFunction(F);
 
   MutexGuard locked(lock);
-  assert(state.getGlobalAddressMap(locked)[GV] && "Global hasn't had an address allocated yet?");
+  void *p = state.getGlobalAddressMap(locked)[GV];
+  if (p)
+    return p;
+
+  // Global variable might have been added since interpreter started.
+  if (GlobalVariable *GVar =
+          const_cast<GlobalVariable *>(dyn_cast<GlobalVariable>(GV)))
+    EmitGlobalVariable(GVar);
+  else
+    assert("Global hasn't had an address allocated yet!");
   return state.getGlobalAddressMap(locked)[GV];
 }