diff options
author | Reid Kleckner <rnk@google.com> | 2018-04-02 21:23:16 +0000 |
---|---|---|
committer | Reid Kleckner <rnk@google.com> | 2018-04-02 21:23:16 +0000 |
commit | a9e9918ee4e23a4d971cca8b970e378eb69cc049 (patch) | |
tree | f8ac9ac70926966eddfcabdd545306b0c97eae68 /llvm/lib/Transforms/Utils/InlineFunction.cpp | |
parent | 3e7d6fc2c6e0e3f229c5060a985b17015738da07 (diff) | |
download | llvm-a9e9918ee4e23a4d971cca8b970e378eb69cc049.zip llvm-a9e9918ee4e23a4d971cca8b970e378eb69cc049.tar.gz llvm-a9e9918ee4e23a4d971cca8b970e378eb69cc049.tar.bz2 |
Treat inlining a notail call as a regular, non-tail call
Otherwise, we end up inlining a musttail call into a non-tail position,
which breaks verifier invariants.
Fixes PR31014
llvm-svn: 329015
Diffstat (limited to 'llvm/lib/Transforms/Utils/InlineFunction.cpp')
-rw-r--r-- | llvm/lib/Transforms/Utils/InlineFunction.cpp | 6 |
1 files changed, 6 insertions, 0 deletions
diff --git a/llvm/lib/Transforms/Utils/InlineFunction.cpp b/llvm/lib/Transforms/Utils/InlineFunction.cpp index a90628f..761c368 100644 --- a/llvm/lib/Transforms/Utils/InlineFunction.cpp +++ b/llvm/lib/Transforms/Utils/InlineFunction.cpp @@ -1826,6 +1826,10 @@ bool llvm::InlineFunction(CallSite CS, InlineFunctionInfo &IFI, if (CallInst *CI = dyn_cast<CallInst>(TheCall)) CallSiteTailKind = CI->getTailCallKind(); + // For inlining purposes, the "notail" marker is the same as no marker. + if (CallSiteTailKind == CallInst::TCK_NoTail) + CallSiteTailKind = CallInst::TCK_None; + for (Function::iterator BB = FirstNewBlock, E = Caller->end(); BB != E; ++BB) { for (auto II = BB->begin(); II != BB->end();) { @@ -1885,6 +1889,8 @@ bool llvm::InlineFunction(CallSite CS, InlineFunctionInfo &IFI, // f -> musttail g -> tail f ==> f -> tail f // f -> g -> musttail f ==> f -> f // f -> g -> tail f ==> f -> f + // + // Inlined notail calls should remain notail calls. CallInst::TailCallKind ChildTCK = CI->getTailCallKind(); if (ChildTCK != CallInst::TCK_NoTail) ChildTCK = std::min(CallSiteTailKind, ChildTCK); |