Skip to content

Commit 5f002ba

Browse files
aadeshps-mcwkrishna2803
authored andcommitted
[SPIRV] Addition of spe-constant-length-array.ll, bit_reverse_small_type.ll test files (llvm#151645)
--Test for support for specialization constant-based variable-length --Test for ensuring that encoding of variable with undef initializer has correct --Test for bitreverse intrinsic with small types
1 parent 91ed4fa commit 5f002ba

File tree

2 files changed

+148
-0
lines changed

2 files changed

+148
-0
lines changed
Lines changed: 56 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,56 @@
1+
; RUN: llc -O0 -verify-machineinstrs -mtriple=spirv64-unknown-unknown --spirv-ext=+SPV_INTEL_variable_length_array %s -o - | FileCheck %s
2+
; RUN: %if spirv-tools %{ llc -O0 -mtriple=spirv64-unknown-unknown --spirv-ext=+SPV_INTEL_variable_length_array %s -o - -filetype=obj | spirv-val %}
3+
4+
; CHECK: OpCapability VariableLengthArrayINTEL
5+
; CHECK: OpExtension "SPV_INTEL_variable_length_array"
6+
7+
; CHECK-DAG: OpDecorate %[[#]] SpecId 0
8+
; CHECK-DAG: OpDecorate %[[#]] SpecId 1
9+
; CHECK-DAG: OpDecorate %[[#]] SpecId 2
10+
; CHECK-DAG: OpDecorate %[[#A0:]] Alignment 4
11+
; CHECK-DAG: OpDecorate %[[#A1:]] Alignment 2
12+
; CHECK-DAG: OpDecorate %[[#A2:]] Alignment 16
13+
14+
; CHECK: %[[#VOID_TY:]] = OpTypeVoid
15+
; CHECK: %[[#FUNC_TY:]] = OpTypeFunction %[[#VOID_TY]]
16+
; CHECK-DAG: %[[#I64:]] = OpTypeInt 64 0
17+
; CHECK-DAG: %[[#I32:]] = OpTypeInt 32 0
18+
; CHECK-DAG: %[[#I8:]] = OpTypeInt 8 0
19+
; CHECK-DAG: %[[#F64:]] = OpTypeFloat 64
20+
; CHECK-DAG: %[[#STRUCT_TY:]] = OpTypeStruct %[[#F64]] %[[#F64]]
21+
; CHECK-DAG: %[[#PTR_STRUCT:]] = OpTypePointer Function %[[#STRUCT_TY]]
22+
; CHECK-DAG: %[[#PTR_I8:]] = OpTypePointer Function %[[#I8]]
23+
; CHECK-DAG: %[[#F32:]] = OpTypeFloat 32
24+
; CHECK-DAG: %[[#PTR_F32:]] = OpTypePointer Function %[[#F32]]
25+
26+
; CHECK-DAG: %[[#SC0:]] = OpSpecConstant %[[#I64]] 1
27+
; CHECK-DAG: %[[#SC1:]] = OpSpecConstant %[[#I32]] 2
28+
; CHECK-DAG: %[[#SC2:]] = OpSpecConstant %[[#I8]] 4
29+
30+
; CHECK: %[[#]] = OpFunction %[[#VOID_TY]] None %[[#FUNC_TY]]
31+
; CHECK: %[[#LABEL:]] = OpLabel
32+
33+
; CHECK: %[[#A0]] = OpVariableLengthArrayINTEL %[[#PTR_F32]] %[[#SC0]]
34+
; CHECK: %[[#A1]] = OpVariableLengthArrayINTEL %[[#PTR_I8]] %[[#SC1]]
35+
; CHECK: %[[#A2]] = OpVariableLengthArrayINTEL %[[#PTR_STRUCT]] %[[#SC2]]
36+
37+
%struct_type = type { double, double }
38+
39+
define spir_kernel void @test() {
40+
entry:
41+
%length0 = call i64 @_Z20__spirv_SpecConstantix(i32 0, i64 1), !SYCL_SPEC_CONST_SYM_ID !0
42+
%length1 = call i32 @_Z20__spirv_SpecConstantii(i32 1, i32 2), !SYCL_SPEC_CONST_SYM_ID !1
43+
%length2 = call i8 @_Z20__spirv_SpecConstantic(i32 2, i8 4), !SYCL_SPEC_CONST_SYM_ID !2
44+
%scla0 = alloca float, i64 %length0, align 4
45+
%scla1 = alloca i8, i32 %length1, align 2
46+
%scla2 = alloca %struct_type, i8 %length2, align 16
47+
ret void
48+
}
49+
50+
declare i8 @_Z20__spirv_SpecConstantic(i32, i8)
51+
declare i32 @_Z20__spirv_SpecConstantii(i32, i32)
52+
declare i64 @_Z20__spirv_SpecConstantix(i32, i64)
53+
54+
!0 = !{!"i64_spec_const", i32 0}
55+
!1 = !{!"i32_spec_const", i32 1}
56+
!2 = !{!"i8_spec_const", i32 2}
Lines changed: 92 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,92 @@
1+
;; Check that llvm.bitreverse.* intrinsics are lowered for
2+
;; 2/4-bit scalar and vector types.
3+
4+
; RUN: llc -O0 -verify-machineinstrs -mtriple=spirv64-unknown-unknown --spirv-ext=+SPV_INTEL_arbitrary_precision_integers %s -o - | FileCheck %s
5+
; TODO: %if spirv-tools %{ llc -O0 -mtriple=spirv64-unknown-unknown --spirv-ext=+SPV_INTEL_arbitrary_precision_integers %s -o - -filetype=obj | spirv-val %}
6+
7+
; CHECK: OpCapability ArbitraryPrecisionIntegersINTEL
8+
; CHECK: OpExtension "SPV_INTEL_arbitrary_precision_integers"
9+
10+
; CHECK: %[[#I4:]] = OpTypeInt 4 0
11+
; CHECK: %[[#I2:]] = OpTypeInt 2 0
12+
; CHECK: %[[#Z4:]] = OpConstantNull %[[#I4]]
13+
; CHECK: %[[#Z2:]] = OpConstantNull %[[#I2]]
14+
; CHECK: %[[#V2I2:]] = OpTypeVector %[[#I2]] 2
15+
; CHECK: %[[#V2I4:]] = OpTypeVector %[[#I4]] 2
16+
; CHECK: %[[#V3I2:]] = OpTypeVector %[[#I2]] 3
17+
; CHECK: %[[#V3I4:]] = OpTypeVector %[[#I4]] 3
18+
; CHECK: %[[#V4I2:]] = OpTypeVector %[[#I2]] 4
19+
; CHECK: %[[#V4I4:]] = OpTypeVector %[[#I4]] 4
20+
; CHECK: %[[#V8I2:]] = OpTypeVector %[[#I2]] 8
21+
; CHECK: %[[#V8I4:]] = OpTypeVector %[[#I4]] 8
22+
; CHECK: %[[#V16I2:]] = OpTypeVector %[[#I2]] 16
23+
; CHECK: %[[#V16I4:]] = OpTypeVector %[[#I4]] 16
24+
25+
26+
; CHECK: %[[#]] = OpBitReverse %[[#I2]] %[[#Z2]]
27+
; CHECK: %[[#]] = OpBitReverse %[[#I4]] %[[#Z4]]
28+
; CHECK: %[[#]] = OpBitReverse %[[#V2I2]] %[[#]]
29+
; CHECK: %[[#]] = OpBitReverse %[[#V2I4]] %[[#]]
30+
; CHECK: %[[#]] = OpBitReverse %[[#V3I2]] %[[#]]
31+
; CHECK: %[[#]] = OpBitReverse %[[#V3I4]] %[[#]]
32+
; CHECK: %[[#]] = OpBitReverse %[[#V4I2]] %[[#]]
33+
; CHECK: %[[#]] = OpBitReverse %[[#V4I4]] %[[#]]
34+
; CHECK: %[[#]] = OpBitReverse %[[#V8I2]] %[[#]]
35+
; CHECK: %[[#]] = OpBitReverse %[[#V8I4]] %[[#]]
36+
; CHECK: %[[#]] = OpBitReverse %[[#V16I2]] %[[#]]
37+
; CHECK: %[[#]] = OpBitReverse %[[#V16I4]] %[[#]]
38+
39+
define spir_kernel void @testBitRev() {
40+
entry:
41+
%call2 = call i2 @llvm.bitreverse.i2(i2 0)
42+
%call4 = call i4 @llvm.bitreverse.i4(i4 0)
43+
ret void
44+
}
45+
46+
define spir_kernel void @testBitRevV2(<2 x i2> %a, <2 x i4> %b) {
47+
entry:
48+
%call2 = call <2 x i2> @llvm.bitreverse.v2i2(<2 x i2> %a)
49+
%call4 = call <2 x i4> @llvm.bitreverse.v2i4(<2 x i4> %b)
50+
ret void
51+
}
52+
53+
define spir_kernel void @testBitRevV3(<3 x i2> %a, <3 x i4> %b) {
54+
entry:
55+
%call2 = call <3 x i2> @llvm.bitreverse.v3i2(<3 x i2> %a)
56+
%call4 = call <3 x i4> @llvm.bitreverse.v3i4(<3 x i4> %b)
57+
ret void
58+
}
59+
60+
define spir_kernel void @testBitRevV4(<4 x i2> %a, <4 x i4> %b) {
61+
entry:
62+
%call2 = call <4 x i2> @llvm.bitreverse.v4i2(<4 x i2> %a)
63+
%call4 = call <4 x i4> @llvm.bitreverse.v4i4(<4 x i4> %b)
64+
ret void
65+
}
66+
67+
define spir_kernel void @testBitRevV8(<8 x i2> %a, <8 x i4> %b) {
68+
entry:
69+
%call2 = call <8 x i2> @llvm.bitreverse.v8i2(<8 x i2> %a)
70+
%call4 = call <8 x i4> @llvm.bitreverse.v8i4(<8 x i4> %b)
71+
ret void
72+
}
73+
74+
define spir_kernel void @testBitRevV16(<16 x i2> %a, <16 x i4> %b) {
75+
entry:
76+
%call2 = call <16 x i2> @llvm.bitreverse.v16i2(<16 x i2> %a)
77+
%call4 = call <16 x i4> @llvm.bitreverse.v16i4(<16 x i4> %b)
78+
ret void
79+
}
80+
81+
declare i2 @llvm.bitreverse.i2(i2)
82+
declare i4 @llvm.bitreverse.i4(i4)
83+
declare <2 x i2> @llvm.bitreverse.v2i2(<2 x i2>)
84+
declare <2 x i4> @llvm.bitreverse.v2i4(<2 x i4>)
85+
declare <3 x i2> @llvm.bitreverse.v3i2(<3 x i2>)
86+
declare <3 x i4> @llvm.bitreverse.v3i4(<3 x i4>)
87+
declare <4 x i2> @llvm.bitreverse.v4i2(<4 x i2>)
88+
declare <4 x i4> @llvm.bitreverse.v4i4(<4 x i4>)
89+
declare <8 x i2> @llvm.bitreverse.v8i2(<8 x i2>)
90+
declare <8 x i4> @llvm.bitreverse.v8i4(<8 x i4>)
91+
declare <16 x i2> @llvm.bitreverse.v16i2(<16 x i2>)
92+
declare <16 x i4> @llvm.bitreverse.v16i4(<16 x i4>)

0 commit comments

Comments
 (0)