summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorameerj <52414509+ameerj@users.noreply.github.com>2023-05-28 19:14:51 +0200
committerameerj <52414509+ameerj@users.noreply.github.com>2023-05-28 19:14:51 +0200
commitea2e155b0b95620e1cc9cc7112315f0cc80b6343 (patch)
treedf95a5dfb5596d33672ce8e6a71d15de833cbaa3
parentMerge pull request #10414 from liamwhite/anv-push-descriptor (diff)
downloadyuzu-ea2e155b0b95620e1cc9cc7112315f0cc80b6343.tar
yuzu-ea2e155b0b95620e1cc9cc7112315f0cc80b6343.tar.gz
yuzu-ea2e155b0b95620e1cc9cc7112315f0cc80b6343.tar.bz2
yuzu-ea2e155b0b95620e1cc9cc7112315f0cc80b6343.tar.lz
yuzu-ea2e155b0b95620e1cc9cc7112315f0cc80b6343.tar.xz
yuzu-ea2e155b0b95620e1cc9cc7112315f0cc80b6343.tar.zst
yuzu-ea2e155b0b95620e1cc9cc7112315f0cc80b6343.zip
-rw-r--r--src/video_core/renderer_opengl/gl_texture_cache.cpp9
1 files changed, 7 insertions, 2 deletions
diff --git a/src/video_core/renderer_opengl/gl_texture_cache.cpp b/src/video_core/renderer_opengl/gl_texture_cache.cpp
index 1e0823836..56d0ff869 100644
--- a/src/video_core/renderer_opengl/gl_texture_cache.cpp
+++ b/src/video_core/renderer_opengl/gl_texture_cache.cpp
@@ -439,6 +439,11 @@ OGLTexture MakeImage(const VideoCommon::ImageInfo& info, GLenum gl_internal_form
return GL_R32UI;
}
+[[nodiscard]] bool IsAstcRecompressionEnabled() {
+ return Settings::values.astc_recompression.GetValue() !=
+ Settings::AstcRecompression::Uncompressed;
+}
+
[[nodiscard]] GLenum SelectAstcFormat(PixelFormat format, bool is_srgb) {
switch (Settings::values.astc_recompression.GetValue()) {
case Settings::AstcRecompression::Bc1:
@@ -760,7 +765,7 @@ Image::Image(TextureCacheRuntime& runtime_, const VideoCommon::ImageInfo& info_,
gl_format = GL_RGBA;
gl_type = GL_UNSIGNED_INT_8_8_8_8_REV;
- if (IsPixelFormatASTC(info.format)) {
+ if (IsPixelFormatASTC(info.format) && IsAstcRecompressionEnabled()) {
gl_internal_format = SelectAstcFormat(info.format, is_srgb);
gl_format = GL_NONE;
}
@@ -1155,7 +1160,7 @@ ImageView::ImageView(TextureCacheRuntime& runtime, const VideoCommon::ImageViewI
const bool is_srgb = IsPixelFormatSRGB(info.format);
internal_format = is_srgb ? GL_SRGB8_ALPHA8 : GL_RGBA8;
- if (IsPixelFormatASTC(info.format)) {
+ if (IsPixelFormatASTC(info.format) && IsAstcRecompressionEnabled()) {
internal_format = SelectAstcFormat(info.format, is_srgb);
}
} else {