diff options
| author | Subv <subv2112@gmail.com> | 2018-07-02 09:43:38 -0500 | 
|---|---|---|
| committer | Subv <subv2112@gmail.com> | 2018-07-02 09:43:38 -0500 | 
| commit | 80c5e8ae99255fd2871e9500a5b26e5b5cb6b167 (patch) | |
| tree | b66edd9bd08bfa3b59345cf94e253c298f1374a2 | |
| parent | e9d147349bd90b7b2ee6d0f9f5825de28c3a018e (diff) | |
GPU: Ignore disabled textures and textures with an invalid address.
| -rw-r--r-- | src/video_core/renderer_opengl/gl_rasterizer.cpp | 6 | ||||
| -rw-r--r-- | src/video_core/renderer_opengl/gl_rasterizer_cache.cpp | 5 | 
2 files changed, 10 insertions, 1 deletions
diff --git a/src/video_core/renderer_opengl/gl_rasterizer.cpp b/src/video_core/renderer_opengl/gl_rasterizer.cpp index 62ee45a36..45560fbee 100644 --- a/src/video_core/renderer_opengl/gl_rasterizer.cpp +++ b/src/video_core/renderer_opengl/gl_rasterizer.cpp @@ -636,7 +636,11 @@ u32 RasterizerOpenGL::SetupTextures(Maxwell::ShaderStage stage, GLuint program,          glProgramUniform1i(program, uniform, current_bindpoint);          const auto texture = maxwell3d.GetStageTexture(entry.GetStage(), entry.GetOffset()); -        ASSERT(texture.enabled); + +        if (!texture.enabled) { +            state.texture_units[current_bindpoint].texture_2d = 0; +            continue; +        }          texture_samplers[current_bindpoint].SyncWithConfig(texture.tsc);          Surface surface = res_cache.GetTextureSurface(texture); diff --git a/src/video_core/renderer_opengl/gl_rasterizer_cache.cpp b/src/video_core/renderer_opengl/gl_rasterizer_cache.cpp index 63f5999ea..44054f338 100644 --- a/src/video_core/renderer_opengl/gl_rasterizer_cache.cpp +++ b/src/video_core/renderer_opengl/gl_rasterizer_cache.cpp @@ -454,6 +454,11 @@ Surface RasterizerCacheOpenGL::GetSurface(const SurfaceParams& params) {          return {};      } +    const auto& gpu = Core::System::GetInstance().GPU(); +    // Don't try to create any entries in the cache if the address of the texture is invalid. +    if (gpu.memory_manager->GpuToCpuAddress(params.addr) == boost::none) +        return {}; +      // Check for an exact match in existing surfaces      const auto& surface_key{SurfaceKey::Create(params)};      const auto& search{surface_cache.find(surface_key)};  | 
