From c2e42316272de143a2984835ef090e1af99d1ffa Mon Sep 17 00:00:00 2001 From: Sanjay Patel Date: Wed, 11 Mar 2015 15:12:32 +0000 Subject: [PATCH] Inliner should not add callgraph edges for intrinsic calls (PR22857) The CallGraphNode function "addCalledFunction()" asserts that edges are not to intrinsics. This patch makes sure that the Inliner does not add such an edge to the callgraph. Fix for clang crash by assertion: https://llvm.org/bugs/show_bug.cgi?id=22857 Differential Revision: http://reviews.llvm.org/D8231 git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@231927 91177308-0d34-0410-b5e6-96231b3b80d8 --- lib/Transforms/Utils/InlineFunction.cpp | 9 +++++- .../InstCombine/inline-intrinsic-assert.ll | 30 +++++++++++++++++++ 2 files changed, 38 insertions(+), 1 deletion(-) create mode 100644 test/Transforms/InstCombine/inline-intrinsic-assert.ll diff --git a/lib/Transforms/Utils/InlineFunction.cpp b/lib/Transforms/Utils/InlineFunction.cpp index 76da677d74f..df3e1d4a47d 100644 --- a/lib/Transforms/Utils/InlineFunction.cpp +++ b/lib/Transforms/Utils/InlineFunction.cpp @@ -693,8 +693,15 @@ static void UpdateCallGraphAfterInlining(CallSite CS, // If the call was inlined, but then constant folded, there is no edge to // add. Check for this case. Instruction *NewCall = dyn_cast(VMI->second); - if (!NewCall) continue; + if (!NewCall) + continue; + // We do not treat intrinsic calls like real function calls because we + // expect them to become inline code; do not add an edge for an intrinsic. + CallSite CS = CallSite(NewCall); + if (CS && CS.getCalledFunction() && CS.getCalledFunction()->isIntrinsic()) + continue; + // Remember that this call site got inlined for the client of // InlineFunction. IFI.InlinedCalls.push_back(NewCall); diff --git a/test/Transforms/InstCombine/inline-intrinsic-assert.ll b/test/Transforms/InstCombine/inline-intrinsic-assert.ll new file mode 100644 index 00000000000..af34277563e --- /dev/null +++ b/test/Transforms/InstCombine/inline-intrinsic-assert.ll @@ -0,0 +1,30 @@ +; RUN: opt < %s -inline -instcombine -S | FileCheck %s + +; PR22857: http://llvm.org/bugs/show_bug.cgi?id=22857 +; The inliner should not add an edge to an intrinsic and +; then assert that it did not add an edge to an intrinsic! + +define float @foo(float %f1) #0 { + %call = call float @bar(float %f1) + ret float %call + +; CHECK-LABEL: @foo( +; CHECK-NEXT: call float @llvm.fabs.f32 +; CHECK-NEXT: ret float +} + +define float @bar(float %f1) #0 { + %call = call float @sqr(float %f1) + %call1 = call float @sqrtf(float %call) #0 + ret float %call1 +} + +define float @sqr(float %f) #0 { + %mul = fmul fast float %f, %f + ret float %mul +} + +declare float @sqrtf(float) #0 + +attributes #0 = { "unsafe-fp-math"="true" } + -- 2.34.1