diff options
| author | Yong He <yonghe@outlook.com> | 2024-06-08 05:12:49 -0700 |
|---|---|---|
| committer | GitHub <noreply@github.com> | 2024-06-08 05:12:49 -0700 |
| commit | 9a23a9aab3721828526c921db1e779008e133e8f (patch) | |
| tree | b49448075cdffe278fd6760e2879bc061eb8e0af /tests | |
| parent | bc680e74bd8a0c415cab5ed6fe00b762c26b8b8d (diff) | |
SPIRV `Block` decoration fixes. (#4303)
* SPIRV `Block` decoration fixes.
- SPIRV does not allow duplicate `Block` decorations. So we shouldn't be generating them.
- Also fixes duplication of OpName.
- SPIRV and HLSL do not allow ConstantBuffer with trailing unsized arrays. Added a check in the front-end against such code.
* Convert failing cross-compile tests to filecheck.
---------
Co-authored-by: Jay Kwak <82421531+jkwak-work@users.noreply.github.com>
Diffstat (limited to 'tests')
30 files changed, 111 insertions, 256 deletions
diff --git a/tests/bindings/glsl-parameter-blocks.slang b/tests/bindings/glsl-parameter-blocks.slang index ee385e158..fd2800e2c 100644 --- a/tests/bindings/glsl-parameter-blocks.slang +++ b/tests/bindings/glsl-parameter-blocks.slang @@ -1,4 +1,7 @@ -//TEST:CROSS_COMPILE: -profile ps_5_0 -entry main -target spirv-assembly +//TEST:SIMPLE(filecheck=CHECK): -profile ps_5_0 -entry main -target spirv-assembly + +// CHECK: OpDecorate %gTest Binding 0 +// CHECK: OpDecorate %gTest DescriptorSet 0 struct Test { diff --git a/tests/bugs/gh-941.slang b/tests/bugs/gh-941.slang index f66c25e97..f0e5a7036 100644 --- a/tests/bugs/gh-941.slang +++ b/tests/bugs/gh-941.slang @@ -1,7 +1,11 @@ -//TEST:CROSS_COMPILE: -profile ps_5_0 -entry main -target spirv-assembly +//TEST:SIMPLE(filecheck=CHECK): -profile spirv_1_5+fragment -entry main -target spirv-assembly +//TEST:SIMPLE(filecheck=GLSL): -profile spirv_1_5+fragment -entry main -target glsl // Ensure that we add the `GL_EXT_nonuniform_qualifier` extension for any code that uses unbounded-size arrays of resources. +// CHECK: OpCapability RuntimeDescriptorArray +// GLSL: #extension GL_EXT_nonuniform_qualifier : require + Texture2D t[]; SamplerState s; diff --git a/tests/bugs/vk-image-atomics.slang b/tests/bugs/vk-image-atomics.slang index f846606f9..f5b2821ec 100644 --- a/tests/bugs/vk-image-atomics.slang +++ b/tests/bugs/vk-image-atomics.slang @@ -1,7 +1,11 @@ -//TEST:CROSS_COMPILE: -profile ps_5_0 -entry main -target spirv-assembly +//TEST:SIMPLE(filecheck=CHECK): -profile ps_5_0 -entry main -target spirv-assembly +//TEST:SIMPLE(filecheck=CHECK): -profile ps_5_0 -entry main -target spirv-assembly -emit-spirv-via-glsl // Ensure that we can lower to `imageAtomicAdd` correctly. +// CHECK: OpImageTexelPointer +// CHECK: OpAtomicIAdd + RWTexture2D<uint> t; float4 main() : SV_Target diff --git a/tests/bugs/vk-structured-buffer-binding.hlsl b/tests/bugs/vk-structured-buffer-binding.hlsl index 3ef1bcc8c..da0424543 100644 --- a/tests/bugs/vk-structured-buffer-binding.hlsl +++ b/tests/bugs/vk-structured-buffer-binding.hlsl @@ -1,4 +1,8 @@ -//TEST:CROSS_COMPILE:-profile ps_4_0 -entry main -target spirv-assembly +//TEST:SIMPLE(filecheck=CHECK):-profile ps_4_0 -entry main -target spirv-assembly + +// CHECK-DAG: OpDecorate %gDoneGroups{{.*}} DescriptorSet 4 + +// CHECK-DAG: OpDecorate %gDoneGroups{{.*}} Binding 3 [[vk::binding(3, 4)]] RWStructuredBuffer<uint> gDoneGroups : register(u3); diff --git a/tests/bugs/vk-structured-buffer-binding.hlsl.glsl b/tests/bugs/vk-structured-buffer-binding.hlsl.glsl deleted file mode 100644 index 18ed1a8a7..000000000 --- a/tests/bugs/vk-structured-buffer-binding.hlsl.glsl +++ /dev/null @@ -1,24 +0,0 @@ -// vk-structured-buffer-binding.hlsl.glsl -//TEST_IGNORE_FILE: - -#version 450 -layout(row_major) uniform; -layout(row_major) buffer; - -layout(std430, binding = 3, set = 4) buffer StructuredBuffer_uint_t_0 { - uint _data[]; -} gDoneGroups_0; - -layout(location = 0) -out vec4 main_0; - -layout(location = 0) -in vec3 uv_0; - -void main() -{ - main_0 = vec4(float(gDoneGroups_0._data[uint(int(uv_0.z))])); - return; -} - - diff --git a/tests/cross-compile/barycentrics.slang b/tests/cross-compile/barycentrics.slang index 1f2c27572..c63835ccc 100644 --- a/tests/cross-compile/barycentrics.slang +++ b/tests/cross-compile/barycentrics.slang @@ -1,4 +1,6 @@ -//TEST:CROSS_COMPILE:-target spirv-assembly -entry main -stage fragment +//TEST:SIMPLE(filecheck=CHECK):-target spirv-assembly -entry main -stage fragment + +// CHECK: OpDecorate %{{.*}} BuiltIn BaryCoordKHR float4 main(float3 bary : SV_Barycentrics) : SV_Target { diff --git a/tests/cross-compile/barycentrics.slang.glsl b/tests/cross-compile/barycentrics.slang.glsl deleted file mode 100644 index ede585db0..000000000 --- a/tests/cross-compile/barycentrics.slang.glsl +++ /dev/null @@ -1,12 +0,0 @@ -#version 450 - -#extension GL_EXT_fragment_shader_barycentric : enable - -layout(location = 0) -out vec4 main_0; - -void main() -{ - main_0 = vec4(gl_BaryCoordEXT, float(0)); - return; -} diff --git a/tests/cross-compile/dual-source-blending.slang b/tests/cross-compile/dual-source-blending.slang index 51af956b2..602f8e20f 100644 --- a/tests/cross-compile/dual-source-blending.slang +++ b/tests/cross-compile/dual-source-blending.slang @@ -4,9 +4,13 @@ // `vk::index` attributes to compile // for dual-source color blending. -//TEST:CROSS_COMPILE:-target spirv-assembly -entry main -stage fragment +//TEST:SIMPLE(filecheck=CHECK):-target spirv-assembly -entry main -stage fragment //TEST_DISABLED:SIMPLE:-target glsl +// CHECK: OpDecorate %{{.*}}main_a Location 0 +// CHECK: OpDecorate %{{.*}}main_b Location 0 +// CHECK: OpDecorate %{{.*}}main_b Index 1 + struct FragmentOutput { [[vk::location(0)]] diff --git a/tests/cross-compile/early-depth-stencil.hlsl b/tests/cross-compile/early-depth-stencil.hlsl index b40a29aba..931538edb 100644 --- a/tests/cross-compile/early-depth-stencil.hlsl +++ b/tests/cross-compile/early-depth-stencil.hlsl @@ -1,5 +1,7 @@ -//TEST:CROSS_COMPILE:-target spirv-assembly -entry main -stage fragment -//TEST:CROSS_COMPILE:-profile ps_6_0 -target dxil-assembly -entry main +//TEST:SIMPLE(filecheck=SPIRV):-target spirv-assembly -entry main -stage fragment +//TEST:SIMPLE(filecheck=SPIRV):-target spirv-assembly -entry main -stage fragment -emit-spirv-via-glsl + +// SPIRV: OpExecutionMode %main EarlyFragmentTests [earlydepthstencil] float4 main(): SV_Target diff --git a/tests/cross-compile/early-depth-stencil.hlsl.glsl b/tests/cross-compile/early-depth-stencil.hlsl.glsl deleted file mode 100644 index 4a723215c..000000000 --- a/tests/cross-compile/early-depth-stencil.hlsl.glsl +++ /dev/null @@ -1,16 +0,0 @@ -//TEST_IGNORE_FILE: -#version 450 -layout(row_major) uniform; -layout(row_major) buffer; - -#line 5 0 -layout(location = 0) -out vec4 main_0; - -#line 5 -layout(early_fragment_tests) in; -void main() -{ - main_0 = vec4(float(1), float(0), float(0), float(1)); - return; -} diff --git a/tests/cross-compile/early-depth-stencil.hlsl.hlsl b/tests/cross-compile/early-depth-stencil.hlsl.hlsl deleted file mode 100644 index 378c5c0a1..000000000 --- a/tests/cross-compile/early-depth-stencil.hlsl.hlsl +++ /dev/null @@ -1,8 +0,0 @@ -//TEST_IGNORE_FILE: -#pragma pack_matrix(column_major) - -[earlydepthstencil] -vector<float,4> main() : SV_TARGET -{ - return vector<float,4>((float) 1, (float) 0, (float) 0, (float) 1); -} diff --git a/tests/cross-compile/glsl-empty-struct-param-field.slang b/tests/cross-compile/glsl-empty-struct-param-field.slang index 21b67e325..f146d4684 100644 --- a/tests/cross-compile/glsl-empty-struct-param-field.slang +++ b/tests/cross-compile/glsl-empty-struct-param-field.slang @@ -1,5 +1,7 @@ -//TEST:CROSS_COMPILE:-target spirv-assembly -entry main -profile ps_5_0 +//TEST:SIMPLE(filecheck=CHECK):-target spirv-assembly -entry main -profile ps_5_0 +// CHECK: OpDecorate %pblock Binding 0 +// CHECK: OpDecorate %pblock DescriptorSet 0 struct E { }; diff --git a/tests/cross-compile/glsl-empty-struct-param-field.slang.glsl b/tests/cross-compile/glsl-empty-struct-param-field.slang.glsl deleted file mode 100644 index bff888233..000000000 --- a/tests/cross-compile/glsl-empty-struct-param-field.slang.glsl +++ /dev/null @@ -1,23 +0,0 @@ -//TEST_IGNORE_FILE: -#version 450 -layout(row_major) uniform; -layout(row_major) buffer; - -struct P_0 -{ - vec4 param_0; -}; - -layout(binding = 0) -layout(std140) uniform _S1 -{ - vec4 param_0; -} pblock_0; -layout(location = 0) -out vec4 main_0; - -void main() -{ - main_0 = pblock_0.param_0; - return; -}
\ No newline at end of file diff --git a/tests/cross-compile/half-conversion.slang b/tests/cross-compile/half-conversion.slang index 316629f81..39ba4001c 100644 --- a/tests/cross-compile/half-conversion.slang +++ b/tests/cross-compile/half-conversion.slang @@ -1,6 +1,8 @@ // half-conversion.slang -//TEST:CROSS_COMPILE:-target spirv-assembly -entry main -stage fragment +//TEST:SIMPLE(filecheck=SPIRV):-target spirv-assembly -entry main -stage fragment + +// SPIRV: OpBitcast cbuffer C { diff --git a/tests/cross-compile/non-uniform-indexing.slang b/tests/cross-compile/non-uniform-indexing.slang index 22e00a212..73483afae 100644 --- a/tests/cross-compile/non-uniform-indexing.slang +++ b/tests/cross-compile/non-uniform-indexing.slang @@ -1,8 +1,9 @@ -//TEST:CROSS_COMPILE:-target spirv-assembly -entry main -stage fragment -//TEST:CROSS_COMPILE:-target spirv-assembly -entry main -stage fragment -verify-debug-serial-ir +//TEST:SIMPLE(filecheck=CHECK):-target spirv-assembly -entry main -stage fragment -verify-debug-serial-ir // Confirm that `NonUniformResourceIndex` translates to SPIR-V as expected +// CHECK: NonUniform + Texture2D t[10]; SamplerState s; diff --git a/tests/cross-compile/non-uniform-indexing.slang.glsl b/tests/cross-compile/non-uniform-indexing.slang.glsl deleted file mode 100644 index 35b5fab95..000000000 --- a/tests/cross-compile/non-uniform-indexing.slang.glsl +++ /dev/null @@ -1,22 +0,0 @@ -#version 450 -#extension GL_EXT_nonuniform_qualifier : require -layout(row_major) uniform; -layout(row_major) buffer; -layout(binding = 0) -uniform texture2D t_0[10]; - -layout(binding = 1) -uniform sampler s_0; - -layout(location = 0) -out vec4 main_0; - -layout(location = 0) -in vec3 uv_0; - -void main() -{ - main_0 = (texture(sampler2D(t_0[nonuniformEXT(int(uv_0.z))],s_0), (uv_0.xy))); - return; -} - diff --git a/tests/cross-compile/sign.slang b/tests/cross-compile/sign.slang index 17a51d93d..934bc5c5a 100644 --- a/tests/cross-compile/sign.slang +++ b/tests/cross-compile/sign.slang @@ -1,10 +1,13 @@ // sign.slang -//TEST:CROSS_COMPILE:-target spirv-assembly -entry main -stage fragment -//TEST:CROSS_COMPILE:-target dxil-assembly -entry main -stage fragment -profile sm_6_0 +//TEST:SIMPLE(filecheck=SPIRV):-target spirv-assembly -entry main -stage fragment +//TEST:SIMPLE(filecheck=DXIL):-target dxil-assembly -entry main -stage fragment -profile sm_6_0 // Test cross compilation of the sign function +// SPIRV: FSign +// DXIL: define void @main + float4 main() : SV_Target { float4 s = sign(float4(1.5, 1.0, -1.5, -1.0)); diff --git a/tests/cross-compile/sign.slang.glsl b/tests/cross-compile/sign.slang.glsl deleted file mode 100644 index ec0bfe377..000000000 --- a/tests/cross-compile/sign.slang.glsl +++ /dev/null @@ -1,12 +0,0 @@ -#version 450 -layout(row_major) uniform; -layout(row_major) buffer; - -layout(location = 0) -out vec4 main_0; - -void main() -{ - main_0 = vec4((ivec4(sign((vec4(1.5, 1.0, -1.5, -1.0)))))); - return; -} diff --git a/tests/cross-compile/sign.slang.hlsl b/tests/cross-compile/sign.slang.hlsl deleted file mode 100644 index d7016dde7..000000000 --- a/tests/cross-compile/sign.slang.hlsl +++ /dev/null @@ -1,6 +0,0 @@ -//TEST_IGNORE_FILE: -float4 main() : SV_Target -{ - float4 s = sign(float4(1.5, 1.0, -1.5, -1.0)); - return s; -}
\ No newline at end of file diff --git a/tests/cross-compile/sv-coverage.slang b/tests/cross-compile/sv-coverage.slang index b61530e7b..ab11311a0 100644 --- a/tests/cross-compile/sv-coverage.slang +++ b/tests/cross-compile/sv-coverage.slang @@ -1,7 +1,7 @@ // sv-coverage.slang -//TEST:CROSS_COMPILE:-target spirv-assembly -entry main -stage fragment //TEST:SIMPLE(filecheck=CHECK):-target spirv -entry main -stage fragment -emit-spirv-directly +//TEST:SIMPLE(filecheck=CHECK):-target spirv -entry main -stage fragment -emit-spirv-via-glsl float4 main( in float4 color : COLOR, @@ -9,7 +9,8 @@ float4 main( out uint outputCoverage : SV_Coverage) : SV_Target { - // CHECK: %gl_SampleMask = OpVariable %_ptr_Input__arr_int_int_1 Input + // CHECK: OpDecorate %gl_SampleMask{{.*}} BuiltIn SampleMask + // CHECK: %gl_SampleMask{{.*}} = OpVariable %_ptr_Input__arr_int_{{u?}}int_1 Input outputCoverage = inputCoverage ^ 1; return color; } diff --git a/tests/cross-compile/sv-coverage.slang.glsl b/tests/cross-compile/sv-coverage.slang.glsl deleted file mode 100644 index a5e0dea47..000000000 --- a/tests/cross-compile/sv-coverage.slang.glsl +++ /dev/null @@ -1,16 +0,0 @@ -// sv-coverage.slang.glsl -#version 450 - -layout(location = 0) -out vec4 main_0; - -layout(location = 0) -in vec4 color_0; - -void main() -{ - uint _S1 = uint(gl_SampleMaskIn[0]) ^ uint(1); - main_0 = color_0; - gl_SampleMask[0] = int(_S1); - return; -} diff --git a/tests/cross-compile/unknown-image-format.slang b/tests/cross-compile/unknown-image-format.slang index bf937c5fa..27eaee606 100644 --- a/tests/cross-compile/unknown-image-format.slang +++ b/tests/cross-compile/unknown-image-format.slang @@ -1,9 +1,14 @@ // unknown-image-format.slang -//TEST:CROSS_COMPILE:-target spirv-assembly -entry main -stage fragment -default-image-format-unknown +//TEST:SIMPLE(filecheck=CHECK):-target spirv-assembly -entry main -stage fragment -default-image-format-unknown // Ensure that we can emit R/W images with an unknown format, when required. +// CHECK: OpTypeImage %float 2D 2 0 0 2 Unknown +// CHECK: OpTypeImage %float 2D 2 0 0 2 R32f +// CHECK: OpTypeImage %float 2D 2 0 0 2 Rgba8 +// CHECK: OpTypeImage %float 2D 2 0 0 2 Rgba16f + // Global Scope: RWTexture2D<float> gNoFormat; diff --git a/tests/cross-compile/unknown-image-format.slang.glsl b/tests/cross-compile/unknown-image-format.slang.glsl deleted file mode 100644 index a39cf3693..000000000 --- a/tests/cross-compile/unknown-image-format.slang.glsl +++ /dev/null @@ -1,66 +0,0 @@ -// unknown-image-format.slang.glsl -//TEST_IGNORE_FILE: - -#version 450 -#extension GL_EXT_shader_image_load_formatted : require -layout(row_major) uniform; -layout(row_major) buffer; - -struct SLANG_ParameterGroup_C_0 -{ - uvec2 index_0; -}; - -layout(binding = 2) -layout(std140) uniform _S1 -{ - uvec2 index_0; -} C_0; - -layout(binding = 0) -uniform image2D gNoFormat_0; - -layout(r32f) -layout(binding = 1) -uniform image2D gExplicitFormat_0; - -layout(binding = 0, set = 1) -uniform image2D gBlock_noFormat_0; - -layout(rgba8) -layout(binding = 1, set = 1) -uniform image2D gBlock_explicitFormat_0; - -layout(binding = 3) -uniform image2D entryPointParams_noFormat_0; - -layout(rgba16f) -layout(binding = 4) -uniform image2D entryPointParams_explicitFormat_0; - -layout(location = 0) -out vec4 main_0; - -void main() -{ - - float _S3 = (imageLoad((gNoFormat_0), ivec2((C_0.index_0))).x); - vec4 _S4 = vec4(_S3); - - float _S5 = (imageLoad((gExplicitFormat_0), ivec2((C_0.index_0))).x); - vec4 result_0 = _S4 + _S5; - - vec4 _S6 = (imageLoad((gBlock_noFormat_0), ivec2((C_0.index_0)))); - vec4 result_1 = result_0 + _S6; - - vec4 _S7 = (imageLoad((gBlock_explicitFormat_0), ivec2((C_0.index_0)))); - vec4 result_2 = result_1 + _S7; - - vec4 _S8 = (imageLoad((entryPointParams_noFormat_0), ivec2((C_0.index_0)))); - vec4 result_3 = result_2 + _S8; - - vec4 _S9 = (imageLoad((entryPointParams_explicitFormat_0), ivec2((C_0.index_0)))); - main_0 = result_3 + _S9; - - return; -} diff --git a/tests/cross-compile/vector-comparison.slang b/tests/cross-compile/vector-comparison.slang index f363eb40c..a018dc940 100644 --- a/tests/cross-compile/vector-comparison.slang +++ b/tests/cross-compile/vector-comparison.slang @@ -1,10 +1,17 @@ // vector-comparison.slang -//TEST:CROSS_COMPILE:-target spirv-assembly -entry main -stage fragment -Wno-use-of-non-short-circuiting-operator +//TEST:SIMPLE(filecheck=CHECK):-target spirv-assembly -entry main -stage fragment -Wno-use-of-non-short-circuiting-operator // This test ensures that we cross-compile vector comparison operators // correctly to GLSL +// CHECK: OpFOrdEqual %v4bool +// CHECK: OpFOrdLessThan %v4bool +// CHECK: OpFOrdGreaterThan %v4bool +// CHECK: OpFOrdLessThanEqual %v4bool +// CHECK: OpFOrdGreaterThanEqual %v4bool +// CHECK: OpFUnordNotEqual %v4bool + struct Param { float4 a, b; diff --git a/tests/cross-compile/vector-comparison.slang.glsl b/tests/cross-compile/vector-comparison.slang.glsl deleted file mode 100644 index f3f103678..000000000 --- a/tests/cross-compile/vector-comparison.slang.glsl +++ /dev/null @@ -1,26 +0,0 @@ -#version 450 -layout(row_major) uniform; -layout(row_major) buffer; -struct Param_0 -{ - vec4 a_0; - vec4 b_0; -}; - -layout(binding = 0) -layout(std140) uniform _S1 -{ - vec4 a_0; - vec4 b_0; -} params_0; -layout(location = 0) -out vec4 main_0; - -void main() -{ - - const vec4 _S3 = vec4(2.0); - const vec4 _S4 = vec4(3.0); - main_0 = mix(_S4, _S3, (equal(params_0.a_0,params_0.b_0))) + mix(_S4, _S3, (lessThan(params_0.a_0,params_0.b_0))) + mix(_S4, _S3, (greaterThan(params_0.a_0,params_0.b_0))) + mix(_S4, _S3, (lessThanEqual(params_0.a_0,params_0.b_0))) + mix(_S4, _S3, (greaterThanEqual(params_0.a_0,params_0.b_0))) + mix(_S4, _S3, (notEqual(params_0.a_0,params_0.b_0))); - return; -} diff --git a/tests/cross-compile/vk-push-constant-set.slang b/tests/cross-compile/vk-push-constant-set.slang index ee9c68ed8..362db59ec 100644 --- a/tests/cross-compile/vk-push-constant-set.slang +++ b/tests/cross-compile/vk-push-constant-set.slang @@ -5,7 +5,7 @@ // parameters and shifting a parameer block over to // `space=1`. -//TEST:CROSS_COMPILE:-target spirv-assembly -entry main -stage fragment +//TEST:SIMPLE(filecheck=CHECK):-target spirv-assembly -entry main -stage fragment struct S { @@ -15,6 +15,9 @@ struct S [[vk::push_constant]] ConstantBuffer<S> x; +// CHECK: OpDecorate %y Binding 0 +// CHECK: OpDecorate %y DescriptorSet 0 + ParameterBlock<S> y; float4 main() : SV_Target diff --git a/tests/diagnostics/constant-buffer-unsized.slang b/tests/diagnostics/constant-buffer-unsized.slang new file mode 100644 index 000000000..25644e803 --- /dev/null +++ b/tests/diagnostics/constant-buffer-unsized.slang @@ -0,0 +1,21 @@ +//TEST:SIMPLE(filecheck=CHECK): -target spirv + +struct T2 { + float4 _m0; +}; + +[[vk::binding(0)]] +cbuffer ubo : register(b0) +{ + int in_val; + // CHECK: ([[# @LINE+1]]): error 31215 + T2 _z0[]; // error 31215: cannot use unsized type 'T2[]' in a constant buffer. +} + +[shader("fragment")] +float4 main() : SV_TARGET +{ + uint x = in_val; + float4 data = _z0[x]._m0; + return data; +}
\ No newline at end of file diff --git a/tests/hlsl/raster-order-resource.slang b/tests/hlsl/raster-order-resource.slang index 2db9f31dc..099234af7 100644 --- a/tests/hlsl/raster-order-resource.slang +++ b/tests/hlsl/raster-order-resource.slang @@ -14,7 +14,7 @@ RasterizerOrderedByteAddressBuffer buffer; [shader("fragment")] float4 fragMain() : SV_Target { - // SPIRV: %fragMain_0 = OpFunction + // SPIRV: %fragMain{{.*}} = OpFunction // SPIRV: OpBeginInvocationInterlockEXT // SPIRV: OpEndInvocationInterlockEXT @@ -27,7 +27,7 @@ RasterizerOrderedTexture2D tex; [shader("fragment")] float4 fragMain2() : SV_Target { - // SPIRV: %fragMain2_0 = OpFunction + // SPIRV: %fragMain2{{.*}} = OpFunction // SPIRV: OpBeginInvocationInterlockEXT // SPIRV: OpEndInvocationInterlockEXT @@ -40,7 +40,7 @@ RasterizerOrderedStructuredBuffer<float> buffer2; [shader("fragment")] float4 fragMain3() : SV_Target { - // SPIRV: %fragMain3_0 = OpFunction + // SPIRV: %fragMain3{{.*}} = OpFunction // SPIRV: OpBeginInvocationInterlockEXT // SPIRV: OpEndInvocationInterlockEXT diff --git a/tests/spirv/block-decoration.slang b/tests/spirv/block-decoration.slang new file mode 100644 index 000000000..e6d350dcd --- /dev/null +++ b/tests/spirv/block-decoration.slang @@ -0,0 +1,18 @@ +//TEST:SIMPLE(filecheck=CHECK): -target spirv + +// Check that we don't produce duplicate `Block` decorations. + +// CHECK: OpDecorate %RWStructuredBuffer Block +// CHECK-NOT: OpDecorate %RWStructuredBuffer Block + +struct Particle { + float4 _m0; +}; + +[[vk::binding(0)]] +RWStructuredBuffer<Particle> particleOut; + +[shader("fragment")] +float4 main() : SV_TARGET { + return particleOut[0]._m0; +}
\ No newline at end of file diff --git a/tests/spirv/varying-out-index.slang b/tests/spirv/varying-out-index.slang index 6448f2266..e4c4400f5 100644 --- a/tests/spirv/varying-out-index.slang +++ b/tests/spirv/varying-out-index.slang @@ -12,9 +12,9 @@ struct PS_OUTPUT }; -// CHECK: OpDecorate %MainPS_vColor Location 0 -// CHECK: OpDecorate %MainPS_vColor2 Location 0 -// CHECK: OpDecorate %MainPS_vColor2 Index 1 +// CHECK: OpDecorate %{{.*}}MainPS_vColor Location 0 +// CHECK: OpDecorate %{{.*}}MainPS_vColor2 Location 0 +// CHECK: OpDecorate %{{.*}}MainPS_vColor2 Index 1 PS_OUTPUT MainPS() { |
