146 lines
4.7 KiB
LLVM
146 lines
4.7 KiB
LLVM
; NOTE: Assertions have been autogenerated by utils/update_llc_test_checks.py
|
|
; RUN: llc < %s -frame-pointer=all -O0 -mcpu=i486 | FileCheck %s
|
|
;; magic constants are 3.999f and half of 3.999
|
|
; ModuleID = '1489.c'
|
|
target datalayout = "e-p:32:32:32-i1:8:8-i8:8:8-i16:16:16-i32:32:32-i64:32:64-f32:32:32-f64:32:64-v64:64:64-v128:128:128-a0:0:64"
|
|
target triple = "i686-apple-darwin8"
|
|
@.str = internal constant [13 x i8] c"%d %d %d %d\0A\00" ; <[13 x i8]*> [#uses=1]
|
|
|
|
define i32 @quux() nounwind {
|
|
; CHECK-LABEL: quux:
|
|
; CHECK: ## %bb.0: ## %entry
|
|
; CHECK-NEXT: pushl %ebp
|
|
; CHECK-NEXT: movl %esp, %ebp
|
|
; CHECK-NEXT: subl $8, %esp
|
|
; CHECK-NEXT: movl %esp, %eax
|
|
; CHECK-NEXT: movl $1082126238, (%eax) ## imm = 0x407FEF9E
|
|
; CHECK-NEXT: calll _lrintf
|
|
; CHECK-NEXT: cmpl $1, %eax
|
|
; CHECK-NEXT: setl %al
|
|
; CHECK-NEXT: andb $1, %al
|
|
; CHECK-NEXT: movzbl %al, %eax
|
|
; CHECK-NEXT: addl $8, %esp
|
|
; CHECK-NEXT: popl %ebp
|
|
; CHECK-NEXT: retl
|
|
entry:
|
|
%tmp1 = tail call i32 @lrintf( float 0x400FFDF3C0000000 ) ; <i32> [#uses=1]
|
|
%tmp2 = icmp slt i32 %tmp1, 1 ; <i1> [#uses=1]
|
|
%tmp23 = zext i1 %tmp2 to i32 ; <i32> [#uses=1]
|
|
ret i32 %tmp23
|
|
}
|
|
|
|
declare i32 @lrintf(float)
|
|
|
|
define i32 @foo() nounwind {
|
|
; CHECK-LABEL: foo:
|
|
; CHECK: ## %bb.0: ## %entry
|
|
; CHECK-NEXT: pushl %ebp
|
|
; CHECK-NEXT: movl %esp, %ebp
|
|
; CHECK-NEXT: subl $8, %esp
|
|
; CHECK-NEXT: movl %esp, %eax
|
|
; CHECK-NEXT: movl $1074789875, 4(%eax) ## imm = 0x400FFDF3
|
|
; CHECK-NEXT: movl $-1236950581, (%eax) ## imm = 0xB645A1CB
|
|
; CHECK-NEXT: calll _lrint
|
|
; CHECK-NEXT: cmpl $1, %eax
|
|
; CHECK-NEXT: setl %al
|
|
; CHECK-NEXT: andb $1, %al
|
|
; CHECK-NEXT: movzbl %al, %eax
|
|
; CHECK-NEXT: addl $8, %esp
|
|
; CHECK-NEXT: popl %ebp
|
|
; CHECK-NEXT: retl
|
|
entry:
|
|
%tmp1 = tail call i32 @lrint( double 3.999000e+00 ) ; <i32> [#uses=1]
|
|
%tmp2 = icmp slt i32 %tmp1, 1 ; <i1> [#uses=1]
|
|
%tmp23 = zext i1 %tmp2 to i32 ; <i32> [#uses=1]
|
|
ret i32 %tmp23
|
|
}
|
|
|
|
declare i32 @lrint(double)
|
|
|
|
define i32 @bar() nounwind {
|
|
; CHECK-LABEL: bar:
|
|
; CHECK: ## %bb.0: ## %entry
|
|
; CHECK-NEXT: pushl %ebp
|
|
; CHECK-NEXT: movl %esp, %ebp
|
|
; CHECK-NEXT: subl $8, %esp
|
|
; CHECK-NEXT: movl %esp, %eax
|
|
; CHECK-NEXT: movl $1082126238, (%eax) ## imm = 0x407FEF9E
|
|
; CHECK-NEXT: calll _lrintf
|
|
; CHECK-NEXT: cmpl $1, %eax
|
|
; CHECK-NEXT: setl %al
|
|
; CHECK-NEXT: andb $1, %al
|
|
; CHECK-NEXT: movzbl %al, %eax
|
|
; CHECK-NEXT: addl $8, %esp
|
|
; CHECK-NEXT: popl %ebp
|
|
; CHECK-NEXT: retl
|
|
entry:
|
|
%tmp1 = tail call i32 @lrintf( float 0x400FFDF3C0000000 ) ; <i32> [#uses=1]
|
|
%tmp2 = icmp slt i32 %tmp1, 1 ; <i1> [#uses=1]
|
|
%tmp23 = zext i1 %tmp2 to i32 ; <i32> [#uses=1]
|
|
ret i32 %tmp23
|
|
}
|
|
|
|
define i32 @baz() nounwind {
|
|
; CHECK-LABEL: baz:
|
|
; CHECK: ## %bb.0: ## %entry
|
|
; CHECK-NEXT: pushl %ebp
|
|
; CHECK-NEXT: movl %esp, %ebp
|
|
; CHECK-NEXT: subl $8, %esp
|
|
; CHECK-NEXT: movl %esp, %eax
|
|
; CHECK-NEXT: movl $1082126238, (%eax) ## imm = 0x407FEF9E
|
|
; CHECK-NEXT: calll _lrintf
|
|
; CHECK-NEXT: cmpl $1, %eax
|
|
; CHECK-NEXT: setl %al
|
|
; CHECK-NEXT: andb $1, %al
|
|
; CHECK-NEXT: movzbl %al, %eax
|
|
; CHECK-NEXT: addl $8, %esp
|
|
; CHECK-NEXT: popl %ebp
|
|
; CHECK-NEXT: retl
|
|
entry:
|
|
%tmp1 = tail call i32 @lrintf( float 0x400FFDF3C0000000 ) ; <i32> [#uses=1]
|
|
%tmp2 = icmp slt i32 %tmp1, 1 ; <i1> [#uses=1]
|
|
%tmp23 = zext i1 %tmp2 to i32 ; <i32> [#uses=1]
|
|
ret i32 %tmp23
|
|
}
|
|
|
|
define i32 @main() nounwind {
|
|
; CHECK-LABEL: main:
|
|
; CHECK: ## %bb.0: ## %entry
|
|
; CHECK-NEXT: pushl %ebp
|
|
; CHECK-NEXT: movl %esp, %ebp
|
|
; CHECK-NEXT: pushl %edi
|
|
; CHECK-NEXT: pushl %esi
|
|
; CHECK-NEXT: subl $32, %esp
|
|
; CHECK-NEXT: calll _baz
|
|
; CHECK-NEXT: movl %eax, %edi
|
|
; CHECK-NEXT: calll _bar
|
|
; CHECK-NEXT: movl %eax, %esi
|
|
; CHECK-NEXT: calll _foo
|
|
; CHECK-NEXT: movl %eax, {{[-0-9]+}}(%e{{[sb]}}p) ## 4-byte Spill
|
|
; CHECK-NEXT: calll _quux
|
|
; CHECK-NEXT: movl {{[-0-9]+}}(%e{{[sb]}}p), %edx ## 4-byte Reload
|
|
; CHECK-NEXT: movl %eax, %ecx
|
|
; CHECK-NEXT: movl %esp, %eax
|
|
; CHECK-NEXT: movl %edi, 16(%eax)
|
|
; CHECK-NEXT: movl %esi, 12(%eax)
|
|
; CHECK-NEXT: movl %edx, 8(%eax)
|
|
; CHECK-NEXT: movl %ecx, 4(%eax)
|
|
; CHECK-NEXT: movl $_.str, (%eax)
|
|
; CHECK-NEXT: calll _printf
|
|
; CHECK-NEXT: ## implicit-def: $eax
|
|
; CHECK-NEXT: addl $32, %esp
|
|
; CHECK-NEXT: popl %esi
|
|
; CHECK-NEXT: popl %edi
|
|
; CHECK-NEXT: popl %ebp
|
|
; CHECK-NEXT: retl
|
|
entry:
|
|
%tmp = tail call i32 @baz( ) ; <i32> [#uses=1]
|
|
%tmp1 = tail call i32 @bar( ) ; <i32> [#uses=1]
|
|
%tmp2 = tail call i32 @foo( ) ; <i32> [#uses=1]
|
|
%tmp3 = tail call i32 @quux( ) ; <i32> [#uses=1]
|
|
%tmp5 = tail call i32 (i8*, ...) @printf( i8* getelementptr ([13 x i8], [13 x i8]* @.str, i32 0, i32 0), i32 %tmp3, i32 %tmp2, i32 %tmp1, i32 %tmp ) ; <i32> [#uses=0]
|
|
ret i32 undef
|
|
}
|
|
|
|
declare i32 @printf(i8*, ...)
|