diff options
author | ReinUsesLisp <reinuseslisp@airmail.cc> | 2019-12-29 02:12:12 +0100 |
---|---|---|
committer | ReinUsesLisp <reinuseslisp@airmail.cc> | 2020-02-28 21:56:41 +0100 |
commit | 7f52efdf61d16d6eaa7eea2500ceb28d9f1041e1 (patch) | |
tree | a18e0a878c025c613b7dcf6f23db83011afda92e /src/video_core/renderer_opengl/gl_state_tracker.cpp | |
parent | renderer_opengl: Reintroduce dirty flags for render targets (diff) | |
download | yuzu-7f52efdf61d16d6eaa7eea2500ceb28d9f1041e1.tar yuzu-7f52efdf61d16d6eaa7eea2500ceb28d9f1041e1.tar.gz yuzu-7f52efdf61d16d6eaa7eea2500ceb28d9f1041e1.tar.bz2 yuzu-7f52efdf61d16d6eaa7eea2500ceb28d9f1041e1.tar.lz yuzu-7f52efdf61d16d6eaa7eea2500ceb28d9f1041e1.tar.xz yuzu-7f52efdf61d16d6eaa7eea2500ceb28d9f1041e1.tar.zst yuzu-7f52efdf61d16d6eaa7eea2500ceb28d9f1041e1.zip |
Diffstat (limited to '')
-rw-r--r-- | src/video_core/renderer_opengl/gl_state_tracker.cpp | 17 |
1 files changed, 17 insertions, 0 deletions
diff --git a/src/video_core/renderer_opengl/gl_state_tracker.cpp b/src/video_core/renderer_opengl/gl_state_tracker.cpp index 268b9351e..6293f6102 100644 --- a/src/video_core/renderer_opengl/gl_state_tracker.cpp +++ b/src/video_core/renderer_opengl/gl_state_tracker.cpp @@ -61,6 +61,22 @@ void SetupDirtyRenderTargets(Tables& tables) { } } +void SetupDirtyViewports(Tables& tables) { + for (std::size_t i = 0; i < Regs::NumViewports; ++i) { + const std::size_t transf_offset = OFF(viewport_transform) + i * NUM(viewport_transform[0]); + const std::size_t viewport_offset = OFF(viewports) + i * NUM(viewports[0]); + + FillBlock(tables[0], transf_offset, NUM(viewport_transform[0]), Viewport0 + i); + FillBlock(tables[0], viewport_offset, NUM(viewports[0]), Viewport0 + i); + } + + FillBlock(tables[1], OFF(viewport_transform), NUM(viewport_transform), Viewports); + FillBlock(tables[1], OFF(viewports), NUM(viewports), Viewports); + + tables[0][OFF(viewport_transform_enabled)] = ViewportTransform; + tables[1][OFF(viewport_transform_enabled)] = Viewports; +} + } // Anonymous namespace StateTracker::StateTracker(Core::System& system) : system{system} {} @@ -80,6 +96,7 @@ void StateTracker::Initialize() { auto& tables = dirty.tables; SetupDirtyRenderTargets(tables); + SetupDirtyViewports(tables); } } // namespace OpenGL |