From 7e2bc8e06f61d554bae9bbebc1db0302eb3f1d8a Mon Sep 17 00:00:00 2001 From: Yong He Date: Fri, 26 Jul 2024 19:42:15 -0700 Subject: Allow passing sized array to unsized array parameter. (#4744) --- tests/language-feature/unsized-array.slang | 42 ++++++++++++++++++++++++++++++ 1 file changed, 42 insertions(+) create mode 100644 tests/language-feature/unsized-array.slang (limited to 'tests') diff --git a/tests/language-feature/unsized-array.slang b/tests/language-feature/unsized-array.slang new file mode 100644 index 000000000..c4479867e --- /dev/null +++ b/tests/language-feature/unsized-array.slang @@ -0,0 +1,42 @@ +//TEST(compute):COMPARE_COMPUTE(filecheck-buffer=CHECK):-compute -output-using-type +//TEST(compute):COMPARE_COMPUTE(filecheck-buffer=CHECK):-vk -compute -output-using-type + +//TEST_INPUT:ubuffer(data=[0 0 0 0], stride=4):out,name=outputBuffer +RWStructuredBuffer outputBuffer; + +int g(int arr[]) +{ + int tmp[] = arr; + return tmp.getCount(); +} + +int test(int arr[]) +{ + return arr[0] + g(arr); +} + +int test2(inout T arr[]) +{ + return arr.getCount(); +} + +[numthreads(1, 1, 1)] +void computeMain(int3 dispatchThreadID: SV_DispatchThreadID) +{ + int arr[3] = {1, 2, 3}; + + // CHECK: 4 + outputBuffer[0] = test(arr); + + // CHECK: 3 + outputBuffer[1] = test2(arr); + + int arr2[2] = { 1, 2 }; + + // CHECK: 3 + outputBuffer[2] = test(arr2); + + // CHECK: 2 + outputBuffer[3] = test2(arr2); + +} -- cgit v1.2.3