[clang][modules] Don't prevent translation of FW_Private includes when explicitly...
[llvm-project.git] / llvm / test / Transforms / SLPVectorizer / X86 / root-trunc-extract-reuse.ll
blob87dd2cfd2004430697994c3b29f30b663c442c97
1 ; NOTE: Assertions have been autogenerated by utils/update_test_checks.py
2 ; RUN: opt -passes=slp-vectorizer -S -slp-threshold=-100 -mtriple=x86_64 < %s | FileCheck %s
4 define i1 @test() {
5 ; CHECK-LABEL: @test(
6 ; CHECK-NEXT:  entry:
7 ; CHECK-NEXT:    br i1 false, label [[THEN:%.*]], label [[ELSE:%.*]]
8 ; CHECK:       then:
9 ; CHECK-NEXT:    br label [[ELSE]]
10 ; CHECK:       else:
11 ; CHECK-NEXT:    [[TMP0:%.*]] = phi <2 x i32> [ zeroinitializer, [[THEN]] ], [ zeroinitializer, [[ENTRY:%.*]] ]
12 ; CHECK-NEXT:    [[TMP1:%.*]] = trunc <2 x i32> [[TMP0]] to <2 x i8>
13 ; CHECK-NEXT:    [[TMP2:%.*]] = extractelement <2 x i8> [[TMP1]], i32 0
14 ; CHECK-NEXT:    [[TMP3:%.*]] = zext i8 [[TMP2]] to i32
15 ; CHECK-NEXT:    [[BF_CAST162:%.*]] = and i32 [[TMP3]], 0
16 ; CHECK-NEXT:    [[TMP4:%.*]] = shufflevector <2 x i32> zeroinitializer, <2 x i32> [[TMP0]], <2 x i32> <i32 3, i32 1>
17 ; CHECK-NEXT:    [[T13:%.*]] = and <2 x i32> [[TMP4]], zeroinitializer
18 ; CHECK-NEXT:    br label [[ELSE1:%.*]]
19 ; CHECK:       else1:
20 ; CHECK-NEXT:    [[TMP5:%.*]] = shufflevector <2 x i32> [[T13]], <2 x i32> poison, <2 x i32> <i32 poison, i32 0>
21 ; CHECK-NEXT:    [[TMP6:%.*]] = insertelement <2 x i32> [[TMP5]], i32 [[BF_CAST162]], i32 0
22 ; CHECK-NEXT:    [[TMP7:%.*]] = icmp ugt <2 x i32> [[TMP6]], zeroinitializer
23 ; CHECK-NEXT:    [[TMP8:%.*]] = extractelement <2 x i1> [[TMP7]], i32 1
24 ; CHECK-NEXT:    ret i1 [[TMP8]]
26 entry:
27   br i1 false, label %then, label %else
29 then:
30   br label %else
32 else:
33   %bf.load.off43 = phi i32 [ 0, %then ], [ 0, %entry ]
34   %bf.load.off44 = phi i32 [ 0, %then ], [ 0, %entry ]
35   %bf.cast162 = and i32 %bf.load.off43, 0
36   %t12 = insertelement <2 x i32> zeroinitializer, i32 %bf.load.off44, i64 0
37   %t13 = and <2 x i32> %t12, zeroinitializer
38   br label %else1
40 else1:
41   %cmp40 = icmp ugt i32 %bf.cast162, 0
42   %t20 = extractelement <2 x i32> %t13, i64 0
43   %cmp50 = icmp ugt i32 %t20, 0
44   ret i1 %cmp50