blob: bf3fa1b8ffe3557467ef8b9e6cf1d9d83e172421 [file] [edit]
; RUN: llc -verify-machineinstrs -O0 -mtriple=spirv64-unknown-unknown %s -o - | FileCheck %s
; RUN: %if spirv-tools %{ llc -O0 -mtriple=spirv64-unknown-unknown %s -o - -filetype=obj | spirv-val %}
; CHECK-DAG: %[[#INT32:]] = OpTypeInt 32 0
; CHECK-DAG: %[[#PTR_INT32:]] = OpTypePointer CrossWorkgroup %[[#INT32]]
; CHECK-DAG: %[[#INT64:]] = OpTypeInt 64 0
; CHECK-DAG: %[[#CONST_0:]] = OpConstantNull %[[#INT64]]
; CHECK-LABEL: Begin function test_vector_gep_with_load
; CHECK-NOT: OpBitcast
; CHECK: %[[#GEP:]] = OpPtrAccessChain %[[#PTR_INT32]] %[[#]] %[[#CONST_0]]
; CHECK-NOT: OpBitcast
; CHECK: %[[#VAL:]] = OpLoad %[[#INT32]] %[[#GEP]]
; CHECK: OpStore %[[#]] %[[#VAL]]
; CHECK: OpFunctionEnd
define spir_kernel void @test_vector_gep_with_load(ptr addrspace(1) %p, ptr addrspace(1) %out) {
%gep = getelementptr i32, ptr addrspace(1) %p, <1 x i64> zeroinitializer
%elem = extractelement <1 x ptr addrspace(1)> %gep, i32 0
%val = load i32, ptr addrspace(1) %elem
store i32 %val, ptr addrspace(1) %out
ret void
}