-
Notifications
You must be signed in to change notification settings - Fork 92
/
Copy pathvstore2_global_long2.ll
24 lines (19 loc) · 1.06 KB
/
vstore2_global_long2.ll
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
; RUN: clspv-opt --passes=replace-opencl-builtin %s -o %t
; RUN: FileCheck %s < %t
target datalayout = "e-p:32:32-i64:64-v16:16-v24:32-v32:32-v48:64-v96:128-v192:256-v256:256-v512:512-v1024:1024"
target triple = "spir-unknown-unknown"
define void @foo(ptr addrspace(1) %in, <2 x i64> %data, i32 %offset) {
entry:
call spir_func void @_Z7vstore2Dv2_mjPU3AS1m(<2 x i64> %data, i32 %offset, ptr addrspace(1) %in)
ret void
}
declare void @_Z7vstore2Dv2_mjPU3AS1m(<2 x i64>, i32, ptr addrspace(1))
; CHECK: [[mul:%[a-zA-Z0-9_.]+]] = mul i32 %offset, 2
; CHECK: [[add:%[a-zA-Z0-9_.]+]] = add i32 [[mul]], 0
; CHECK: [[gep:%[a-zA-Z0-9_.]+]] = getelementptr i64, ptr addrspace(1) %in, i32 [[add]]
; CHECK: [[ex:%[a-zA-Z0-9_.]+]] = extractelement <2 x i64> %data, i64 0
; CHECK: store i64 [[ex]], ptr addrspace(1) [[gep]]
; CHECK: [[add:%[a-zA-Z0-9_.]+]] = add i32 [[mul]], 1
; CHECK: [[gep:%[a-zA-Z0-9_.]+]] = getelementptr i64, ptr addrspace(1) %in, i32 [[add]]
; CHECK: [[ex:%[a-zA-Z0-9_.]+]] = extractelement <2 x i64> %data, i64 1
; CHECK: store i64 [[ex]], ptr addrspace(1) [[gep]]