Run DCE after a LoopFlatten test to reduce spurious output [nfc]
[llvm-project.git] / llvm / test / CodeGen / PowerPC / sms-phi.ll
blob53a3f13c0597d72df06097a2f006297212b66d71
1 ; REQUIRES: asserts
2 ; RUN: llc < %s -mtriple=powerpc64le-unknown-linux-gnu -verify-machineinstrs\
3 ; RUN:       -mcpu=pwr9 --ppc-enable-pipeliner -debug-only=pipeliner 2>&1 \
4 ; RUN:       >/dev/null | FileCheck %s
5 define dso_local void @sha512() #0 {
6 ;CHECK: prolog:
7 ;CHECK:        %{{[0-9]+}}:g8rc = ADD8 %{{[0-9]+}}:g8rc, %{{[0-9]+}}:g8rc
8 ;CHECK: epilog:
9 ;CHECK:        %{{[0-9]+}}:g8rc_and_g8rc_nox0 = PHI %{{[0-9]+}}:g8rc_and_g8rc_nox0, %bb.3, %{{[0-9]+}}:g8rc_and_g8rc_nox0, %bb.4
10 ;CHECK-NEXT:   %{{[0-9]+}}:g8rc = PHI %{{[0-9]+}}:g8rc, %bb.3, %{{[0-9]+}}:g8rc, %bb.4
11 ;CHECK-NEXT:   %{{[0-9]+}}:g8rc = PHI %{{[0-9]+}}:g8rc, %bb.3, %{{[0-9]+}}:g8rc, %bb.4
12   br label %1
14 1:                                                ; preds = %1, %0
15   %2 = phi i64 [ 0, %0 ], [ %12, %1 ]
16   %3 = phi i64 [ undef, %0 ], [ %11, %1 ]
17   %4 = phi i64 [ undef, %0 ], [ %3, %1 ]
18   %5 = getelementptr inbounds [80 x i64], ptr null, i64 0, i64 %2
19   %6 = load i64, ptr %5, align 8
20   %7 = add i64 0, %6
21   %8 = and i64 %3, %4
22   %9 = or i64 0, %8
23   %10 = add i64 0, %9
24   %11 = add i64 %10, %7
25   %12 = add nuw nsw i64 %2, 1
26   %13 = icmp eq i64 %12, 80
27   br i1 %13, label %14, label %1
29 14:                                               ; preds = %1
30   %15 = add i64 %4, 0
31   store i64 %15, ptr undef, align 8
32   ret void