summaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorGravatar Rodolfo Bogado2018-11-25 12:18:29 -0300
committerGravatar Rodolfo Bogado2018-11-25 12:18:29 -0300
commit415e8383ba33e08ca3a95ae30c03be7de63de3e6 (patch)
tree71400a9b69e48581aac30285c59da0cb2f12fcdf /src
parentAdd support for viewport_transfom_enable register (diff)
downloadyuzu-415e8383ba33e08ca3a95ae30c03be7de63de3e6.tar.gz
yuzu-415e8383ba33e08ca3a95ae30c03be7de63de3e6.tar.xz
yuzu-415e8383ba33e08ca3a95ae30c03be7de63de3e6.zip
Limit the amount of viewports tested for state changes only to the usable ones
Diffstat (limited to 'src')
-rw-r--r--src/video_core/renderer_opengl/gl_rasterizer.cpp12
1 files changed, 10 insertions, 2 deletions
diff --git a/src/video_core/renderer_opengl/gl_rasterizer.cpp b/src/video_core/renderer_opengl/gl_rasterizer.cpp
index fea106ba1..99004c9ad 100644
--- a/src/video_core/renderer_opengl/gl_rasterizer.cpp
+++ b/src/video_core/renderer_opengl/gl_rasterizer.cpp
@@ -969,7 +969,11 @@ u32 RasterizerOpenGL::SetupTextures(Maxwell::ShaderStage stage, Shader& shader,
969 969
970void RasterizerOpenGL::SyncViewport(OpenGLState& current_state) { 970void RasterizerOpenGL::SyncViewport(OpenGLState& current_state) {
971 const auto& regs = Core::System::GetInstance().GPU().Maxwell3D().regs; 971 const auto& regs = Core::System::GetInstance().GPU().Maxwell3D().regs;
972 for (std::size_t i = 0; i < Tegra::Engines::Maxwell3D::Regs::NumViewports; i++) { 972 const bool geometry_shaders_enabled =
973 regs.IsShaderConfigEnabled(static_cast<size_t>(Maxwell::ShaderProgram::Geometry));
974 const std::size_t viewport_count =
975 geometry_shaders_enabled ? Tegra::Engines::Maxwell3D::Regs::NumViewports : 1;
976 for (std::size_t i = 0; i < viewport_count; i++) {
973 auto& viewport = current_state.viewports[i]; 977 auto& viewport = current_state.viewports[i];
974 const auto& src = regs.viewports[i]; 978 const auto& src = regs.viewports[i];
975 if (regs.viewport_transform_enabled) { 979 if (regs.viewport_transform_enabled) {
@@ -1157,7 +1161,11 @@ void RasterizerOpenGL::SyncLogicOpState() {
1157 1161
1158void RasterizerOpenGL::SyncScissorTest(OpenGLState& current_state) { 1162void RasterizerOpenGL::SyncScissorTest(OpenGLState& current_state) {
1159 const auto& regs = Core::System::GetInstance().GPU().Maxwell3D().regs; 1163 const auto& regs = Core::System::GetInstance().GPU().Maxwell3D().regs;
1160 for (std::size_t i = 0; i < Tegra::Engines::Maxwell3D::Regs::NumViewports; i++) { 1164 const bool geometry_shaders_enabled =
1165 regs.IsShaderConfigEnabled(static_cast<size_t>(Maxwell::ShaderProgram::Geometry));
1166 const std::size_t viewport_count =
1167 geometry_shaders_enabled ? Tegra::Engines::Maxwell3D::Regs::NumViewports : 1;
1168 for (std::size_t i = 0; i < viewport_count; i++) {
1161 const auto& src = regs.scissor_test[i]; 1169 const auto& src = regs.scissor_test[i];
1162 auto& dst = current_state.viewports[i].scissor; 1170 auto& dst = current_state.viewports[i].scissor;
1163 dst.enabled = (src.enable != 0); 1171 dst.enabled = (src.enable != 0);