[LLVM][IR] Use splat syntax when printing ConstantExpr based splats. (#116856)
[llvm-project.git] / llvm / test / Transforms / SLPVectorizer / X86 / reduction-value-in-tree.ll
blob6d6dd502415e5d7fb5067d860004ca120d28cb5e
1 ; NOTE: Assertions have been autogenerated by utils/update_test_checks.py
2 ; RUN: opt -S -passes=slp-vectorizer -mtriple=x86_64-unknown-linux < %s | FileCheck %s
3 define void @test() {
4 ; CHECK-LABEL: @test(
5 ; CHECK-NEXT:  bb:
6 ; CHECK-NEXT:    br i1 false, label [[PH:%.*]], label [[EXIT:%.*]]
7 ; CHECK:       ph:
8 ; CHECK-NEXT:    [[TMP0:%.*]] = call i8 @llvm.vector.reduce.and.v8i8(<8 x i8> zeroinitializer)
9 ; CHECK-NEXT:    [[OP_RDX:%.*]] = and i8 0, [[TMP0]]
10 ; CHECK-NEXT:    [[OP_RDX1:%.*]] = and i8 [[OP_RDX]], 0
11 ; CHECK-NEXT:    br label [[EXIT]]
12 ; CHECK:       exit:
13 ; CHECK-NEXT:    [[PHI:%.*]] = phi i8 [ [[OP_RDX1]], [[PH]] ], [ 0, [[BB:%.*]] ]
14 ; CHECK-NEXT:    ret void
16 bb:
17   br i1 false, label %ph, label %exit
19 ph:
20   %add1 = add i8 0, 0
21   %add2 = add i8 %add1, 0
22   %add3 = add i8 %add1, 0
23   %add4 = add i8 %add1, 0
24   %add5 = add i8 %add1, 0
25   %add6 = add i8 %add1, 0
26   %add7 = add i8 %add1, 0
27   %add8 = add i8 %add1, 0
28   %add9 = add i8 0, 0
29   %add10 = add i8 0, %add9
30   %0 = and i8 %add10, %add3
31   %1 = and i8 %0, %add2
32   %2 = and i8 %1, %add4
33   %3 = and i8 %2, 0
34   %4 = and i8 %3, %add5
35   %5 = and i8 %4, %add6
36   %6 = and i8 %5, 0
37   %7 = and i8 %6, 0
38   %8 = and i8 %7, 0
39   %9 = and i8 %8, 0
40   %10 = and i8 %9, 0
41   %11 = and i8 %10, 0
42   %12 = and i8 %11, 0
43   %13 = and i8 %12, %add7
44   %14 = and i8 %13, %add8
45   %15 = and i8 %14, 0
46   %16 = and i8 %15, 0
47   %17 = and i8 %16, 0
48   %18 = and i8 %17, 0
49   %and = and i8 %18, %add1
50   br label %exit
52 exit:
53   %phi = phi i8 [ %and, %ph ], [ 0, %bb ]
54   ret void