summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--source/slang/slang-ir-loop-unroll.cpp3
-rw-r--r--tests/ir/loop-unroll-3.slang38
2 files changed, 41 insertions, 0 deletions
diff --git a/source/slang/slang-ir-loop-unroll.cpp b/source/slang/slang-ir-loop-unroll.cpp
index 5f9c53bc7..6b001a562 100644
--- a/source/slang/slang-ir-loop-unroll.cpp
+++ b/source/slang/slang-ir-loop-unroll.cpp
@@ -463,6 +463,9 @@ bool unrollLoopsInFunc(
for (auto loop : loops)
{
+ if (!loop->parent)
+ continue;
+
// Remove any continue jumps from the loop.
eliminateContinueBlocks(module, loop);
diff --git a/tests/ir/loop-unroll-3.slang b/tests/ir/loop-unroll-3.slang
new file mode 100644
index 000000000..4e5275e67
--- /dev/null
+++ b/tests/ir/loop-unroll-3.slang
@@ -0,0 +1,38 @@
+//TEST:COMPARE_COMPUTE(filecheck-buffer=CHECK): -output-using-type
+
+//TEST_INPUT:set buffer = ubuffer(data=[0 0 0 0], stride=4)
+RWStructuredBuffer<float> buffer;
+
+struct Foo<let D : int>
+{
+ float load()
+ {
+ int idx[D];
+ [ForceUnroll]
+ for (int i = 0; i < D; ++i)
+ idx[i] = 0;
+ [ForceUnroll]
+ for (int i = 0; i < D-2; ++i)
+ idx[i] = 0;
+ float result = 100.0;
+ [ForceUnroll]
+ for (int i = 0; i < 1; i++)
+ result += buffer[idx[0]];
+
+ return result;
+ }
+}
+
+//TEST_INPUT:set result = out ubuffer(data=[0 0 0 0], stride=4)
+uniform RWStructuredBuffer<float> result;
+
+[shader("compute")]
+void computeMain(uint3 dispatchThreadID: SV_DispatchThreadID)
+{
+ Foo<2> biases = {};
+
+ // Test that we can unroll loops of 0 iterations.
+ result[0] = biases.load();
+
+ // CHECK: 100.0
+} \ No newline at end of file