[llvm-commits] [llvm] r124650 - in /llvm/trunk: lib/Linker/LinkModules.cpp test/Linker/available_externally_a.ll test/Linker/available_externally_b.ll

Rafael Espindola rafael.espindola at gmail.com
Mon Jan 31 21:33:52 PST 2011


Author: rafael
Date: Mon Jan 31 23:33:52 2011
New Revision: 124650

URL: http://llvm.org/viewvc/llvm-project?rev=124650&view=rev
Log:
Correctly merge available_externally and regular definitions when they have
different visibilities.

Added:
    llvm/trunk/test/Linker/available_externally_a.ll
    llvm/trunk/test/Linker/available_externally_b.ll
Modified:
    llvm/trunk/lib/Linker/LinkModules.cpp

Modified: llvm/trunk/lib/Linker/LinkModules.cpp
URL: http://llvm.org/viewvc/llvm-project/llvm/trunk/lib/Linker/LinkModules.cpp?rev=124650&r1=124649&r2=124650&view=diff
==============================================================================
--- llvm/trunk/lib/Linker/LinkModules.cpp (original)
+++ llvm/trunk/lib/Linker/LinkModules.cpp Mon Jan 31 23:33:52 2011
@@ -434,8 +434,10 @@
   }
 
   // Check visibility
-  if (Dest && Src->getVisibility() != Dest->getVisibility())
-    if (!Src->isDeclaration() && !Dest->isDeclaration())
+  if (Dest && Src->getVisibility() != Dest->getVisibility() &&
+      !Src->isDeclaration() && !Dest->isDeclaration() &&
+      !Src->hasAvailableExternallyLinkage() &&
+      !Dest->hasAvailableExternallyLinkage())
       return Error(Err, "Linking globals named '" + Src->getName() +
                    "': symbols have different visibilities!");
   return false;

Added: llvm/trunk/test/Linker/available_externally_a.ll
URL: http://llvm.org/viewvc/llvm-project/llvm/trunk/test/Linker/available_externally_a.ll?rev=124650&view=auto
==============================================================================
--- llvm/trunk/test/Linker/available_externally_a.ll (added)
+++ llvm/trunk/test/Linker/available_externally_a.ll Mon Jan 31 23:33:52 2011
@@ -0,0 +1,5 @@
+; RUN: llvm-link %s %p/available_externally_b.ll -S -o - | FileCheck %s
+
+ at foo = available_externally unnamed_addr constant i32 0
+
+; CHECK: @foo = hidden unnamed_addr constant i32 0

Added: llvm/trunk/test/Linker/available_externally_b.ll
URL: http://llvm.org/viewvc/llvm-project/llvm/trunk/test/Linker/available_externally_b.ll?rev=124650&view=auto
==============================================================================
--- llvm/trunk/test/Linker/available_externally_b.ll (added)
+++ llvm/trunk/test/Linker/available_externally_b.ll Mon Jan 31 23:33:52 2011
@@ -0,0 +1,4 @@
+; This file is for use with available_externally_a.ll
+; RUN: true
+
+ at foo = hidden unnamed_addr constant i32 0





More information about the llvm-commits mailing list