Fix PR2411, where ip constant prop would propagate the
authorChris Lattner <sabre@nondot.org>
Mon, 9 Jun 2008 07:58:07 +0000 (07:58 +0000)
committerChris Lattner <sabre@nondot.org>
Mon, 9 Jun 2008 07:58:07 +0000 (07:58 +0000)
result of a weak function.

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

lib/Transforms/IPO/IPConstantPropagation.cpp
test/Transforms/IPConstantProp/2008-06-09-WeakProp.ll [new file with mode: 0644]

index 792fa980a60b5ff29d767cf9bc5032cedb0faa4a..4ebdaf3fb2b40ee12b938cc0953b8d2aab113976 100644 (file)
@@ -147,6 +147,11 @@ bool IPCP::PropagateConstantReturn(Function &F) {
   if (F.getReturnType() == Type::VoidTy)
     return false; // No return value.
 
+  // If this function could be overridden later in the link stage, we can't
+  // propagate information about its results into callers.
+  if (F.hasLinkOnceLinkage() || F.hasWeakLinkage())
+    return false;
+  
   // Check to see if this function returns a constant.
   SmallVector<Value *,4> RetVals;
   const StructType *STy = dyn_cast<StructType>(F.getReturnType());
diff --git a/test/Transforms/IPConstantProp/2008-06-09-WeakProp.ll b/test/Transforms/IPConstantProp/2008-06-09-WeakProp.ll
new file mode 100644 (file)
index 0000000..fc7e3bb
--- /dev/null
@@ -0,0 +1,15 @@
+; RUN: llvm-as < %s | opt -ipconstprop | llvm-dis | grep {ret i32 %r}
+; Should not propagate the result of a weak function.
+; PR2411
+
+define weak i32 @foo() nounwind  {
+entry:
+        ret i32 1
+}
+
+define i32 @main() nounwind  {
+entry:
+        %r = call i32 @foo( ) nounwind
+        ret i32 %r
+}
+