Run DCE after a LoopFlatten test to reduce spurious output [nfc]
[llvm-project.git] / llvm / test / Bitcode / fcmp-fast.ll
blob79e023318fab79a49d6ec0ac8e2ab60c09ad0820
1 ; RUN: llvm-as < %s | llvm-dis > %t0
2 ; RUN: opt -S < %s > %t1
3 ; RUN: diff %t0 %t1
4 ; RUN: FileCheck < %t1 %s
6 ; Make sure fast math flags on fcmp instructions are serialized/deserialized properly.
8 define i1 @foo(float %a, float %b, double %c, double %d) {
9   ; CHECK:   %plain = fcmp ueq float %a, %b
10   %plain = fcmp ueq float %a, %b
11   ; CHECK:   %fast = fcmp fast olt float %a, %b
12   %fast = fcmp fast olt float %a, %b
13   ; CHECK:   %nsz = fcmp nsz uge float %a, %b
14   %nsz = fcmp nsz uge float %a, %b
15   ; CHECK:   %nnan = fcmp nnan nsz oge double %c, %d
16   %nnan = fcmp nnan nsz oge double %c, %d
18   %dce1 = or i1 %plain, %fast
19   %dce2 = or i1 %dce1, %nsz
20   %dce3 = or i1 %dce2, %nnan
22   ret i1 %dce3