mirror of
https://github.com/RPCS3/llvm.git
synced 2024-12-31 17:04:28 +00:00
c68dda815e
of zero-initialized sections, virtual sections and common symbols and preventing the loading of sections which are not required for execution such as debug information. Patch by Andy Kaylor! git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@154610 91177308-0d34-0410-b5e6-96231b3b80d8
23 lines
681 B
LLVM
23 lines
681 B
LLVM
; PR672
|
|
; RUN: %lli %s
|
|
; XFAIL: arm
|
|
|
|
define i32 @main() {
|
|
%f = bitcast i32 (i32, i32*, i32)* @check_tail to i32* ; <i32*> [#uses=1]
|
|
%res = tail call fastcc i32 @check_tail( i32 10, i32* %f, i32 10 ) ; <i32> [#uses=1]
|
|
ret i32 %res
|
|
}
|
|
|
|
define fastcc i32 @check_tail(i32 %x, i32* %f, i32 %g) {
|
|
%tmp1 = icmp sgt i32 %x, 0 ; <i1> [#uses=1]
|
|
br i1 %tmp1, label %if-then, label %if-else
|
|
if-then: ; preds = %0
|
|
%fun_ptr = bitcast i32* %f to i32 (i32, i32*, i32)* ; <i32 (i32, i32*, i32)*> [#uses=1]
|
|
%arg1 = add i32 %x, -1 ; <i32> [#uses=1]
|
|
%res = tail call fastcc i32 %fun_ptr( i32 %arg1, i32* %f, i32 %g ) ; <i32> [#uses=1]
|
|
ret i32 %res
|
|
if-else: ; preds = %0
|
|
ret i32 %x
|
|
}
|
|
|