mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-01-27 14:34:58 +00:00
Prevent tailcallelim from breaking "recursive" calls to builtins.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@41804 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
b0869ed44d
commit
8d9455d4e4
@ -302,6 +302,15 @@ bool TailCallElim::ProcessReturningBlock(ReturnInst *Ret, BasicBlock *&OldEntry,
|
||||
|
||||
if (&BB->front() == Ret) // Make sure there is something before the ret...
|
||||
return false;
|
||||
|
||||
// If the return is in the entry block, then making this transformation would
|
||||
// turn infinite recursion into an infinite loop. This transformation is ok
|
||||
// in theory, but breaks some code like:
|
||||
// double fabs(double f) { return __builtin_fabs(f); } // a 'fabs' call
|
||||
// disable this xform in this case, because the code generator will lower the
|
||||
// call to fabs into inline code.
|
||||
if (BB == &F->getEntryBlock())
|
||||
return false;
|
||||
|
||||
// Scan backwards from the return, checking to see if there is a tail call in
|
||||
// this block. If so, set CI to it.
|
||||
|
10
test/Transforms/TailCallElim/inf-recursion.ll
Normal file
10
test/Transforms/TailCallElim/inf-recursion.ll
Normal file
@ -0,0 +1,10 @@
|
||||
; RUN: llvm-as < %s | opt -tailcallelim | grep call
|
||||
; Don't turn this into an infinite loop, this is probably the implementation
|
||||
; of fabs and we expect the codegen to lower fabs.
|
||||
|
||||
define double @fabs(double %f) {
|
||||
entry:
|
||||
%tmp2 = call double @fabs( double %f ) ; <double> [#uses=1]
|
||||
ret double %tmp2
|
||||
}
|
||||
|
Loading…
x
Reference in New Issue
Block a user