summaryrefslogtreecommitdiffstats
path: root/src/video_core/texture_cache
diff options
context:
space:
mode:
authorbunnei <bunneidev@gmail.com>2021-11-18 20:30:47 +0100
committerGitHub <noreply@github.com>2021-11-18 20:30:47 +0100
commit0bc46fedd617f6a42c53716680ed99d8f42bf99a (patch)
treeaec333a588d638492cca77d7814cdc5379d2b6c0 /src/video_core/texture_cache
parentMerge pull request #7353 from v1993/no-more-epilepsy (diff)
parentgl_texture_cache: Round format conversion PBO to next power of 2 (diff)
downloadyuzu-0bc46fedd617f6a42c53716680ed99d8f42bf99a.tar
yuzu-0bc46fedd617f6a42c53716680ed99d8f42bf99a.tar.gz
yuzu-0bc46fedd617f6a42c53716680ed99d8f42bf99a.tar.bz2
yuzu-0bc46fedd617f6a42c53716680ed99d8f42bf99a.tar.lz
yuzu-0bc46fedd617f6a42c53716680ed99d8f42bf99a.tar.xz
yuzu-0bc46fedd617f6a42c53716680ed99d8f42bf99a.tar.zst
yuzu-0bc46fedd617f6a42c53716680ed99d8f42bf99a.zip
Diffstat (limited to '')
-rw-r--r--src/video_core/texture_cache/texture_cache.h3
-rw-r--r--src/video_core/texture_cache/texture_cache_base.h2
2 files changed, 5 insertions, 0 deletions
diff --git a/src/video_core/texture_cache/texture_cache.h b/src/video_core/texture_cache/texture_cache.h
index 4d2874bf2..241f71a91 100644
--- a/src/video_core/texture_cache/texture_cache.h
+++ b/src/video_core/texture_cache/texture_cache.h
@@ -1759,6 +1759,9 @@ void TextureCache<P>::CopyImage(ImageId dst_id, ImageId src_id, std::vector<Imag
}
UNIMPLEMENTED_IF(dst.info.type != ImageType::e2D);
UNIMPLEMENTED_IF(src.info.type != ImageType::e2D);
+ if constexpr (HAS_PIXEL_FORMAT_CONVERSIONS) {
+ return runtime.ConvertImage(dst, src, copies);
+ }
for (const ImageCopy& copy : copies) {
UNIMPLEMENTED_IF(copy.dst_subresource.num_layers != 1);
UNIMPLEMENTED_IF(copy.src_subresource.num_layers != 1);
diff --git a/src/video_core/texture_cache/texture_cache_base.h b/src/video_core/texture_cache/texture_cache_base.h
index 643ad811c..a9504c0e8 100644
--- a/src/video_core/texture_cache/texture_cache_base.h
+++ b/src/video_core/texture_cache/texture_cache_base.h
@@ -59,6 +59,8 @@ class TextureCache {
static constexpr bool HAS_EMULATED_COPIES = P::HAS_EMULATED_COPIES;
/// True when the API can provide info about the memory of the device.
static constexpr bool HAS_DEVICE_MEMORY_INFO = P::HAS_DEVICE_MEMORY_INFO;
+ /// True when the API provides utilities for pixel format conversions.
+ static constexpr bool HAS_PIXEL_FORMAT_CONVERSIONS = P::HAS_PIXEL_FORMAT_CONVERSIONS;
static constexpr u64 DEFAULT_EXPECTED_MEMORY = 1_GiB;
static constexpr u64 DEFAULT_CRITICAL_MEMORY = 2_GiB;