diff options
| author | James Helferty (NVIDIA) <jhelferty@nvidia.com> | 2025-10-08 19:11:10 -0400 |
|---|---|---|
| committer | GitHub <noreply@github.com> | 2025-10-08 23:11:10 +0000 |
| commit | 54d9b345bff4b01949e875366cb1e7cf1c021c61 (patch) | |
| tree | 374b635c94799c151f1ed98e562a9c1e194d086b /tests | |
| parent | eda080bbf7a2b48e26342df13005a40434f7d802 (diff) | |
parser: Avoid dropping modifiers when splitting list (#8546)
Fix for a linked list usage bug; avoids dropping any modifiers when
moving type modifiers from a linked list of modifiers into their own
linked list. Since this change results in no_diff modifiers to
traditional functions ending up on the return type instead of the
function (due to the order they're parsed in), we duplicate the no_diff
modifier onto the function declaration after the fact.
Includes a test for the original issue. The no_diff redistribution case
is covered by a slangpy device test case.
Fixes #8332
---------
Co-authored-by: slangbot <186143334+slangbot@users.noreply.github.com>
Diffstat (limited to 'tests')
| -rw-r--r-- | tests/autodiff/no-diff-static.slang | 31 |
1 files changed, 31 insertions, 0 deletions
diff --git a/tests/autodiff/no-diff-static.slang b/tests/autodiff/no-diff-static.slang new file mode 100644 index 000000000..15d316a90 --- /dev/null +++ b/tests/autodiff/no-diff-static.slang @@ -0,0 +1,31 @@ +//TEST(compute):COMPARE_COMPUTE_EX(filecheck-buffer=BUF):-slang -compute -output-using-type + +//TEST_INPUT:ubuffer(data=[0 0 0 0], stride=4):out,name=outputBuffer +RWStructuredBuffer<float> outputBuffer; +// BUF: 1.000000 +// BUF: 1.000000 + +struct TestStruct : IDifferentiable +{ + static const no_diff float foo = 1.0f; + + int x; + + void assignOut() + { + outputBuffer[0] = foo; + } +} +no_diff static const float foo = 1.0f; + +[shader("compute")] +[numthreads(1, 1, 1)] +void computeMain(uint thread_idx: SV_DispatchThreadID) +{ + if (thread_idx == 0) { + TestStruct t; + t.x = 10; + t.assignOut(); + } + outputBuffer[1] = foo; +} |
