summaryrefslogtreecommitdiff
path: root/llvm/test/Transforms/SLPVectorizer/AArch64/buildvector-vectorize.ll
blob: 674ebf59d2e857fb6a3d2490d41f3f03d8c848c2 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
; NOTE: Assertions have been autogenerated by utils/update_test_checks.py
; RUN: opt -passes=slp-vectorizer -S -mtriple=aarch64 < %s | FileCheck %s

define void @test(ptr %p) {
; CHECK-LABEL: @test(
; CHECK-NEXT:  entry:
; CHECK-NEXT:    [[INC:%.*]] = getelementptr inbounds i16, ptr [[P:%.*]], i64 1
; CHECK-NEXT:    [[TMP0:%.*]] = load i16, ptr [[INC]], align 4
; CHECK-NEXT:    [[TMP1:%.*]] = load i16, ptr [[P]], align 2
; CHECK-NEXT:    [[TMP2:%.*]] = insertelement <8 x i16> zeroinitializer, i16 [[TMP0]], i32 5
; CHECK-NEXT:    [[TMP3:%.*]] = insertelement <8 x i16> [[TMP2]], i16 [[TMP1]], i32 7
; CHECK-NEXT:    ret void
;
entry:
  %inc = getelementptr inbounds i16, ptr %p, i64 1
  %0 = load i16, ptr %inc, align 4
  %1 = load i16, ptr %p, align 2
  %2 = insertelement <8 x i16> zeroinitializer, i16 %0, i32 5
  %3 = insertelement <8 x i16> %2, i16 %1, i32 7
  ret void
}