diff options
author | bunnei <bunneidev@gmail.com> | 2018-09-14 12:11:37 -0400 |
---|---|---|
committer | bunnei <bunneidev@gmail.com> | 2018-09-30 14:31:57 -0400 |
commit | 871580dcd8433f2063693c69fe09b4abe6344ff0 (patch) | |
tree | 476bc4b4bcb152ac6ce3607b4f623e8aed68e5d5 /src | |
parent | a9aa1db5522798c06d3c5708f649758b045e9cde (diff) |
gl_rasterizer_cache: Implement LoadGLBuffer for Texture2DArray.
Diffstat (limited to 'src')
-rw-r--r-- | src/video_core/renderer_opengl/gl_rasterizer_cache.cpp | 8 |
1 files changed, 8 insertions, 0 deletions
diff --git a/src/video_core/renderer_opengl/gl_rasterizer_cache.cpp b/src/video_core/renderer_opengl/gl_rasterizer_cache.cpp index 57af6cdd1..022561d43 100644 --- a/src/video_core/renderer_opengl/gl_rasterizer_cache.cpp +++ b/src/video_core/renderer_opengl/gl_rasterizer_cache.cpp @@ -679,6 +679,14 @@ void CachedSurface::LoadGLBuffer() { case SurfaceParams::SurfaceTarget::Texture2D: // Pass impl. to the fallback code below break; + case SurfaceParams::SurfaceTarget::Texture2DArray: + for (std::size_t index = 0; index < params.depth; ++index) { + const std::size_t offset{index * copy_size}; + morton_to_gl_fns[static_cast<std::size_t>(params.pixel_format)]( + params.width, params.block_height, params.height, gl_buffer.data() + offset, + copy_size, params.addr + offset); + } + break; default: LOG_CRITICAL(HW_GPU, "Unimplemented tiled load for target={}", static_cast<u32>(params.target)); |