Run DCE after a LoopFlatten test to reduce spurious output [nfc]
[llvm-project.git] / llvm / test / CodeGen / PowerPC / ppc32-i64-to-float-conv.ll
blobab4753b51ca81cd06903129bf4c896725ac9919e
1 ; RUN: llc -verify-machineinstrs < %s -mcpu=pwr4 -mattr=-altivec \
2 ; RUN: -mtriple=powerpc-ibm-aix-xcoff 2>&1 | FileCheck %s
4 ; RUN: llc -verify-machineinstrs < %s -mcpu=pwr4 -mattr=-altivec \
5 ; RUN: -mtriple=powerpc-unknown-linux-gnu 2>&1 | FileCheck %s
7 ; When we convert an `i64` to `f32` on 32-bit PPC target, a `setcc` will be
8 ; generated. And this testcase verifies that the operand expansion of `setcc`
9 ; will not crash.
11 %struct.A = type { float }
13 @ll = external local_unnamed_addr global i64
14 @a = external local_unnamed_addr global %struct.A
16 define void @foo() local_unnamed_addr {
17 entry:
18   %0 = load i64, ptr @ll
19   %conv = sitofp i64 %0 to float
20   store float %conv, ptr @a
21   ret void
24 ; CHECK-NOT: Unexpected setcc expansion!