2013-02-14 03:45:08 +00:00
|
|
|
; RUN: llc < %s -tailcallopt -mtriple=i686-pc-linux-gnu -relocation-model=pic | FileCheck %s
|
2007-10-11 19:40:01 +00:00
|
|
|
|
Disable x86 tail call optimizations that jump through GOT
For x86 targets, do not do sibling call optimization when materializing
the callee's address would require a GOT relocation. We can still do
tail calls to internal functions, hidden functions, and protected
functions, because they do not require this kind of relocation. It is
still possible to get GOT relocations when the user explicitly asks for
it with musttail or -tailcallopt, both of which are supposed to
guarantee TCO.
Based on a patch by Chih-hung Hsieh.
Reviewers: srhines, timmurray, danalbert, enh, void, nadav, rnk
Subscribers: joerg, davidxl, llvm-commits
Differential Revision: http://reviews.llvm.org/D9799
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@238487 91177308-0d34-0410-b5e6-96231b3b80d8
2015-05-28 20:44:28 +00:00
|
|
|
; This test uses guaranteed TCO so these will be tail calls, despite the early
|
|
|
|
; binding issues.
|
|
|
|
|
2007-10-11 19:40:01 +00:00
|
|
|
define protected fastcc i32 @tailcallee(i32 %a1, i32 %a2, i32 %a3, i32 %a4) {
|
|
|
|
entry:
|
|
|
|
ret i32 %a3
|
|
|
|
}
|
|
|
|
|
|
|
|
define fastcc i32 @tailcaller(i32 %in1, i32 %in2) {
|
|
|
|
entry:
|
|
|
|
%tmp11 = tail call fastcc i32 @tailcallee( i32 %in1, i32 %in2, i32 %in1, i32 %in2 ) ; <i32> [#uses=1]
|
|
|
|
ret i32 %tmp11
|
2013-02-14 03:45:08 +00:00
|
|
|
; CHECK: jmp tailcallee
|
2007-10-11 19:40:01 +00:00
|
|
|
}
|