[ARM] Adjust how NEON shifts are lowered
[llvm-core.git] / test / Transforms / SLPVectorizer / X86 / crash_gep.ll
blobeca21e7d3a1a01c5b931c8f2eb6f61bb058ca108
1 ; NOTE: Assertions have been autogenerated by utils/update_test_checks.py
2 ; RUN: opt < %s -basicaa -slp-vectorizer -dce -S -mtriple=x86_64-unknown-linux-gnu | FileCheck %s
4 target datalayout = "e-m:e-i64:64-f80:128-n8:16:32:64-S128"
5 target triple = "x86_64-unknown-linux-gnu"
7 @a = common global i64* null, align 8
9 ; Function Attrs: nounwind uwtable
10 define i32 @fn1() {
11 ; CHECK-LABEL: @fn1(
12 ; CHECK-NEXT:  entry:
13 ; CHECK-NEXT:    [[TMP0:%.*]] = load i64*, i64** @a, align 8
14 ; CHECK-NEXT:    [[ADD_PTR:%.*]] = getelementptr inbounds i64, i64* [[TMP0]], i64 1
15 ; CHECK-NEXT:    [[TMP1:%.*]] = ptrtoint i64* [[ADD_PTR]] to i64
16 ; CHECK-NEXT:    [[ARRAYIDX:%.*]] = getelementptr inbounds i64, i64* [[TMP0]], i64 2
17 ; CHECK-NEXT:    store i64 [[TMP1]], i64* [[ARRAYIDX]], align 8
18 ; CHECK-NEXT:    [[TMP2:%.*]] = ptrtoint i64* [[ARRAYIDX]] to i64
19 ; CHECK-NEXT:    store i64 [[TMP2]], i64* [[ADD_PTR]], align 8
20 ; CHECK-NEXT:    ret i32 undef
22 entry:
23   %0 = load i64*, i64** @a, align 8
24   %add.ptr = getelementptr inbounds i64, i64* %0, i64 1
25   %1 = ptrtoint i64* %add.ptr to i64
26   %arrayidx = getelementptr inbounds i64, i64* %0, i64 2
27   store i64 %1, i64* %arrayidx, align 8
28   %2 = ptrtoint i64* %arrayidx to i64
29   store i64 %2, i64* %add.ptr, align 8
30   ret i32 undef