diff options
| author | 2021-04-16 23:52:58 +0200 | |
|---|---|---|
| committer | 2021-07-22 21:51:28 -0400 | |
| commit | f18a6dd1bdaffda4c3e771af3cf7cf41919ebd67 (patch) | |
| tree | ffd531d2a81f9e48369c7f362e11e224f437fd5c /src/video_core | |
| parent | shader: Fix Phi node types (diff) | |
| download | yuzu-f18a6dd1bdaffda4c3e771af3cf7cf41919ebd67.tar.gz yuzu-f18a6dd1bdaffda4c3e771af3cf7cf41919ebd67.tar.xz yuzu-f18a6dd1bdaffda4c3e771af3cf7cf41919ebd67.zip | |
shader: Implement SR_Y_DIRECTION
Diffstat (limited to 'src/video_core')
| -rw-r--r-- | src/video_core/renderer_vulkan/fixed_pipeline_state.cpp | 2 | ||||
| -rw-r--r-- | src/video_core/renderer_vulkan/fixed_pipeline_state.h | 1 | ||||
| -rw-r--r-- | src/video_core/renderer_vulkan/vk_pipeline_cache.cpp | 1 |
3 files changed, 4 insertions, 0 deletions
diff --git a/src/video_core/renderer_vulkan/fixed_pipeline_state.cpp b/src/video_core/renderer_vulkan/fixed_pipeline_state.cpp index 6a3baf837..24834e0f7 100644 --- a/src/video_core/renderer_vulkan/fixed_pipeline_state.cpp +++ b/src/video_core/renderer_vulkan/fixed_pipeline_state.cpp | |||
| @@ -82,6 +82,8 @@ void FixedPipelineState::Refresh(Tegra::Engines::Maxwell3D& maxwell3d, | |||
| 82 | alpha_test_ref = Common::BitCast<u32>(regs.alpha_test_ref); | 82 | alpha_test_ref = Common::BitCast<u32>(regs.alpha_test_ref); |
| 83 | point_size = Common::BitCast<u32>(regs.point_size); | 83 | point_size = Common::BitCast<u32>(regs.point_size); |
| 84 | 84 | ||
| 85 | y_negate.Assign(regs.screen_y_control.y_negate != 0 ? 1 : 0); | ||
| 86 | |||
| 85 | if (maxwell3d.dirty.flags[Dirty::InstanceDivisors]) { | 87 | if (maxwell3d.dirty.flags[Dirty::InstanceDivisors]) { |
| 86 | maxwell3d.dirty.flags[Dirty::InstanceDivisors] = false; | 88 | maxwell3d.dirty.flags[Dirty::InstanceDivisors] = false; |
| 87 | for (size_t index = 0; index < Maxwell::NumVertexArrays; ++index) { | 89 | for (size_t index = 0; index < Maxwell::NumVertexArrays; ++index) { |
diff --git a/src/video_core/renderer_vulkan/fixed_pipeline_state.h b/src/video_core/renderer_vulkan/fixed_pipeline_state.h index 5568c4f72..31de6b2c8 100644 --- a/src/video_core/renderer_vulkan/fixed_pipeline_state.h +++ b/src/video_core/renderer_vulkan/fixed_pipeline_state.h | |||
| @@ -202,6 +202,7 @@ struct FixedPipelineState { | |||
| 202 | BitField<3, 1, u32> early_z; | 202 | BitField<3, 1, u32> early_z; |
| 203 | BitField<4, 1, u32> depth_enabled; | 203 | BitField<4, 1, u32> depth_enabled; |
| 204 | BitField<5, 5, u32> depth_format; | 204 | BitField<5, 5, u32> depth_format; |
| 205 | BitField<10, 1, u32> y_negate; | ||
| 205 | }; | 206 | }; |
| 206 | std::array<u8, Maxwell::NumRenderTargets> color_formats; | 207 | std::array<u8, Maxwell::NumRenderTargets> color_formats; |
| 207 | 208 | ||
diff --git a/src/video_core/renderer_vulkan/vk_pipeline_cache.cpp b/src/video_core/renderer_vulkan/vk_pipeline_cache.cpp index 4d0d3ebb7..e9b93336b 100644 --- a/src/video_core/renderer_vulkan/vk_pipeline_cache.cpp +++ b/src/video_core/renderer_vulkan/vk_pipeline_cache.cpp | |||
| @@ -1116,6 +1116,7 @@ Shader::Profile PipelineCache::MakeProfile(const GraphicsPipelineCacheKey& key, | |||
| 1116 | break; | 1116 | break; |
| 1117 | } | 1117 | } |
| 1118 | profile.force_early_z = key.state.early_z != 0; | 1118 | profile.force_early_z = key.state.early_z != 0; |
| 1119 | profile.y_negate = key.state.y_negate != 0; | ||
| 1119 | return profile; | 1120 | return profile; |
| 1120 | } | 1121 | } |
| 1121 | 1122 | ||