diff options
| author | 2019-11-29 16:51:14 -0300 | |
|---|---|---|
| committer | 2019-11-29 16:51:14 -0300 | |
| commit | ff64c3951a1daff33d7c66058bb7c4edbb162fbf (patch) | |
| tree | 54062097312593d1396128bef4d7de3de5ea603e /src | |
| parent | Merge pull request #3169 from lioncash/memory (diff) | |
| download | yuzu-ff64c3951a1daff33d7c66058bb7c4edbb162fbf.tar.gz yuzu-ff64c3951a1daff33d7c66058bb7c4edbb162fbf.tar.xz yuzu-ff64c3951a1daff33d7c66058bb7c4edbb162fbf.zip | |
texture_cache/surface_base: Fix out of bounds texture views
Some texture views were being created out of bounds (with more layers or
mipmaps than what the original texture has). This is because of a
miscalculation in mipmap bounding. end_layer and end_mipmap are out of
bounds (e.g. layer 6 in a cubemap), there's no need to add one more
there.
Fixes OpenGL errors and Vulkan crashes on Splatoon 2.
Diffstat (limited to 'src')
| -rw-r--r-- | src/video_core/texture_cache/surface_base.h | 11 |
1 files changed, 4 insertions, 7 deletions
diff --git a/src/video_core/texture_cache/surface_base.h b/src/video_core/texture_cache/surface_base.h index 1bed82898..5f79bb0aa 100644 --- a/src/video_core/texture_cache/surface_base.h +++ b/src/video_core/texture_cache/surface_base.h | |||
| @@ -254,16 +254,14 @@ public: | |||
| 254 | if (!layer_mipmap) { | 254 | if (!layer_mipmap) { |
| 255 | return {}; | 255 | return {}; |
| 256 | } | 256 | } |
| 257 | const u32 end_layer{layer_mipmap->first}; | 257 | const auto [end_layer, end_mipmap] = *layer_mipmap; |
| 258 | const u32 end_mipmap{layer_mipmap->second}; | ||
| 259 | if (layer != end_layer) { | 258 | if (layer != end_layer) { |
| 260 | if (mipmap == 0 && end_mipmap == 0) { | 259 | if (mipmap == 0 && end_mipmap == 0) { |
| 261 | return GetView(ViewParams(view_params.target, layer, end_layer - layer + 1, 0, 1)); | 260 | return GetView(ViewParams(view_params.target, layer, end_layer - layer, 0, 1)); |
| 262 | } | 261 | } |
| 263 | return {}; | 262 | return {}; |
| 264 | } else { | 263 | } else { |
| 265 | return GetView( | 264 | return GetView(ViewParams(view_params.target, layer, 1, mipmap, end_mipmap - mipmap)); |
| 266 | ViewParams(view_params.target, layer, 1, mipmap, end_mipmap - mipmap + 1)); | ||
| 267 | } | 265 | } |
| 268 | } | 266 | } |
| 269 | 267 | ||
| @@ -278,8 +276,7 @@ public: | |||
| 278 | if (!layer_mipmap) { | 276 | if (!layer_mipmap) { |
| 279 | return {}; | 277 | return {}; |
| 280 | } | 278 | } |
| 281 | const u32 layer{layer_mipmap->first}; | 279 | const auto [layer, mipmap] = *layer_mipmap; |
| 282 | const u32 mipmap{layer_mipmap->second}; | ||
| 283 | if (GetMipmapSize(mipmap) != candidate_size) { | 280 | if (GetMipmapSize(mipmap) != candidate_size) { |
| 284 | return EmplaceIrregularView(view_params, view_addr, candidate_size, mipmap, layer); | 281 | return EmplaceIrregularView(view_params, view_addr, candidate_size, mipmap, layer); |
| 285 | } | 282 | } |