summaryrefslogtreecommitdiffstats
path: root/tests/compute/interface-param-partial-specialize.slang
diff options
context:
space:
mode:
authorYong He <yonghe@outlook.com>2020-10-04 01:40:58 -0700
committerGitHub <noreply@github.com>2020-10-04 01:40:58 -0700
commit3321df74904dfe3a11a41179b66a4c3ce5b57022 (patch)
tree2644bd8c0dcb3cdd148042745ed2fb7c51cd91ed /tests/compute/interface-param-partial-specialize.slang
parent24ecd1fa2f37f3c4949989b53562e8f85833a8f6 (diff)
Handle partial existential parameter type specialization. (#1568)
* Specialize exsitentials parameters in struct fields. * Cleanup. * Handle partial existential parameter type specialization. Co-authored-by: Yong He <yhe@nvidia.com>
Diffstat (limited to 'tests/compute/interface-param-partial-specialize.slang')
-rw-r--r--tests/compute/interface-param-partial-specialize.slang46
1 files changed, 46 insertions, 0 deletions
diff --git a/tests/compute/interface-param-partial-specialize.slang b/tests/compute/interface-param-partial-specialize.slang
new file mode 100644
index 000000000..e856e04e8
--- /dev/null
+++ b/tests/compute/interface-param-partial-specialize.slang
@@ -0,0 +1,46 @@
+// Tests generating dynamic dispatch code for a function
+// with existential-struct-typed param by specializing it
+// with __Dynamic. This verifies that the handling of
+// "partially" specializing an existential type is correct.
+
+//TEST(compute):COMPARE_COMPUTE_EX:-slang -compute -cuda
+//TEST(compute):COMPARE_COMPUTE_EX:-slang -compute -cpu
+
+[anyValueSize(8)]
+interface IInterface
+{
+ uint eval();
+}
+
+public struct Impl : IInterface
+{
+ uint val;
+ uint eval()
+ {
+ return val;
+ }
+};
+
+struct Params
+{
+ StructuredBuffer<IInterface> obj;
+};
+
+//TEST_INPUT:ubuffer(data=[0 0 0 0], stride=4):out,name=gOutputBuffer
+RWStructuredBuffer<uint> gOutputBuffer;
+
+void compute(uint tid, Params p)
+{
+ gOutputBuffer[tid] = p.obj[0].eval();
+}
+
+//TEST_INPUT: entryPointExistentialType __Dynamic
+
+[numthreads(4, 1, 1)]
+void computeMain(uint3 dispatchThreadID : SV_DispatchThreadID,
+//TEST_INPUT:ubuffer(data=[rtti(Impl) witness(Impl, IInterface) 1 0], stride=4):name=params.obj
+ uniform Params params)
+{
+ uint tid = dispatchThreadID.x;
+ compute(tid, params);
+} \ No newline at end of file