diff options
| author | ReinUsesLisp <reinuseslisp@airmail.cc> | 2019-05-01 00:36:11 -0300 | 
|---|---|---|
| committer | ReinUsesLisp <reinuseslisp@airmail.cc> | 2019-05-01 00:36:11 -0300 | 
| commit | 4aa081b4e774436d7a4ba70a42a14ff5b1869662 (patch) | |
| tree | 5dcaada5d1f568f85fd2f006eafbecd148916c34 /src/video_core | |
| parent | fb420358a99fb4a27cb48fd0e21c5c3f3a477c0c (diff) | |
gl_shader_disk_cache: Skip stored shader variants instead of asserting
Instead of asserting on already stored shader variants, silently skip them.
This shouldn't be happening but when a shader is invalidated and it is
not stored in the shader cache, this assert would hit and save that
shader anyways when the asserts are disabled.
Diffstat (limited to 'src/video_core')
| -rw-r--r-- | src/video_core/renderer_opengl/gl_shader_disk_cache.cpp | 5 | 
1 files changed, 4 insertions, 1 deletions
| diff --git a/src/video_core/renderer_opengl/gl_shader_disk_cache.cpp b/src/video_core/renderer_opengl/gl_shader_disk_cache.cpp index ed7afc4a0..254c0d499 100644 --- a/src/video_core/renderer_opengl/gl_shader_disk_cache.cpp +++ b/src/video_core/renderer_opengl/gl_shader_disk_cache.cpp @@ -475,7 +475,10 @@ void ShaderDiskCacheOpenGL::SaveUsage(const ShaderDiskCacheUsage& usage) {      ASSERT_MSG(it != transferable.end(), "Saving shader usage without storing raw previously");      auto& usages{it->second}; -    ASSERT(usages.find(usage) == usages.end()); +    if (usages.find(usage) != usages.end()) { +        // Skip this variant since the shader is already stored. +        return; +    }      usages.insert(usage);      FileUtil::IOFile file = AppendTransferableFile(); | 
