From 1148564b9cdbbc8fec4fbecf65b0af60aa6af344 Mon Sep 17 00:00:00 2001 From: jsmall-nvidia Date: Wed, 18 May 2022 10:09:28 -0400 Subject: Support for `[[vk::spirv_instruction(op)]]` (#2242) * #include an absolute path didn't work - because paths were taken to always be relative. * Add extension required by SPIRVOpDecoration into part of emit (could be a prior pass). * Add [[vk::spirv_instruction]] attribute * Add documentation for [[vk::spirv_instruction]. * Update 08-attributes.md * Update 08-attributes.md --- tests/spirv/spirv-instruction.slang | 17 +++++++++++++++++ tests/spirv/spirv-instruction.slang.expected.txt | 4 ++++ 2 files changed, 21 insertions(+) create mode 100644 tests/spirv/spirv-instruction.slang create mode 100644 tests/spirv/spirv-instruction.slang.expected.txt (limited to 'tests') diff --git a/tests/spirv/spirv-instruction.slang b/tests/spirv/spirv-instruction.slang new file mode 100644 index 000000000..1f85479f9 --- /dev/null +++ b/tests/spirv/spirv-instruction.slang @@ -0,0 +1,17 @@ +// spirv-instruction.slang +//TEST(compute, vulkan):COMPARE_COMPUTE_EX:-vk -compute + +// Test using a spirv op. 128 is SpvOpIAdd + +[[vk::spirv_instruction(128)]] +uint add(uint a, uint b); + +//TEST_INPUT:set resultBuffer = out ubuffer(data=[0 0 0 0], stride=4) +RWStructuredBuffer resultBuffer; + +[numthreads(4,1,1)] +void computeMain(uint3 dispatchThreadID : SV_DispatchThreadID) +{ + uint threadId = dispatchThreadID.x; + resultBuffer[threadId] = add(threadId, threadId); +} diff --git a/tests/spirv/spirv-instruction.slang.expected.txt b/tests/spirv/spirv-instruction.slang.expected.txt new file mode 100644 index 000000000..e1e8ccec4 --- /dev/null +++ b/tests/spirv/spirv-instruction.slang.expected.txt @@ -0,0 +1,4 @@ +0 +2 +4 +6 -- cgit v1.2.3