blob: a1b68a93f157786a5298433c249a749162bfac0a [file] [log] [blame]
// RUN: clspv %s -o %t.spv -cluster-pod-kernel-args=0
// RUN: spirv-dis -o %t2.spvasm %t.spv
// RUN: FileCheck %s < %t2.spvasm
// RUN: spirv-val --target-env vulkan1.0 %t.spv
// RUN: clspv %s -o %t4.spv
// RUN: spirv-dis -o %t4.spvasm %t4.spv
// RUN: FileCheck %s < %t4.spvasm -check-prefix=CLUSTER
// RUN: spirv-val --target-env vulkan1.0 %t4.spv
void kernel __attribute__((reqd_work_group_size(1, 1, 1))) foo(sampler_t s, read_only image2d_t i, float2 c, global int4* a)
{
*a = read_imagei(i, s, c);
}
// CHECK-DAG: [[_float:%[0-9a-zA-Z_]+]] = OpTypeFloat 32
// CHECK-DAG: [[_2:%[0-9a-zA-Z_]+]] = OpTypeSampler
// CHECK-DAG: [[_uint:%[0-9a-zA-Z_]+]] = OpTypeInt 32 0
// CHECK-DAG: [[_v4uint:%[0-9a-zA-Z_]+]] = OpTypeVector [[_uint]] 4
// CHECK-DAG: [[_int:%[0-9a-zA-Z_]+]] = OpTypeInt 32 1
// CHECK-DAG: [[_v4int:%[0-9a-zA-Z_]+]] = OpTypeVector [[_int]] 4
// CHECK-DAG: [[_4:%[0-9a-zA-Z_]+]] = OpTypeImage [[_int]] 2D 0 0 0 1 Unknown
// CHECK-DAG: [[_v2float:%[0-9a-zA-Z_]+]] = OpTypeVector [[_float]] 2
// CHECK-DAG: [[_18:%[a-zA-Z0-9_]+]] = OpTypeSampledImage [[_4]]
// CHECK-DAG: [[_float_0:%[0-9a-zA-Z_]+]] = OpConstant [[_float]] 0
// CHECK: [[_27:%[0-9a-zA-Z_]+]] = OpLoad [[_2]]
// CHECK: [[_28:%[0-9a-zA-Z_]+]] = OpLoad [[_4]]
// CHECK: [[_30:%[0-9a-zA-Z_]+]] = OpLoad [[_v2float]]
// CHECK: [[_32:%[0-9a-zA-Z_]+]] = OpSampledImage [[_18]] [[_28]] [[_27]]
// CHECK: [[_33:%[0-9a-zA-Z_]+]] = OpImageSampleExplicitLod [[_v4int]] [[_32]] [[_30]] Lod [[_float_0]]
// CHECK: [[cast:%[0-9a-zA-Z_]+]] = OpBitcast [[_v4uint]] [[_33]]
// CHECK: OpStore {{.*}} [[cast]]
// In a second round, check -cluster-pod-kernel-args
// CLUSTER-DAG: [[_float:%[a-zA-Z0-9_]+]] = OpTypeFloat 32
// CLUSTER-DAG: [[_2:%[a-zA-Z0-9_]+]] = OpTypeSampler
// CLUSTER-DAG: [[_uint:%[0-9a-zA-Z_]+]] = OpTypeInt 32 0
// CLUSTER-DAG: [[_v4uint:%[0-9a-zA-Z_]+]] = OpTypeVector [[_uint]] 4
// CLUSTER-DAG: [[_int:%[0-9a-zA-Z_]+]] = OpTypeInt 32 1
// CLUSTER-DAG: [[_v4int:%[0-9a-zA-Z_]+]] = OpTypeVector [[_int]] 4
// CLUSTER-DAG: [[_4:%[0-9a-zA-Z_]+]] = OpTypeImage [[_int]] 2D 0 0 0 1 Unknown
// CLUSTER-DAG: [[_v2float:%[a-zA-Z0-9_]+]] = OpTypeVector [[_float]] 2
// CLUSTER-DAG: [[__struct_12:%[a-zA-Z0-9_]+]] = OpTypeStruct [[_v2float]]
// CLUSTER-DAG: [[_19:%[a-zA-Z0-9_]+]] = OpTypeSampledImage [[_4]]
// CLUSTER-DAG: [[_float_0:%[0-9a-zA-Z_]+]] = OpConstant [[_float]] 0
// CLUSTER: [[_28:%[a-zA-Z0-9_]+]] = OpLoad [[_2]]
// CLUSTER: [[_29:%[a-zA-Z0-9_]+]] = OpLoad [[_4]]
// CLUSTER: [[_32:%[a-zA-Z0-9_]+]] = OpLoad [[__struct_12]]
// CLUSTER: [[_33:%[a-zA-Z0-9_]+]] = OpCompositeExtract [[_v2float]] [[_32]] 0
// CLUSTER: [[_34:%[a-zA-Z0-9_]+]] = OpSampledImage [[_19]] [[_29]] [[_28]]
// CLUSTER: [[_35:%[a-zA-Z0-9_]+]] = OpImageSampleExplicitLod [[_v4int]] [[_34]] [[_33]] Lod [[_float_0]]
// CLUSTER: [[cast:%[0-9a-zA-Z_]+]] = OpBitcast [[_v4uint]] [[_35]]
// CLUSTER: OpStore {{.*}} [[cast]]