diff options
author | ameerj <52414509+ameerj@users.noreply.github.com> | 2023-05-28 19:14:51 +0200 |
---|---|---|
committer | ameerj <52414509+ameerj@users.noreply.github.com> | 2023-05-28 19:14:51 +0200 |
commit | ea2e155b0b95620e1cc9cc7112315f0cc80b6343 (patch) | |
tree | df95a5dfb5596d33672ce8e6a71d15de833cbaa3 /src/video_core | |
parent | Merge pull request #10414 from liamwhite/anv-push-descriptor (diff) | |
download | yuzu-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 |
Diffstat (limited to 'src/video_core')
-rw-r--r-- | src/video_core/renderer_opengl/gl_texture_cache.cpp | 9 |
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 { |