summaryrefslogtreecommitdiff
path: root/tests
diff options
context:
space:
mode:
authorjsmall-nvidia <jsmall@nvidia.com>2020-03-10 16:43:41 -0400
committerGitHub <noreply@github.com>2020-03-10 16:43:41 -0400
commitb380b1af6ba6f5f58e3841c2a5b14db7ee8c372d (patch)
tree2013ac90c39ee20e25bd08513271b5e5538dab15 /tests
parenta10d9cd8767e88a064719d71cc97144ba8b112d1 (diff)
Wave Prefix Product (#1270)
* Fix some typos. * Add wave-prefix-sum.slang test * First pass at implementing prefixSum. * Small improvments to prefixSum CUDA. * Small improvement to prefix sum. * Enable prefix sum in stdlib. * Wave prefix product without using a divide. * Split out SM6.5 Wave intrinsics. Template mechanism for do prefix calculations.
Diffstat (limited to 'tests')
-rw-r--r--tests/hlsl-intrinsic/wave-prefix-product.slang16
-rw-r--r--tests/hlsl-intrinsic/wave-prefix-product.slang.expected.txt8
2 files changed, 24 insertions, 0 deletions
diff --git a/tests/hlsl-intrinsic/wave-prefix-product.slang b/tests/hlsl-intrinsic/wave-prefix-product.slang
new file mode 100644
index 000000000..bc324ed7d
--- /dev/null
+++ b/tests/hlsl-intrinsic/wave-prefix-product.slang
@@ -0,0 +1,16 @@
+//DISABLE_TEST(compute):COMPARE_COMPUTE_EX:-cpu -compute
+//DISABLE_TEST(compute):COMPARE_COMPUTE_EX:-slang -compute
+//TEST(compute):COMPARE_COMPUTE_EX:-slang -compute -dx12 -use-dxil -profile cs_6_0
+//TEST(compute, vulkan):COMPARE_COMPUTE_EX:-vk -compute
+//TEST(compute):COMPARE_COMPUTE_EX:-cuda -compute
+
+//TEST_INPUT:ubuffer(data=[0 0 0 0 0 0 0 0], stride=4):out,name outputBuffer
+RWStructuredBuffer<int> outputBuffer;
+
+[numthreads(8, 1, 1)]
+void computeMain(uint3 dispatchThreadID : SV_DispatchThreadID)
+{
+ int idx = int(dispatchThreadID.x);
+ int val = WavePrefixProduct(idx + 1);
+ outputBuffer[idx] = val;
+} \ No newline at end of file
diff --git a/tests/hlsl-intrinsic/wave-prefix-product.slang.expected.txt b/tests/hlsl-intrinsic/wave-prefix-product.slang.expected.txt
new file mode 100644
index 000000000..03cb63ab9
--- /dev/null
+++ b/tests/hlsl-intrinsic/wave-prefix-product.slang.expected.txt
@@ -0,0 +1,8 @@
+1
+1
+2
+6
+18
+78
+2D0
+13B0