summaryrefslogtreecommitdiffstats
path: root/src/video_core
diff options
context:
space:
mode:
authorReinUsesLisp <reinuseslisp@airmail.cc>2020-12-30 06:06:22 +0100
committerReinUsesLisp <reinuseslisp@airmail.cc>2020-12-30 06:10:19 +0100
commit9106ac1e6b912d7098845c346e5465b780bd70dd (patch)
tree464269b4d06dd6263f7bd9a37ab9f3bc6ad6489d /src/video_core
parenthost_shaders: Add Vulkan assembler compute shaders (diff)
downloadyuzu-9106ac1e6b912d7098845c346e5465b780bd70dd.tar
yuzu-9106ac1e6b912d7098845c346e5465b780bd70dd.tar.gz
yuzu-9106ac1e6b912d7098845c346e5465b780bd70dd.tar.bz2
yuzu-9106ac1e6b912d7098845c346e5465b780bd70dd.tar.lz
yuzu-9106ac1e6b912d7098845c346e5465b780bd70dd.tar.xz
yuzu-9106ac1e6b912d7098845c346e5465b780bd70dd.tar.zst
yuzu-9106ac1e6b912d7098845c346e5465b780bd70dd.zip
Diffstat (limited to 'src/video_core')
-rw-r--r--src/video_core/CMakeLists.txt1
-rw-r--r--src/video_core/delayed_destruction_ring.h32
2 files changed, 33 insertions, 0 deletions
diff --git a/src/video_core/CMakeLists.txt b/src/video_core/CMakeLists.txt
index 5b73724ce..acf96f789 100644
--- a/src/video_core/CMakeLists.txt
+++ b/src/video_core/CMakeLists.txt
@@ -25,6 +25,7 @@ add_library(video_core STATIC
command_classes/vic.h
compatible_formats.cpp
compatible_formats.h
+ delayed_destruction_ring.h
dirty_flags.cpp
dirty_flags.h
dma_pusher.cpp
diff --git a/src/video_core/delayed_destruction_ring.h b/src/video_core/delayed_destruction_ring.h
new file mode 100644
index 000000000..4f1d29c04
--- /dev/null
+++ b/src/video_core/delayed_destruction_ring.h
@@ -0,0 +1,32 @@
+// Copyright 2020 yuzu Emulator Project
+// Licensed under GPLv2 or any later version
+// Refer to the license.txt file included.
+
+#pragma once
+
+#include <array>
+#include <cstddef>
+#include <utility>
+#include <vector>
+
+namespace VideoCommon {
+
+/// Container to push objects to be destroyed a few ticks in the future
+template <typename T, size_t TICKS_TO_DESTROY>
+class DelayedDestructionRing {
+public:
+ void Tick() {
+ index = (index + 1) % TICKS_TO_DESTROY;
+ elements[index].clear();
+ }
+
+ void Push(T&& object) {
+ elements[index].push_back(std::move(object));
+ }
+
+private:
+ size_t index = 0;
+ std::array<std::vector<T>, TICKS_TO_DESTROY> elements;
+};
+
+} // namespace VideoCommon