summaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
Diffstat (limited to 'src')
-rw-r--r--src/video_core/renderer_opengl/gl_texture_cache.cpp4
-rw-r--r--src/video_core/renderer_opengl/gl_texture_cache.h16
-rw-r--r--src/video_core/renderer_vulkan/vk_texture_cache.cpp4
-rw-r--r--src/video_core/renderer_vulkan/vk_texture_cache.h16
-rw-r--r--src/video_core/texture_cache/texture_cache.h3
5 files changed, 43 insertions, 0 deletions
diff --git a/src/video_core/renderer_opengl/gl_texture_cache.cpp b/src/video_core/renderer_opengl/gl_texture_cache.cpp
index 1d3f193af..30dfcfa6a 100644
--- a/src/video_core/renderer_opengl/gl_texture_cache.cpp
+++ b/src/video_core/renderer_opengl/gl_texture_cache.cpp
@@ -1117,6 +1117,8 @@ ImageView::ImageView(TextureCacheRuntime&, const VideoCommon::ImageInfo& info,
1117ImageView::ImageView(TextureCacheRuntime& runtime, const VideoCommon::NullImageViewParams& params) 1117ImageView::ImageView(TextureCacheRuntime& runtime, const VideoCommon::NullImageViewParams& params)
1118 : VideoCommon::ImageViewBase{params}, views{runtime.null_image_views} {} 1118 : VideoCommon::ImageViewBase{params}, views{runtime.null_image_views} {}
1119 1119
1120ImageView::~ImageView() = default;
1121
1120GLuint ImageView::StorageView(Shader::TextureType texture_type, Shader::ImageFormat image_format) { 1122GLuint ImageView::StorageView(Shader::TextureType texture_type, Shader::ImageFormat image_format) {
1121 if (image_format == Shader::ImageFormat::Typeless) { 1123 if (image_format == Shader::ImageFormat::Typeless) {
1122 return Handle(texture_type); 1124 return Handle(texture_type);
@@ -1272,6 +1274,8 @@ Framebuffer::Framebuffer(TextureCacheRuntime& runtime, std::span<ImageView*, NUM
1272 } 1274 }
1273} 1275}
1274 1276
1277Framebuffer::~Framebuffer() = default;
1278
1275void BGRCopyPass::CopyBGR(Image& dst_image, Image& src_image, 1279void BGRCopyPass::CopyBGR(Image& dst_image, Image& src_image,
1276 std::span<const VideoCommon::ImageCopy> copies) { 1280 std::span<const VideoCommon::ImageCopy> copies) {
1277 static constexpr VideoCommon::Offset3D zero_offset{0, 0, 0}; 1281 static constexpr VideoCommon::Offset3D zero_offset{0, 0, 0};
diff --git a/src/video_core/renderer_opengl/gl_texture_cache.h b/src/video_core/renderer_opengl/gl_texture_cache.h
index c51a7428d..a717cf8c8 100644
--- a/src/video_core/renderer_opengl/gl_texture_cache.h
+++ b/src/video_core/renderer_opengl/gl_texture_cache.h
@@ -232,6 +232,14 @@ public:
232 const VideoCommon::ImageViewInfo& view_info); 232 const VideoCommon::ImageViewInfo& view_info);
233 explicit ImageView(TextureCacheRuntime&, const VideoCommon::NullImageViewParams&); 233 explicit ImageView(TextureCacheRuntime&, const VideoCommon::NullImageViewParams&);
234 234
235 ~ImageView();
236
237 ImageView(const ImageView&) = delete;
238 ImageView& operator=(const ImageView&) = delete;
239
240 ImageView(ImageView&&) = default;
241 ImageView& operator=(ImageView&&) = default;
242
235 [[nodiscard]] GLuint StorageView(Shader::TextureType texture_type, 243 [[nodiscard]] GLuint StorageView(Shader::TextureType texture_type,
236 Shader::ImageFormat image_format); 244 Shader::ImageFormat image_format);
237 245
@@ -300,6 +308,14 @@ public:
300 explicit Framebuffer(TextureCacheRuntime&, std::span<ImageView*, NUM_RT> color_buffers, 308 explicit Framebuffer(TextureCacheRuntime&, std::span<ImageView*, NUM_RT> color_buffers,
301 ImageView* depth_buffer, const VideoCommon::RenderTargets& key); 309 ImageView* depth_buffer, const VideoCommon::RenderTargets& key);
302 310
311 ~Framebuffer();
312
313 Framebuffer(const Framebuffer&) = delete;
314 Framebuffer& operator=(const Framebuffer&) = delete;
315
316 Framebuffer(Framebuffer&&) = default;
317 Framebuffer& operator=(Framebuffer&&) = default;
318
303 [[nodiscard]] GLuint Handle() const noexcept { 319 [[nodiscard]] GLuint Handle() const noexcept {
304 return framebuffer.handle; 320 return framebuffer.handle;
305 } 321 }
diff --git a/src/video_core/renderer_vulkan/vk_texture_cache.cpp b/src/video_core/renderer_vulkan/vk_texture_cache.cpp
index daf26f380..407fd2a15 100644
--- a/src/video_core/renderer_vulkan/vk_texture_cache.cpp
+++ b/src/video_core/renderer_vulkan/vk_texture_cache.cpp
@@ -1366,6 +1366,8 @@ ImageView::ImageView(TextureCacheRuntime&, const VideoCommon::ImageInfo& info,
1366ImageView::ImageView(TextureCacheRuntime&, const VideoCommon::NullImageViewParams& params) 1366ImageView::ImageView(TextureCacheRuntime&, const VideoCommon::NullImageViewParams& params)
1367 : VideoCommon::ImageViewBase{params} {} 1367 : VideoCommon::ImageViewBase{params} {}
1368 1368
1369ImageView::~ImageView() = default;
1370
1369VkImageView ImageView::DepthView() { 1371VkImageView ImageView::DepthView() {
1370 if (depth_view) { 1372 if (depth_view) {
1371 return *depth_view; 1373 return *depth_view;
@@ -1492,6 +1494,8 @@ Framebuffer::Framebuffer(TextureCacheRuntime& runtime, ImageView* color_buffer,
1492 CreateFramebuffer(runtime, color_buffers, depth_buffer); 1494 CreateFramebuffer(runtime, color_buffers, depth_buffer);
1493} 1495}
1494 1496
1497Framebuffer::~Framebuffer() = default;
1498
1495void Framebuffer::CreateFramebuffer(TextureCacheRuntime& runtime, 1499void Framebuffer::CreateFramebuffer(TextureCacheRuntime& runtime,
1496 std::span<ImageView*, NUM_RT> color_buffers, 1500 std::span<ImageView*, NUM_RT> color_buffers,
1497 ImageView* depth_buffer) { 1501 ImageView* depth_buffer) {
diff --git a/src/video_core/renderer_vulkan/vk_texture_cache.h b/src/video_core/renderer_vulkan/vk_texture_cache.h
index 9d149d306..ff28b4e96 100644
--- a/src/video_core/renderer_vulkan/vk_texture_cache.h
+++ b/src/video_core/renderer_vulkan/vk_texture_cache.h
@@ -162,6 +162,14 @@ public:
162 const VideoCommon::ImageViewInfo&, GPUVAddr); 162 const VideoCommon::ImageViewInfo&, GPUVAddr);
163 explicit ImageView(TextureCacheRuntime&, const VideoCommon::NullImageViewParams&); 163 explicit ImageView(TextureCacheRuntime&, const VideoCommon::NullImageViewParams&);
164 164
165 ~ImageView();
166
167 ImageView(const ImageView&) = delete;
168 ImageView& operator=(const ImageView&) = delete;
169
170 ImageView(ImageView&&) = default;
171 ImageView& operator=(ImageView&&) = default;
172
165 [[nodiscard]] VkImageView DepthView(); 173 [[nodiscard]] VkImageView DepthView();
166 174
167 [[nodiscard]] VkImageView StencilView(); 175 [[nodiscard]] VkImageView StencilView();
@@ -235,6 +243,14 @@ public:
235 explicit Framebuffer(TextureCacheRuntime& runtime, ImageView* color_buffer, 243 explicit Framebuffer(TextureCacheRuntime& runtime, ImageView* color_buffer,
236 ImageView* depth_buffer, VkExtent2D extent); 244 ImageView* depth_buffer, VkExtent2D extent);
237 245
246 ~Framebuffer();
247
248 Framebuffer(const Framebuffer&) = delete;
249 Framebuffer& operator=(const Framebuffer&) = delete;
250
251 Framebuffer(Framebuffer&&) = default;
252 Framebuffer& operator=(Framebuffer&&) = default;
253
238 void CreateFramebuffer(TextureCacheRuntime& runtime, 254 void CreateFramebuffer(TextureCacheRuntime& runtime,
239 std::span<ImageView*, NUM_RT> color_buffers, ImageView* depth_buffer); 255 std::span<ImageView*, NUM_RT> color_buffers, ImageView* depth_buffer);
240 256
diff --git a/src/video_core/texture_cache/texture_cache.h b/src/video_core/texture_cache/texture_cache.h
index aec130a32..4d2874bf2 100644
--- a/src/video_core/texture_cache/texture_cache.h
+++ b/src/video_core/texture_cache/texture_cache.h
@@ -1620,6 +1620,9 @@ void TextureCache<P>::RemoveFramebuffers(std::span<const ImageViewId> removed_vi
1620 auto it = framebuffers.begin(); 1620 auto it = framebuffers.begin();
1621 while (it != framebuffers.end()) { 1621 while (it != framebuffers.end()) {
1622 if (it->first.Contains(removed_views)) { 1622 if (it->first.Contains(removed_views)) {
1623 auto framebuffer_id = it->second;
1624 ASSERT(framebuffer_id);
1625 sentenced_framebuffers.Push(std::move(slot_framebuffers[framebuffer_id]));
1623 it = framebuffers.erase(it); 1626 it = framebuffers.erase(it);
1624 } else { 1627 } else {
1625 ++it; 1628 ++it;