[ARM] Adjust how NEON shifts are lowered
[llvm-core.git] / test / Transforms / SLPVectorizer / X86 / gep_mismatch.ll
blobf9b9995066a22e26de4b62169bf24866e0f5855c
1 ; NOTE: Assertions have been autogenerated by utils/update_test_checks.py
2 ; RUN: opt < %s -S -slp-vectorizer | FileCheck %s
4 ; This code has GEPs with different index types, which should not
5 ; matter for the SLPVectorizer.
7 target triple = "x86_64--linux"
9 define void @foo() {
10 ; CHECK-LABEL: @foo(
11 ; CHECK-NEXT:  entry:
12 ; CHECK-NEXT:    br label [[BB1:%.*]]
13 ; CHECK:       bb1:
14 ; CHECK-NEXT:    [[LS1_PH:%.*]] = phi float* [ [[_TMP1:%.*]], [[BB1]] ], [ undef, [[ENTRY:%.*]] ]
15 ; CHECK-NEXT:    [[LS2_PH:%.*]] = phi float* [ [[_TMP2:%.*]], [[BB1]] ], [ undef, [[ENTRY]] ]
16 ; CHECK-NEXT:    store float undef, float* [[LS1_PH]]
17 ; CHECK-NEXT:    [[_TMP1]] = getelementptr float, float* [[LS1_PH]], i32 1
18 ; CHECK-NEXT:    [[_TMP2]] = getelementptr float, float* [[LS2_PH]], i64 4
19 ; CHECK-NEXT:    br i1 false, label [[BB1]], label [[BB2:%.*]]
20 ; CHECK:       bb2:
21 ; CHECK-NEXT:    ret void
23 entry:
24   br label %bb1
26 bb1:
27   %ls1.ph = phi float* [ %_tmp1, %bb1 ], [ undef, %entry ]
28   %ls2.ph = phi float* [ %_tmp2, %bb1 ], [ undef, %entry ]
29   store float undef, float* %ls1.ph
30   %_tmp1 = getelementptr float, float* %ls1.ph, i32 1
31   %_tmp2 = getelementptr float, float* %ls2.ph, i64 4
32   br i1 false, label %bb1, label %bb2
34 bb2:
35   ret void