diff options
| author | Chris Lattner <sabre@nondot.org> | 2008-06-09 07:58:07 +0000 |
|---|---|---|
| committer | Chris Lattner <sabre@nondot.org> | 2008-06-09 07:58:07 +0000 |
| commit | dbd595f22dcae94306df84f70e9a22614034dac4 (patch) | |
| tree | 3803d3250422310ad8e32220fd6c98b855c03d78 /llvm/lib/Transforms | |
| parent | 54a6cbf12af79068f9f0045d6a738d44e8598c25 (diff) | |
| download | bcm5719-llvm-dbd595f22dcae94306df84f70e9a22614034dac4.tar.gz bcm5719-llvm-dbd595f22dcae94306df84f70e9a22614034dac4.zip | |
Fix PR2411, where ip constant prop would propagate the
result of a weak function.
llvm-svn: 52137
Diffstat (limited to 'llvm/lib/Transforms')
| -rw-r--r-- | llvm/lib/Transforms/IPO/IPConstantPropagation.cpp | 5 |
1 files changed, 5 insertions, 0 deletions
diff --git a/llvm/lib/Transforms/IPO/IPConstantPropagation.cpp b/llvm/lib/Transforms/IPO/IPConstantPropagation.cpp index 792fa980a60..4ebdaf3fb2b 100644 --- a/llvm/lib/Transforms/IPO/IPConstantPropagation.cpp +++ b/llvm/lib/Transforms/IPO/IPConstantPropagation.cpp @@ -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()); |

