Run DCE after a LoopFlatten test to reduce spurious output [nfc]
[llvm-project.git] / llvm / test / CodeGen / SPIRV / image.ll
blob8d4ab7f3cbf0ee20219a49aab6fba0992decdc18
1 ; RUN: llc -O0 -mtriple=spirv64-unknown-unknown %s -o - | FileCheck %s --check-prefix=CHECK-SPIRV
3 ; CHECK-SPIRV:     %[[#VOID_TY:]] = OpTypeVoid
4 ; CHECK-SPIRV-DAG: %[[#]] = OpTypeImage %[[#VOID_TY]] 2D 0 0 0 0 Unknown ReadOnly
5 ; CHECK-SPIRV-DAG: %[[#]] = OpTypeImage %[[#VOID_TY]] 2D 0 0 0 0 Unknown WriteOnly
6 ; CHECK-SPIRV-NOT: %[[#]] = OpTypeImage %[[#VOID_TY]] 2D 0 0 0 0 Unknown ReadOnly
7 ; CHECK-SPIRV:     OpImageSampleExplicitLod
8 ; CHECK-SPIRV:     OpImageWrite
10 define spir_kernel void @image_copy(target("spirv.Image", void, 1, 0, 0, 0, 0, 0, 0) %image1, target("spirv.Image", void, 1, 0, 0, 0, 0, 0, 0) %image2) !kernel_arg_access_qual !1 {
11   %call = tail call spir_func i64 @_Z13get_global_idj(i32 0)
12   %conv = trunc i64 %call to i32
13   %call1 = tail call spir_func i64 @_Z13get_global_idj(i32 1)
14   %conv2 = trunc i64 %call1 to i32
15   %vecinit = insertelement <2 x i32> undef, i32 %conv, i32 0
16   %vecinit3 = insertelement <2 x i32> %vecinit, i32 %conv2, i32 1
17   %call4 = tail call spir_func <4 x float> @_Z11read_imagef11ocl_image2d11ocl_samplerDv2_i(target("spirv.Image", void, 1, 0, 0, 0, 0, 0, 0) %image1, i32 20, <2 x i32> %vecinit3)
18   tail call spir_func void @_Z12write_imagef11ocl_image2dDv2_iDv4_f(target("spirv.Image", void, 1, 0, 0, 0, 0, 0, 0) %image2, <2 x i32> %vecinit3, <4 x float> %call4)
19   ret void
22 declare spir_func i64 @_Z13get_global_idj(i32)
24 declare spir_func <4 x float> @_Z11read_imagef11ocl_image2d11ocl_samplerDv2_i(target("spirv.Image", void, 1, 0, 0, 0, 0, 0, 0), i32, <2 x i32>)
26 declare spir_func void @_Z12write_imagef11ocl_image2dDv2_iDv4_f(target("spirv.Image", void, 1, 0, 0, 0, 0, 0, 0), <2 x i32>, <4 x float>)
28 !1 = !{!"read_only", !"write_only"}