llvm/llvm/test/CodeGen/X86/2008-10-06-x87ld-nan-2.ll

; 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
}