diff options
author | bunnei <bunneidev@gmail.com> | 2018-03-23 19:58:27 +0100 |
---|---|---|
committer | bunnei <bunneidev@gmail.com> | 2018-03-23 19:58:27 +0100 |
commit | ec4e1a3685d458147ac76f4cf53ea86632d0debd (patch) | |
tree | 0bdc8e13b56ae88459055360f02b13e943dd6199 /src/video_core | |
parent | renderer_opengl: Use accelerated framebuffer load with LoadFBToScreenInfo. (diff) | |
download | yuzu-ec4e1a3685d458147ac76f4cf53ea86632d0debd.tar yuzu-ec4e1a3685d458147ac76f4cf53ea86632d0debd.tar.gz yuzu-ec4e1a3685d458147ac76f4cf53ea86632d0debd.tar.bz2 yuzu-ec4e1a3685d458147ac76f4cf53ea86632d0debd.tar.lz yuzu-ec4e1a3685d458147ac76f4cf53ea86632d0debd.tar.xz yuzu-ec4e1a3685d458147ac76f4cf53ea86632d0debd.tar.zst yuzu-ec4e1a3685d458147ac76f4cf53ea86632d0debd.zip |
Diffstat (limited to 'src/video_core')
-rw-r--r-- | src/video_core/gpu.h | 5 | ||||
-rw-r--r-- | src/video_core/renderer_opengl/renderer_opengl.cpp | 18 |
2 files changed, 20 insertions, 3 deletions
diff --git a/src/video_core/gpu.h b/src/video_core/gpu.h index f3c5e366a..206b3e05e 100644 --- a/src/video_core/gpu.h +++ b/src/video_core/gpu.h @@ -8,6 +8,7 @@ #include <unordered_map> #include <vector> #include "common/common_types.h" +#include "core/hle/service/nvflinger/buffer_queue.h" #include "video_core/memory_manager.h" namespace Tegra { @@ -38,7 +39,9 @@ struct FramebufferConfig { u32 height; u32 stride; PixelFormat pixel_format; - bool flip_vertical; + + using TransformFlags = Service::NVFlinger::BufferQueue::BufferTransformFlags; + TransformFlags transform_flags; }; namespace Engines { diff --git a/src/video_core/renderer_opengl/renderer_opengl.cpp b/src/video_core/renderer_opengl/renderer_opengl.cpp index 047389fee..ef63cbcf0 100644 --- a/src/video_core/renderer_opengl/renderer_opengl.cpp +++ b/src/video_core/renderer_opengl/renderer_opengl.cpp @@ -141,6 +141,9 @@ void RendererOpenGL::LoadFBToScreenInfo(const Tegra::FramebufferConfig& framebuf const u32 size_in_bytes{framebuffer.stride * framebuffer.height * bpp}; const VAddr framebuffer_addr{framebuffer.address}; + // Framebuffer orientation handling + framebuffer_transform_flags = framebuffer.transform_flags; + // Ensure no bad interactions with GL_UNPACK_ALIGNMENT, which by default // only allows rows to have a memory alignement of 4. ASSERT(framebuffer.stride % 4 == 0); @@ -292,8 +295,19 @@ void RendererOpenGL::ConfigureFramebufferTexture(TextureInfo& texture, void RendererOpenGL::DrawSingleScreen(const ScreenInfo& screen_info, float x, float y, float w, float h) { const auto& texcoords = screen_info.display_texcoords; - const auto& left = framebuffer_flip_vertical ? texcoords.right : texcoords.left; - const auto& right = framebuffer_flip_vertical ? texcoords.left : texcoords.right; + auto left = texcoords.left; + auto right = texcoords.right; + if (framebuffer_transform_flags != Tegra::FramebufferConfig::TransformFlags::Unset) + if (framebuffer_transform_flags == Tegra::FramebufferConfig::TransformFlags::FlipV) { + // Flip the framebuffer vertically + left = texcoords.right; + right = texcoords.left; + } else { + // Other transformations are unsupported + LOG_CRITICAL(HW_GPU, "unsupported framebuffer_transform_flags=%d", + framebuffer_transform_flags); + UNIMPLEMENTED(); + } std::array<ScreenRectVertex, 4> vertices = {{ ScreenRectVertex(x, y, texcoords.top, right), |