diff options
author | Bill Wendling <isanbard@gmail.com> | 2013-12-15 20:55:09 +0000 |
---|---|---|
committer | Bill Wendling <isanbard@gmail.com> | 2013-12-15 20:55:09 +0000 |
commit | b525888b1f988f6a993054285a3a43a24c26fbca (patch) | |
tree | b198da8738db8bc8cd51723ff8cccb431f409c0f /lib | |
parent | e6725194d1045eeb5a9371316120b9b027f3d289 (diff) | |
download | external_llvm-b525888b1f988f6a993054285a3a43a24c26fbca.zip external_llvm-b525888b1f988f6a993054285a3a43a24c26fbca.tar.gz external_llvm-b525888b1f988f6a993054285a3a43a24c26fbca.tar.bz2 |
Merging r197216:
------------------------------------------------------------------------
r197216 | chandlerc | 2013-12-13 00:00:01 -0800 (Fri, 13 Dec 2013) | 9 lines
[inliner] Fix PR18206 by preventing inlining functions that call setjmp
through an invoke instruction.
The original patch for this was written by Mark Seaborn, but I've
reworked his test case into the existing returns_twice test case and
implemented the fix by the prior refactoring to actually run the cost
analysis over invoke instructions, and then here fixing our detection of
the returns_twice attribute to work for both calls and invokes. We never
noticed because we never saw an invoke. =[
------------------------------------------------------------------------
git-svn-id: https://llvm.org/svn/llvm-project/llvm/branches/release_34@197352 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib')
-rw-r--r-- | lib/Analysis/IPA/InlineCost.cpp | 2 |
1 files changed, 1 insertions, 1 deletions
diff --git a/lib/Analysis/IPA/InlineCost.cpp b/lib/Analysis/IPA/InlineCost.cpp index 5e6d72d..3bc796e 100644 --- a/lib/Analysis/IPA/InlineCost.cpp +++ b/lib/Analysis/IPA/InlineCost.cpp @@ -713,7 +713,7 @@ bool CallAnalyzer::simplifyCallSite(Function *F, CallSite CS) { } bool CallAnalyzer::visitCallSite(CallSite CS) { - if (CS.isCall() && cast<CallInst>(CS.getInstruction())->canReturnTwice() && + if (CS.hasFnAttr(Attribute::ReturnsTwice) && !F.getAttributes().hasAttribute(AttributeSet::FunctionIndex, Attribute::ReturnsTwice)) { // This aborts the entire analysis. |