From ea4ebe39663f12f6ffbe4378ed6a8c7cba6a3e8a Mon Sep 17 00:00:00 2001 From: ArielG-NV <159081215+ArielG-NV@users.noreply.github.com> Date: Fri, 28 Jun 2024 19:44:02 -0400 Subject: Nested initialization list in struct crash fix (#4491) --- .../nested-empty-initializer-list.slang | 25 ++++++++++++++++++++++ 1 file changed, 25 insertions(+) create mode 100644 tests/language-feature/nested-empty-initializer-list.slang (limited to 'tests') diff --git a/tests/language-feature/nested-empty-initializer-list.slang b/tests/language-feature/nested-empty-initializer-list.slang new file mode 100644 index 000000000..4b1d9cd79 --- /dev/null +++ b/tests/language-feature/nested-empty-initializer-list.slang @@ -0,0 +1,25 @@ +//TEST(compute):COMPARE_COMPUTE(filecheck-buffer=BUF):-shaderobj +//TEST(compute):COMPARE_COMPUTE(filecheck-buffer=BUF):-dx12 -use-dxil -shaderobj +//TEST(compute):COMPARE_COMPUTE(filecheck-buffer=BUF):-cpu -shaderobj +//TEST(compute):COMPARE_COMPUTE(filecheck-buffer=BUF):-vk -shaderobj + +//TEST_INPUT:ubuffer(data=[0], stride=4):out,name=outputBuffer +RWStructuredBuffer outputBuffer; + +struct NestedStruct +{ + int data; +}; + +struct TopStruct +{ + NestedStruct nestedStruct = {}; +} + +[numthreads(1, 1, 1)] +void computeMain(uint3 dispatchThreadID : SV_DispatchThreadID) +{ + TopStruct val = {}; +// BUF: 1 + outputBuffer[0] = val.nestedStruct.data == 0; +} -- cgit v1.2.3