summaryrefslogtreecommitdiffstats
path: root/src/video_core/host_shaders/vulkan_quad_indexed.comp
diff options
context:
space:
mode:
authorReinUsesLisp <reinuseslisp@airmail.cc>2020-12-30 06:03:50 +0100
committerReinUsesLisp <reinuseslisp@airmail.cc>2020-12-30 06:03:50 +0100
commit21b18057f7035e1442be20667662efba911653df (patch)
treed8d607ce81d0b78db2b1eeb07d82dbb65357f5c9 /src/video_core/host_shaders/vulkan_quad_indexed.comp
parenthost_shaders: Add helper to blit depth stencil fragment shader (diff)
downloadyuzu-21b18057f7035e1442be20667662efba911653df.tar
yuzu-21b18057f7035e1442be20667662efba911653df.tar.gz
yuzu-21b18057f7035e1442be20667662efba911653df.tar.bz2
yuzu-21b18057f7035e1442be20667662efba911653df.tar.lz
yuzu-21b18057f7035e1442be20667662efba911653df.tar.xz
yuzu-21b18057f7035e1442be20667662efba911653df.tar.zst
yuzu-21b18057f7035e1442be20667662efba911653df.zip
Diffstat (limited to 'src/video_core/host_shaders/vulkan_quad_indexed.comp')
-rw-r--r--src/video_core/host_shaders/vulkan_quad_indexed.comp41
1 files changed, 41 insertions, 0 deletions
diff --git a/src/video_core/host_shaders/vulkan_quad_indexed.comp b/src/video_core/host_shaders/vulkan_quad_indexed.comp
new file mode 100644
index 000000000..8655591d0
--- /dev/null
+++ b/src/video_core/host_shaders/vulkan_quad_indexed.comp
@@ -0,0 +1,41 @@
+// Copyright 2020 yuzu Emulator Project
+// Licensed under GPLv2 or any later version
+// Refer to the license.txt file included.
+
+#version 460 core
+
+layout (local_size_x = 1024) in;
+
+layout (std430, set = 0, binding = 0) readonly buffer InputBuffer {
+ uint input_indexes[];
+};
+
+layout (std430, set = 0, binding = 1) writeonly buffer OutputBuffer {
+ uint output_indexes[];
+};
+
+layout (push_constant) uniform PushConstants {
+ uint base_vertex;
+ int index_shift; // 0: uint8, 1: uint16, 2: uint32
+};
+
+void main() {
+ int primitive = int(gl_GlobalInvocationID.x);
+ if (primitive * 6 >= output_indexes.length()) {
+ return;
+ }
+
+ int index_size = 8 << index_shift;
+ int flipped_shift = 2 - index_shift;
+ int mask = (1 << flipped_shift) - 1;
+
+ const int quad_swizzle[6] = int[](0, 1, 2, 0, 2, 3);
+ for (uint vertex = 0; vertex < 6; ++vertex) {
+ int offset = primitive * 4 + quad_swizzle[vertex];
+ int int_offset = offset >> flipped_shift;
+ int bit_offset = (offset & mask) * index_size;
+ uint packed_input = input_indexes[int_offset];
+ uint index = bitfieldExtract(packed_input, bit_offset, index_size);
+ output_indexes[primitive * 6 + vertex] = index + base_vertex;
+ }
+}