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 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61
|
; NOTE: Assertions have been autogenerated by utils/update_test_checks.py UTC_ARGS: --version 5
; RUN: opt -passes=sandbox-vectorizer -sbvec-vec-reg-bits=1024 -sbvec-allow-non-pow2 -sbvec-passes="seed-collection<tr-save,bottom-up-vec,tr-accept>" --sbvec-stop-at=0 %s -S | FileCheck %s --check-prefix=STOPAT0
; RUN: opt -passes=sandbox-vectorizer -sbvec-vec-reg-bits=1024 -sbvec-allow-non-pow2 -sbvec-passes="seed-collection<tr-save,bottom-up-vec,tr-accept>" --sbvec-stop-at=1 %s -S | FileCheck %s --check-prefix=STOPAT1
; RUN: opt -passes=sandbox-vectorizer -sbvec-vec-reg-bits=1024 -sbvec-allow-non-pow2 -sbvec-passes="seed-collection<tr-save,bottom-up-vec,tr-accept>" --sbvec-stop-at=2 %s -S | FileCheck %s --check-prefix=STOPAT2
define void @widen(ptr %ptrA, ptr %ptrB) {
; STOPAT0-LABEL: define void @widen(
; STOPAT0-SAME: ptr [[PTRA:%.*]], ptr [[PTRB:%.*]]) {
; STOPAT0-NEXT: [[PTRA0:%.*]] = getelementptr float, ptr [[PTRA]], i32 0
; STOPAT0-NEXT: [[PTRA1:%.*]] = getelementptr float, ptr [[PTRA]], i32 1
; STOPAT0-NEXT: [[LDA0:%.*]] = load float, ptr [[PTRA0]], align 4
; STOPAT0-NEXT: [[LDA1:%.*]] = load float, ptr [[PTRA1]], align 4
; STOPAT0-NEXT: store float [[LDA0]], ptr [[PTRA0]], align 4
; STOPAT0-NEXT: store float [[LDA1]], ptr [[PTRA1]], align 4
; STOPAT0-NEXT: [[PTRB0:%.*]] = getelementptr float, ptr [[PTRB]], i32 0
; STOPAT0-NEXT: [[PTRB1:%.*]] = getelementptr float, ptr [[PTRB]], i32 1
; STOPAT0-NEXT: [[LDB0:%.*]] = load float, ptr [[PTRB0]], align 4
; STOPAT0-NEXT: [[LDB1:%.*]] = load float, ptr [[PTRB1]], align 4
; STOPAT0-NEXT: store float [[LDB0]], ptr [[PTRB0]], align 4
; STOPAT0-NEXT: store float [[LDB1]], ptr [[PTRB1]], align 4
; STOPAT0-NEXT: ret void
;
; STOPAT1-LABEL: define void @widen(
; STOPAT1-SAME: ptr [[PTRA:%.*]], ptr [[PTRB:%.*]]) {
; STOPAT1-NEXT: [[PTRA0:%.*]] = getelementptr float, ptr [[PTRA]], i32 0
; STOPAT1-NEXT: [[VECL:%.*]] = load <2 x float>, ptr [[PTRA0]], align 4
; STOPAT1-NEXT: store <2 x float> [[VECL]], ptr [[PTRA0]], align 4
; STOPAT1-NEXT: [[PTRB0:%.*]] = getelementptr float, ptr [[PTRB]], i32 0
; STOPAT1-NEXT: [[PTRB1:%.*]] = getelementptr float, ptr [[PTRB]], i32 1
; STOPAT1-NEXT: [[LDB0:%.*]] = load float, ptr [[PTRB0]], align 4
; STOPAT1-NEXT: [[LDB1:%.*]] = load float, ptr [[PTRB1]], align 4
; STOPAT1-NEXT: store float [[LDB0]], ptr [[PTRB0]], align 4
; STOPAT1-NEXT: store float [[LDB1]], ptr [[PTRB1]], align 4
; STOPAT1-NEXT: ret void
;
; STOPAT2-LABEL: define void @widen(
; STOPAT2-SAME: ptr [[PTRA:%.*]], ptr [[PTRB:%.*]]) {
; STOPAT2-NEXT: [[PTRA0:%.*]] = getelementptr float, ptr [[PTRA]], i32 0
; STOPAT2-NEXT: [[VECL:%.*]] = load <2 x float>, ptr [[PTRA0]], align 4
; STOPAT2-NEXT: store <2 x float> [[VECL]], ptr [[PTRA0]], align 4
; STOPAT2-NEXT: [[PTRB0:%.*]] = getelementptr float, ptr [[PTRB]], i32 0
; STOPAT2-NEXT: [[VECL1:%.*]] = load <2 x float>, ptr [[PTRB0]], align 4
; STOPAT2-NEXT: store <2 x float> [[VECL1]], ptr [[PTRB0]], align 4
; STOPAT2-NEXT: ret void
;
%ptrA0 = getelementptr float, ptr %ptrA, i32 0
%ptrA1 = getelementptr float, ptr %ptrA, i32 1
%ldA0 = load float, ptr %ptrA0
%ldA1 = load float, ptr %ptrA1
store float %ldA0, ptr %ptrA0
store float %ldA1, ptr %ptrA1
%ptrB0 = getelementptr float, ptr %ptrB, i32 0
%ptrB1 = getelementptr float, ptr %ptrB, i32 1
%ldB0 = load float, ptr %ptrB0
%ldB1 = load float, ptr %ptrB1
store float %ldB0, ptr %ptrB0
store float %ldB1, ptr %ptrB1
ret void
}
|