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
|
; RUN: opt -S -mtriple=amdgcn-- -passes=load-store-vectorizer < %s | FileCheck -check-prefix=OPT %s
; OPT-LABEL: @buffer_fat_ptrs(
define void @buffer_fat_ptrs(ptr addrspace(7) %out) {
entry:
%a1 = getelementptr i32, ptr addrspace(7) %out, i32 1
%a2 = getelementptr i32, ptr addrspace(7) %out, i32 2
%a3 = getelementptr i32, ptr addrspace(7) %out, i32 3
; OPT: store <4 x i32> <i32 0, i32 1, i32 2, i32 3>, ptr addrspace(7) %out, align 16
store i32 0, ptr addrspace(7) %out, align 16
store i32 1, ptr addrspace(7) %a1, align 4
store i32 2, ptr addrspace(7) %a2, align 8
store i32 3, ptr addrspace(7) %a3, align 4
ret void
}
; OPT-LABEL: @buffer_strided_ptrs(
define void @buffer_strided_ptrs(ptr addrspace(9) %out) {
entry:
%a1 = getelementptr i32, ptr addrspace(9) %out, i32 1
%a2 = getelementptr i32, ptr addrspace(9) %out, i32 2
%a3 = getelementptr i32, ptr addrspace(9) %out, i32 3
; OPT: store <4 x i32> <i32 0, i32 1, i32 2, i32 3>, ptr addrspace(9) %out, align 16
store i32 0, ptr addrspace(9) %out, align 16
store i32 1, ptr addrspace(9) %a1, align 4
store i32 2, ptr addrspace(9) %a2, align 8
store i32 3, ptr addrspace(9) %a3, align 4
ret void
}
|