; NOTE: Assertions have been autogenerated by utils/update_llc_test_checks.py
; ModuleID = 'nan.bc'
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-f80:32:32-v64:64:64-v128:128:128-a0:0:64"
target triple = "i686-apple-darwin8"
; RUN: llc < %s -mattr=-sse2,-sse3,-sse | FileCheck %s
; it is not safe to shorten any of these NaNs.
declare x86_stdcallcc void @_D3nan5printFeZv(x86_fp80 %f)
@_D3nan4rvale = global x86_fp80 0xK7FFF8001234000000000 ; <ptr> [#uses=1]
define i32 @main() {
; CHECK-LABEL: main:
; CHECK: ## %bb.0: ## %entry_nan.main
; CHECK-NEXT: subl $28, %esp
; CHECK-NEXT: .cfi_def_cfa_offset 32
; CHECK-NEXT: fldt __D3nan4rvale
; CHECK-NEXT: fstpt (%esp)
; CHECK-NEXT: calll __D3nan5printFeZv
; CHECK-NEXT: subl $16, %esp
; CHECK-NEXT: fldt {{\.?LCPI[0-9]+_[0-9]+}}
; CHECK-NEXT: fstpt (%esp)
; CHECK-NEXT: calll __D3nan5printFeZv
; CHECK-NEXT: subl $16, %esp
; CHECK-NEXT: fldt {{\.?LCPI[0-9]+_[0-9]+}}
; CHECK-NEXT: fstpt (%esp)
; CHECK-NEXT: calll __D3nan5printFeZv
; CHECK-NEXT: subl $16, %esp
; CHECK-NEXT: xorl %eax, %eax
; CHECK-NEXT: addl $28, %esp
; CHECK-NEXT: retl
entry_nan.main:
%tmp = load x86_fp80, ptr @_D3nan4rvale ; <x86_fp80> [#uses=1]
call x86_stdcallcc void @_D3nan5printFeZv(x86_fp80 %tmp)
call x86_stdcallcc void @_D3nan5printFeZv(x86_fp80 0xK7FFF8001234000000000)
call x86_stdcallcc void @_D3nan5printFeZv(x86_fp80 0xK7FFFC001234000000400)
ret i32 0
}