summaryrefslogtreecommitdiff
path: root/tests/spirv/bit-field.slang
diff options
context:
space:
mode:
authorYong He <yonghe@outlook.com>2023-09-26 23:56:06 -0700
committerGitHub <noreply@github.com>2023-09-27 14:56:06 +0800
commitebe8ddefc48478307d5f206cd3e40c41d28a36e3 (patch)
tree8e13977979909a26394eea532d8b95cd5ad0f6d1 /tests/spirv/bit-field.slang
parentc5c8cfbb360d9a763f549df48636effde839eacd (diff)
Various SPIRV fixes. (#3231)
* Various SPIRV fixes. - Geometry shader support (WIP). - Fix texture get dimension and load. - Fold global GetElement(MakeArray/MakeVector) insts. - Call spvopt to inline all functions. - Translate OpImageSubscript. - Emit struct member names and global variable names. - Fix lowering of OpBitNot -> OpNot, instead of OpBitReverse. * Fix test. * Fix geometry shader. * Fix geometry shader emit. * Add atomic Image access test. * Fix tests. * don't fail if spirv-opt fails. * Update comments. * Fix test. * Cleanups. * indentation --------- Co-authored-by: Yong He <yhe@nvidia.com> Co-authored-by: Ellie Hermaszewska <ellieh@nvidia.com>
Diffstat (limited to 'tests/spirv/bit-field.slang')
-rw-r--r--tests/spirv/bit-field.slang54
1 files changed, 54 insertions, 0 deletions
diff --git a/tests/spirv/bit-field.slang b/tests/spirv/bit-field.slang
new file mode 100644
index 000000000..878b4483d
--- /dev/null
+++ b/tests/spirv/bit-field.slang
@@ -0,0 +1,54 @@
+// bit-field.slang
+
+//TEST(compute, vulkan):COMPARE_COMPUTE_EX(filecheck-buffer=BUFFER):-vk -compute -output-using-type
+
+// Test direct SPIR-V emit on bit field operations.
+
+//TEST_INPUT:set resultBuffer = out ubuffer(data=[0 0 0 0], stride=4)
+RWStructuredBuffer<uint> resultBuffer;
+
+enum Flag
+{
+ AAA = 1,
+ BBB = 2,
+ CCC = 4,
+}
+struct Data
+{
+ uint flags;
+ [mutating] void setFlag(Flag g, bool v)
+ {
+ const uint bit = uint(g) << 8;
+ if (v) flags |= bit;
+ else flags &= ~bit;
+ }
+ bool hasFlag(Flag g)
+ {
+ const uint bit = uint(g) << 8;
+ return (flags & bit) != 0;
+ }
+}
+
+//TEST_INPUT: set Uniforms.d = new Data{0};
+cbuffer Uniforms
+{
+ Data d;
+}
+
+// BUFFER: 1
+// BUFFER: 1
+// BUFFER: 1
+// BUFFER: 0
+
+[numthreads(1,1,1)]
+void computeMain(uint3 dispatchThreadID : SV_DispatchThreadID)
+{
+ Data d1 = d;
+ d1.setFlag(Flag.BBB, true);
+ d1.setFlag(Flag.AAA, true);
+ resultBuffer[0] = d1.hasFlag(Flag.AAA) ? 1 : 0;
+ resultBuffer[1] = d1.hasFlag(Flag.BBB) ? 1 : 0;
+ d1.setFlag(Flag.BBB, false);
+ resultBuffer[2] = d1.hasFlag(Flag.AAA) ? 1 : 0;
+ resultBuffer[3] = d1.hasFlag(Flag.BBB) ? 1 : 0;
+}