Emit extern_weak when needed.
 - PR3629.


git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@65203 91177308-0d34-0410-b5e6-96231b3b80d8
diff --git a/lib/CodeGen/CodeGenModule.cpp b/lib/CodeGen/CodeGenModule.cpp
index 7432b01..ccba324 100644
--- a/lib/CodeGen/CodeGenModule.cpp
+++ b/lib/CodeGen/CodeGenModule.cpp
@@ -264,7 +264,8 @@
         } else
           GV->setLinkage(llvm::Function::DLLImportLinkage);
       }
-    }
+    } else if (D->getAttr<WeakAttr>())
+      GV->setLinkage(llvm::Function::ExternalWeakLinkage);
   } else {
     if (IsInternal) {
       GV->setLinkage(llvm::Function::InternalLinkage);
@@ -287,11 +288,10 @@
     setGlobalVisibility(GV, attr->getVisibility());
   // FIXME: else handle -fvisibility
 
-  if (const AsmLabelAttr *ALA = D->getAttr<AsmLabelAttr>()) {
-    // Prefaced with special LLVM marker to indicate that the name
-    // should not be munged.
+  // Prefaced with special LLVM marker to indicate that the name
+  // should not be munged.
+  if (const AsmLabelAttr *ALA = D->getAttr<AsmLabelAttr>())
     GV->setName("\01" + ALA->getLabel());
-  }
 
   if (const SectionAttr *SA = D->getAttr<SectionAttr>())
     GV->setSection(SA->getName());
@@ -598,8 +598,13 @@
 
     GV->setConstant(D->getType().isConstant(Context));
 
+    // FIXME: Merge with other attribute handling code.
+
     if (D->getStorageClass() == VarDecl::PrivateExtern)
       setGlobalVisibility(GV, VisibilityAttr::HiddenVisibility);
+
+    if (D->getAttr<WeakAttr>())
+      GV->setLinkage(llvm::GlobalValue::ExternalWeakLinkage);
   }
   
   // Make sure the result is of the correct type.