diff --git a/external/slang-rhi b/external/slang-rhi index 3bb34bb0c2..5b77d09cea 160000 --- a/external/slang-rhi +++ b/external/slang-rhi @@ -1 +1 @@ -Subproject commit 3bb34bb0c2e75e4f75dc4f180071111592b86bab +Subproject commit 5b77d09cea9a309b98b65469e8438835d972caca diff --git a/source/slang/slang-check-shader.cpp b/source/slang/slang-check-shader.cpp index 52a70034a8..50382f9c12 100644 --- a/source/slang/slang-check-shader.cpp +++ b/source/slang/slang-check-shader.cpp @@ -79,15 +79,6 @@ static void _collectExistentialSpecializationParamsRec( loc); return; } - else if (auto structuredBufferType = as(type)) - { - _collectExistentialSpecializationParamsRec( - astBuilder, - ioSpecializationParams, - structuredBufferType->getElementType(), - loc); - return; - } if (auto declRefType = as(type)) { diff --git a/source/slang/slang-mangle.cpp b/source/slang/slang-mangle.cpp index 4257f5dc2b..7d45874808 100644 --- a/source/slang/slang-mangle.cpp +++ b/source/slang/slang-mangle.cpp @@ -817,6 +817,7 @@ String getMangledTypeName(ASTBuilder* astBuilder, Type* type) { SLANG_AST_BUILDER_RAII(astBuilder); ManglingContext context(astBuilder); + emitRaw(&context, "_ST"); emitType(&context, type); return context.sb.produceString(); } diff --git a/tests/bugs/dyn-dispatch-single-conformance.slang b/tests/bugs/dyn-dispatch-single-conformance.slang new file mode 100644 index 0000000000..eae0fee07f --- /dev/null +++ b/tests/bugs/dyn-dispatch-single-conformance.slang @@ -0,0 +1,27 @@ +//TEST:COMPARE_COMPUTE(filecheck-buffer=CHECK): -output-using-type + +interface IFoo +{ + float3 get(); +} + +struct Foo : IFoo +{ + float3 val; + float3 get() { return val; } +}; + +//TEST_INPUT: type_conformance Foo:IFoo=0 + +//TEST_INPUT:set foo = ubuffer(data=[0 0 0 0 1.0 2.0 3.0 0.0], stride=4) +StructuredBuffer foo; + +//TEST_INPUT:ubuffer(data=[0 0 0 0], stride=4):out,name=outputBuffer +RWStructuredBuffer outputBuffer; + +[numthreads(1,1,1)] +void computeMain() +{ + // CHECK: 1.0 + outputBuffer[0] = foo[0].get().x; +} \ No newline at end of file diff --git a/tests/compute/dynamic-dispatch-13.slang b/tests/compute/dynamic-dispatch-13.slang index 20d78e0ad6..eff5218a0e 100644 --- a/tests/compute/dynamic-dispatch-13.slang +++ b/tests/compute/dynamic-dispatch-13.slang @@ -17,7 +17,6 @@ interface IInterface RWStructuredBuffer gOutputBuffer; //TEST_INPUT: set gCb = new StructuredBuffer{new MyImpl{1}}; RWStructuredBuffer gCb; -// Add two elements into the structured buffer to prevent specialization. //TEST_INPUT: set gCb1 = new StructuredBuffer{new MyImpl{1}, new MyImpl2{2}}; RWStructuredBuffer gCb1; diff --git a/tests/compute/dynamic-dispatch-14.slang b/tests/compute/dynamic-dispatch-14.slang index 641fe938c8..16703aa2a0 100644 --- a/tests/compute/dynamic-dispatch-14.slang +++ b/tests/compute/dynamic-dispatch-14.slang @@ -23,12 +23,10 @@ interface IInterface //TEST_INPUT:ubuffer(data=[0 0 0 0], stride=4):out,name=gOutputBuffer RWStructuredBuffer gOutputBuffer; - -// Specialize gCb1, but not gCb2 //TEST_INPUT: set gCb = new StructuredBuffer{new MyImpl{1}}; RWStructuredBuffer gCb; -//TEST_INPUT: set gCb1 = dynamic new StructuredBuffer{new MyImpl{1}} +//TEST_INPUT: set gCb1 = new StructuredBuffer{new MyImpl{1}} RWStructuredBuffer gCb1; [numthreads(4, 1, 1)] diff --git a/tests/compute/dynamic-dispatch-15.slang b/tests/compute/dynamic-dispatch-15.slang index 2ab169281c..46e209a8ae 100644 --- a/tests/compute/dynamic-dispatch-15.slang +++ b/tests/compute/dynamic-dispatch-15.slang @@ -14,7 +14,7 @@ interface IInterface //TEST_INPUT:ubuffer(data=[0], stride=4):out,name=gOutputBuffer RWStructuredBuffer gOutputBuffer; -//TEST_INPUT: set gObj = dynamic new StructuredBuffer[new FloatVal{1.0}, new Float4Val{{[2.0, 3.0, 4.0, 5.0]}}, new IntVal{6}, new Int4Val{[7,8,9,10]}]; +//TEST_INPUT: set gObj = new StructuredBuffer[new FloatVal{1.0}, new Float4Val{{[2.0, 3.0, 4.0, 5.0]}}, new IntVal{6}, new Int4Val{[7,8,9,10]}]; RWStructuredBuffer gObj; [numthreads(1, 1, 1)] diff --git a/tests/compute/interface-assoc-type-param.slang b/tests/compute/interface-assoc-type-param.slang index a234d457f0..6f7443e1f4 100644 --- a/tests/compute/interface-assoc-type-param.slang +++ b/tests/compute/interface-assoc-type-param.slang @@ -16,7 +16,8 @@ interface IEval uint eval(); } -export struct Impl : IInterface +//TEST_INPUT: type_conformance Impl:IInterface = 0 +struct Impl : IInterface { uint val; struct TEval : IEval diff --git a/tests/language-feature/interfaces/empty-type-conformance.slang b/tests/language-feature/interfaces/empty-type-conformance.slang index 9fee046073..ae529a4961 100644 --- a/tests/language-feature/interfaces/empty-type-conformance.slang +++ b/tests/language-feature/interfaces/empty-type-conformance.slang @@ -1,5 +1,3 @@ -// Test that we allow empty type conformances. - //TEST(compute):COMPARE_COMPUTE_EX(filecheck-buffer=CHECK):-dx11 -compute -output-using-type //TEST(compute):COMPARE_COMPUTE_EX(filecheck-buffer=CHECK):-vk -compute -output-using-type @@ -18,6 +16,8 @@ StructuredBuffer inBuffer; //TEST_INPUT: set outputBuffer = out ubuffer(data=[0 0 0 0], stride=4); RWStructuredBuffer outputBuffer; +//TEST_INPUT: type_conformance TestImplementation:TestInterface=0 + [shader("compute")] [numthreads(1, 1, 1)] void computeMain(uint3 dispatchThreadID: SV_DispatchThreadID)