Fix JIT support for static ctors, which was apparently completely broken!
authorChris Lattner <sabre@nondot.org>
Sat, 22 Apr 2006 05:02:46 +0000 (05:02 +0000)
committerChris Lattner <sabre@nondot.org>
Sat, 22 Apr 2006 05:02:46 +0000 (05:02 +0000)
This allows Prolangs-C++/city and probably a bunch of other stuff to work
well with the new front-end

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

lib/ExecutionEngine/ExecutionEngine.cpp

index ab56f592b0438fd4f4f398ebb1fb76be6680b68d..5cd83ff51a353d8a5c35ea989cc9fc1137754728 100644 (file)
@@ -103,7 +103,11 @@ static void *CreateArgv(ExecutionEngine *EE,
 void ExecutionEngine::runStaticConstructorsDestructors(bool isDtors) {
   const char *Name = isDtors ? "llvm.global_dtors" : "llvm.global_ctors";
   GlobalVariable *GV = CurMod.getNamedGlobal(Name);
-  if (!GV || GV->isExternal() || !GV->hasInternalLinkage()) return;
+
+  // If this global has internal linkage, or if it has a use, then it must be
+  // an old-style (llvmgcc3) static ctor with __main linked in and in use.  If
+  // this is the case, don't execute any of the global ctors, __main will do it.
+  if (!GV || GV->isExternal() || GV->hasInternalLinkage()) return;
   
   // Should be an array of '{ int, void ()* }' structs.  The first value is the
   // init priority, which we ignore.