1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44
|
; NOTE: Assertions have been autogenerated by utils/update_test_checks.py UTC_ARGS: --version 5
; RUN: opt -S --passes=slp-vectorizer -mtriple=riscv64-unknown-linux -mattr=+v -pass-remarks-output=%t -mcpu=sifive-p670 < %s | FileCheck %s
; RUN: FileCheck %s --check-prefix YAML --input-file=%t
; YAML-LABEL: --- !Passed
; YAML-NEXT: Pass: slp-vectorizer
; YAML-NEXT: Name: StoresVectorized
; YAML-NEXT: Function: test
; YAML-NEXT: Args:
; YAML-NEXT: - String: 'Stores SLP vectorized with cost '
; YAML-NEXT: - Cost: '-2'
; YAML-NEXT: - String: ' and with tree size '
; YAML-NEXT: - TreeSize: '2'
define void @test(ptr %h) {
; CHECK-LABEL: define void @test(
; CHECK-SAME: ptr [[H:%.*]]) #[[ATTR0:[0-9]+]] {
; CHECK-NEXT: [[ENTRY:.*:]]
; CHECK-NEXT: [[DCT2X211:%.*]] = alloca [0 x [0 x [8 x i64]]], i32 0, align 16
; CHECK-NEXT: [[CHROMA_DC209:%.*]] = getelementptr i8, ptr [[H]], i64 0
; CHECK-NEXT: [[TMP0:%.*]] = load <4 x i64>, ptr [[DCT2X211]], align 16
; CHECK-NEXT: [[TMP1:%.*]] = shufflevector <4 x i64> [[TMP0]], <4 x i64> poison, <4 x i32> <i32 0, i32 2, i32 1, i32 3>
; CHECK-NEXT: store <4 x i64> [[TMP1]], ptr [[CHROMA_DC209]], align 2
; CHECK-NEXT: ret void
;
entry:
%dct2x211 = alloca [0 x [0 x [8 x i64]]], i32 0, align 16
%chroma_dc209 = getelementptr i8, ptr %h, i64 0
%arrayidx30.i = getelementptr i8, ptr %dct2x211, i64 16
%arrayidx33.i = getelementptr i8, ptr %dct2x211, i64 8
%arrayidx36.i181 = getelementptr i8, ptr %dct2x211, i64 24
%0 = load i64, ptr %dct2x211, align 16
store i64 %0, ptr %chroma_dc209, align 2
%1 = load i64, ptr %arrayidx30.i, align 4
%arrayidx3.i224 = getelementptr i8, ptr %h, i64 8
store i64 %1, ptr %arrayidx3.i224, align 2
%2 = load i64, ptr %arrayidx33.i, align 2
%arrayidx5.i226 = getelementptr i8, ptr %h, i64 16
store i64 %2, ptr %arrayidx5.i226, align 2
%3 = load i64, ptr %arrayidx36.i181, align 2
%arrayidx7.i228 = getelementptr i8, ptr %h, i64 24
store i64 %3, ptr %arrayidx7.i228, align 2
ret void
}
|