summaryrefslogtreecommitdiff
path: root/src/video_core/renderer_opengl
diff options
context:
space:
mode:
authorGravatar bunnei2018-11-26 18:34:09 -0500
committerGravatar GitHub2018-11-26 18:34:09 -0500
commit1856d0ee8a5fbcc1570d5bb073d0e92d74d2a914 (patch)
tree7bd759f523dab8055a7c85b8de6d6ec706c2bffb /src/video_core/renderer_opengl
parentMerge pull request #1723 from degasus/dirty_flags (diff)
parentLimit the amount of viewports tested for state changes only to the usable ones (diff)
downloadyuzu-1856d0ee8a5fbcc1570d5bb073d0e92d74d2a914.tar.gz
yuzu-1856d0ee8a5fbcc1570d5bb073d0e92d74d2a914.tar.xz
yuzu-1856d0ee8a5fbcc1570d5bb073d0e92d74d2a914.zip
Merge pull request #1794 from Tinob/master
Add support for viewport_transfom_enable register
Diffstat (limited to 'src/video_core/renderer_opengl')
-rw-r--r--src/video_core/renderer_opengl/gl_rasterizer.cpp30
1 files changed, 23 insertions, 7 deletions
diff --git a/src/video_core/renderer_opengl/gl_rasterizer.cpp b/src/video_core/renderer_opengl/gl_rasterizer.cpp
index 1f9acda36..98fb5a9aa 100644
--- a/src/video_core/renderer_opengl/gl_rasterizer.cpp
+++ b/src/video_core/renderer_opengl/gl_rasterizer.cpp
@@ -985,13 +985,25 @@ u32 RasterizerOpenGL::SetupTextures(Maxwell::ShaderStage stage, Shader& shader,
985 985
986void RasterizerOpenGL::SyncViewport(OpenGLState& current_state) { 986void RasterizerOpenGL::SyncViewport(OpenGLState& current_state) {
987 const auto& regs = Core::System::GetInstance().GPU().Maxwell3D().regs; 987 const auto& regs = Core::System::GetInstance().GPU().Maxwell3D().regs;
988 for (std::size_t i = 0; i < Tegra::Engines::Maxwell3D::Regs::NumViewports; i++) { 988 const bool geometry_shaders_enabled =
989 const MathUtil::Rectangle<s32> viewport_rect{regs.viewport_transform[i].GetRect()}; 989 regs.IsShaderConfigEnabled(static_cast<size_t>(Maxwell::ShaderProgram::Geometry));
990 const std::size_t viewport_count =
991 geometry_shaders_enabled ? Tegra::Engines::Maxwell3D::Regs::NumViewports : 1;
992 for (std::size_t i = 0; i < viewport_count; i++) {
990 auto& viewport = current_state.viewports[i]; 993 auto& viewport = current_state.viewports[i];
991 viewport.x = viewport_rect.left; 994 const auto& src = regs.viewports[i];
992 viewport.y = viewport_rect.bottom; 995 if (regs.viewport_transform_enabled) {
993 viewport.width = viewport_rect.GetWidth(); 996 const MathUtil::Rectangle<s32> viewport_rect{regs.viewport_transform[i].GetRect()};
994 viewport.height = viewport_rect.GetHeight(); 997 viewport.x = viewport_rect.left;
998 viewport.y = viewport_rect.bottom;
999 viewport.width = viewport_rect.GetWidth();
1000 viewport.height = viewport_rect.GetHeight();
1001 } else {
1002 viewport.x = src.x;
1003 viewport.y = src.y;
1004 viewport.width = src.width;
1005 viewport.height = src.height;
1006 }
995 viewport.depth_range_far = regs.viewports[i].depth_range_far; 1007 viewport.depth_range_far = regs.viewports[i].depth_range_far;
996 viewport.depth_range_near = regs.viewports[i].depth_range_near; 1008 viewport.depth_range_near = regs.viewports[i].depth_range_near;
997 } 1009 }
@@ -1165,7 +1177,11 @@ void RasterizerOpenGL::SyncLogicOpState() {
1165 1177
1166void RasterizerOpenGL::SyncScissorTest(OpenGLState& current_state) { 1178void RasterizerOpenGL::SyncScissorTest(OpenGLState& current_state) {
1167 const auto& regs = Core::System::GetInstance().GPU().Maxwell3D().regs; 1179 const auto& regs = Core::System::GetInstance().GPU().Maxwell3D().regs;
1168 for (std::size_t i = 0; i < Tegra::Engines::Maxwell3D::Regs::NumViewports; i++) { 1180 const bool geometry_shaders_enabled =
1181 regs.IsShaderConfigEnabled(static_cast<size_t>(Maxwell::ShaderProgram::Geometry));
1182 const std::size_t viewport_count =
1183 geometry_shaders_enabled ? Tegra::Engines::Maxwell3D::Regs::NumViewports : 1;
1184 for (std::size_t i = 0; i < viewport_count; i++) {
1169 const auto& src = regs.scissor_test[i]; 1185 const auto& src = regs.scissor_test[i];
1170 auto& dst = current_state.viewports[i].scissor; 1186 auto& dst = current_state.viewports[i].scissor;
1171 dst.enabled = (src.enable != 0); 1187 dst.enabled = (src.enable != 0);