summaryrefslogtreecommitdiffstats
path: root/tests/diagnostics/array-parameterblock-struct.slang
diff options
context:
space:
mode:
authorEllie Hermaszewska <ellieh@nvidia.com>2025-10-13 23:14:45 +0900
committerGitHub <noreply@github.com>2025-10-13 22:14:45 +0800
commit96df31a9fa53e3d897a2b7c4eef021f37f421c91 (patch)
tree46cfb983265ce63b619da3b18004d2c163371d2c /tests/diagnostics/array-parameterblock-struct.slang
parentf5a3a6dc6a98d22964154f809f9e0dcae30ab67f (diff)
Fix segfault on arrays of structs containing parameter blocks (#8555)
Closes https://github.com/shader-slang/slang/issues/8154 However there is further design work to do on implementing the "NonAddressableType" suggestion
Diffstat (limited to 'tests/diagnostics/array-parameterblock-struct.slang')
-rw-r--r--tests/diagnostics/array-parameterblock-struct.slang21
1 files changed, 21 insertions, 0 deletions
diff --git a/tests/diagnostics/array-parameterblock-struct.slang b/tests/diagnostics/array-parameterblock-struct.slang
new file mode 100644
index 000000000..5723ce709
--- /dev/null
+++ b/tests/diagnostics/array-parameterblock-struct.slang
@@ -0,0 +1,21 @@
+//DIAGNOSTIC_TEST:SIMPLE(filecheck=CHECK):
+
+// Test: Array of struct containing ParameterBlock - should error
+
+struct StructWithParameterBlock
+{
+ ParameterBlock<float> pb;
+ int other;
+}
+
+RWStructuredBuffer<float> outputBuffer;
+
+[numthreads(4, 1, 1)]
+void computeMain(uint3 dispatchThreadID : SV_DispatchThreadID)
+{
+ // Force usage of the array to prevent optimization
+ outputBuffer[dispatchThreadID.x] = arrayOfStructWithPB[dispatchThreadID.x % 3].pb;
+}
+
+//CHECK: ([[# @LINE+1]]): error 30027
+uniform StructWithParameterBlock arrayOfStructWithPB[3]; \ No newline at end of file