Run DCE after a LoopFlatten test to reduce spurious output [nfc]
[llvm-project.git] / llvm / test / CodeGen / X86 / 2008-10-06-x87ld-nan-2.ll
blobaa54767fdedee0f7672f6307738846e476202007
1 ; NOTE: Assertions have been autogenerated by utils/update_llc_test_checks.py
2 ; ModuleID = 'nan.bc'
3 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"
4 target triple = "i686-apple-darwin8"
5 ; RUN: llc < %s -mattr=-sse2,-sse3,-sse | FileCheck %s
6 ; it is not safe to shorten any of these NaNs.
8 declare x86_stdcallcc void @_D3nan5printFeZv(x86_fp80 %f)
10 @_D3nan4rvale = global x86_fp80 0xK7FFF8001234000000000   ; <ptr> [#uses=1]
12 define i32 @main() {
13 ; CHECK-LABEL: main:
14 ; CHECK:       ## %bb.0: ## %entry_nan.main
15 ; CHECK-NEXT:    subl $28, %esp
16 ; CHECK-NEXT:    .cfi_def_cfa_offset 32
17 ; CHECK-NEXT:    fldt __D3nan4rvale
18 ; CHECK-NEXT:    fstpt (%esp)
19 ; CHECK-NEXT:    calll __D3nan5printFeZv
20 ; CHECK-NEXT:    subl $16, %esp
21 ; CHECK-NEXT:    fldt {{\.?LCPI[0-9]+_[0-9]+}}
22 ; CHECK-NEXT:    fstpt (%esp)
23 ; CHECK-NEXT:    calll __D3nan5printFeZv
24 ; CHECK-NEXT:    subl $16, %esp
25 ; CHECK-NEXT:    fldt {{\.?LCPI[0-9]+_[0-9]+}}
26 ; CHECK-NEXT:    fstpt (%esp)
27 ; CHECK-NEXT:    calll __D3nan5printFeZv
28 ; CHECK-NEXT:    subl $16, %esp
29 ; CHECK-NEXT:    xorl %eax, %eax
30 ; CHECK-NEXT:    addl $28, %esp
31 ; CHECK-NEXT:    retl
32 entry_nan.main:
33   %tmp = load x86_fp80, ptr @_D3nan4rvale   ; <x86_fp80> [#uses=1]
34   call x86_stdcallcc void @_D3nan5printFeZv(x86_fp80 %tmp)
35   call x86_stdcallcc void @_D3nan5printFeZv(x86_fp80 0xK7FFF8001234000000000)
36   call x86_stdcallcc void @_D3nan5printFeZv(x86_fp80 0xK7FFFC001234000000400)
37   ret i32 0