From 4c6b0a2831a7edd1419bd0b2e6edd089080e07be Mon Sep 17 00:00:00 2001 From: Yong He Date: Wed, 31 Jul 2024 17:35:08 -0700 Subject: Allow generic type deduction from ParameterBlock arguments. (#4766) * Allow generic type deduction from ParameterBlock arguments. * Fix test. * Update expected failure list. --------- Co-authored-by: Yong He --- tests/expected-failure-github.txt | 2 -- .../generics/parameter-block-unify.slang | 33 ++++++++++++++++++++++ 2 files changed, 33 insertions(+), 2 deletions(-) create mode 100644 tests/language-feature/generics/parameter-block-unify.slang (limited to 'tests') diff --git a/tests/expected-failure-github.txt b/tests/expected-failure-github.txt index f157d2b9a..524930f62 100644 --- a/tests/expected-failure-github.txt +++ b/tests/expected-failure-github.txt @@ -5,5 +5,3 @@ tests/language-feature/saturated-cooperation/fuse-product.slang (vk) tests/language-feature/saturated-cooperation/fuse.slang (vk) tests/bugs/byte-address-buffer-interlocked-add-f32.slang (vk) tests/serialization/obfuscated-serialized-module-test.slang.2 syn (mtl) -tests/render/cross-compile-entry-point.slang.2 syn (mtl) -tests/bindings/nested-parameter-block-2.slang.3 syn (mtl) diff --git a/tests/language-feature/generics/parameter-block-unify.slang b/tests/language-feature/generics/parameter-block-unify.slang new file mode 100644 index 000000000..b549f555b --- /dev/null +++ b/tests/language-feature/generics/parameter-block-unify.slang @@ -0,0 +1,33 @@ +//TEST(compute):COMPARE_COMPUTE_EX(filecheck-buffer=CHECK):-slang -compute -shaderobj -output-using-type +//TEST(compute, vulkan):COMPARE_COMPUTE_EX(filecheck-buffer=CHECK):-vk -compute -shaderobj -output-using-type +//TEST(compute, vulkan):COMPARE_COMPUTE_EX(filecheck-buffer=CHECK):-mtl -compute -shaderobj -output-using-type -render-features argument-buffer-tier-2 + +struct TestStruct +{ + Format f; +}; + +Format testFunction(TestStruct data) +{ + return data.f + __int_cast(count); +} + +//TEST_INPUT: set testBlock = new TestStruct{1} +ParameterBlock> testBlock; + +//TEST_INPUT: set testBlock2 = new TestStruct{2} +ConstantBuffer> testBlock2; + +//TEST_INPUT: set outputBuffer = out ubuffer(data=[0 0 0 0], stride=4) +RWStructuredBuffer outputBuffer; + +[numthreads(1, 1, 1)] +void computeMain(uint3 dispatchThreadID : SV_DispatchThreadID) +{ + // CHECK: 13 + outputBuffer[0] = testFunction(testBlock); + // CHECK: 13 + outputBuffer[1] = testFunction(testBlock); + // CHECK: 4 + outputBuffer[2] = testFunction(testBlock2); +} \ No newline at end of file -- cgit v1.2.3