diff options
Diffstat (limited to 'src')
| -rw-r--r-- | src/video_core/renderer_opengl/gl_texture_cache.cpp | 4 | ||||
| -rw-r--r-- | src/video_core/renderer_opengl/gl_texture_cache.h | 16 | ||||
| -rw-r--r-- | src/video_core/renderer_vulkan/vk_texture_cache.cpp | 4 | ||||
| -rw-r--r-- | src/video_core/renderer_vulkan/vk_texture_cache.h | 16 | ||||
| -rw-r--r-- | src/video_core/texture_cache/texture_cache.h | 3 |
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, | |||
| 1117 | ImageView::ImageView(TextureCacheRuntime& runtime, const VideoCommon::NullImageViewParams& params) | 1117 | ImageView::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 | ||
| 1120 | ImageView::~ImageView() = default; | ||
| 1121 | |||
| 1120 | GLuint ImageView::StorageView(Shader::TextureType texture_type, Shader::ImageFormat image_format) { | 1122 | GLuint 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 | ||
| 1277 | Framebuffer::~Framebuffer() = default; | ||
| 1278 | |||
| 1275 | void BGRCopyPass::CopyBGR(Image& dst_image, Image& src_image, | 1279 | void 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, | |||
| 1366 | ImageView::ImageView(TextureCacheRuntime&, const VideoCommon::NullImageViewParams& params) | 1366 | ImageView::ImageView(TextureCacheRuntime&, const VideoCommon::NullImageViewParams& params) |
| 1367 | : VideoCommon::ImageViewBase{params} {} | 1367 | : VideoCommon::ImageViewBase{params} {} |
| 1368 | 1368 | ||
| 1369 | ImageView::~ImageView() = default; | ||
| 1370 | |||
| 1369 | VkImageView ImageView::DepthView() { | 1371 | VkImageView 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 | ||
| 1497 | Framebuffer::~Framebuffer() = default; | ||
| 1498 | |||
| 1495 | void Framebuffer::CreateFramebuffer(TextureCacheRuntime& runtime, | 1499 | void 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; |