diff options
Diffstat (limited to 'src')
| -rw-r--r-- | src/video_core/renderer_vulkan/vk_blit_screen.cpp | 2 | ||||
| -rw-r--r-- | src/video_core/renderer_vulkan/vk_rasterizer.cpp | 9 | ||||
| -rw-r--r-- | src/video_core/texture_cache/texture_cache.h | 4 |
3 files changed, 11 insertions, 4 deletions
diff --git a/src/video_core/renderer_vulkan/vk_blit_screen.cpp b/src/video_core/renderer_vulkan/vk_blit_screen.cpp index 21644a7e7..fbd406f2b 100644 --- a/src/video_core/renderer_vulkan/vk_blit_screen.cpp +++ b/src/video_core/renderer_vulkan/vk_blit_screen.cpp | |||
| @@ -535,7 +535,9 @@ void VKBlitScreen::CreateGraphicsPipeline() { | |||
| 535 | viewport_state_ci.pNext = nullptr; | 535 | viewport_state_ci.pNext = nullptr; |
| 536 | viewport_state_ci.flags = 0; | 536 | viewport_state_ci.flags = 0; |
| 537 | viewport_state_ci.viewportCount = 1; | 537 | viewport_state_ci.viewportCount = 1; |
| 538 | viewport_state_ci.pViewports = nullptr; | ||
| 538 | viewport_state_ci.scissorCount = 1; | 539 | viewport_state_ci.scissorCount = 1; |
| 540 | viewport_state_ci.pScissors = nullptr; | ||
| 539 | 541 | ||
| 540 | VkPipelineRasterizationStateCreateInfo rasterization_ci; | 542 | VkPipelineRasterizationStateCreateInfo rasterization_ci; |
| 541 | rasterization_ci.sType = VK_STRUCTURE_TYPE_PIPELINE_RASTERIZATION_STATE_CREATE_INFO; | 543 | rasterization_ci.sType = VK_STRUCTURE_TYPE_PIPELINE_RASTERIZATION_STATE_CREATE_INFO; |
diff --git a/src/video_core/renderer_vulkan/vk_rasterizer.cpp b/src/video_core/renderer_vulkan/vk_rasterizer.cpp index 33cbc0bb6..774ba1f26 100644 --- a/src/video_core/renderer_vulkan/vk_rasterizer.cpp +++ b/src/video_core/renderer_vulkan/vk_rasterizer.cpp | |||
| @@ -62,13 +62,16 @@ constexpr auto ComputeShaderIndex = static_cast<std::size_t>(Tegra::Engines::Sha | |||
| 62 | 62 | ||
| 63 | VkViewport GetViewportState(const VKDevice& device, const Maxwell& regs, std::size_t index) { | 63 | VkViewport GetViewportState(const VKDevice& device, const Maxwell& regs, std::size_t index) { |
| 64 | const auto& src = regs.viewport_transform[index]; | 64 | const auto& src = regs.viewport_transform[index]; |
| 65 | const float width = src.scale_x * 2.0f; | ||
| 66 | const float height = src.scale_y * 2.0f; | ||
| 67 | |||
| 65 | VkViewport viewport; | 68 | VkViewport viewport; |
| 66 | viewport.x = src.translate_x - src.scale_x; | 69 | viewport.x = src.translate_x - src.scale_x; |
| 67 | viewport.y = src.translate_y - src.scale_y; | 70 | viewport.y = src.translate_y - src.scale_y; |
| 68 | viewport.width = src.scale_x * 2.0f; | 71 | viewport.width = width != 0.0f ? width : 1.0f; |
| 69 | viewport.height = src.scale_y * 2.0f; | 72 | viewport.height = height != 0.0f ? height : 1.0f; |
| 70 | 73 | ||
| 71 | const float reduce_z = regs.depth_mode == Maxwell::DepthMode::MinusOneToOne; | 74 | const float reduce_z = regs.depth_mode == Maxwell::DepthMode::MinusOneToOne ? 1.0f : 0.0f; |
| 72 | viewport.minDepth = src.translate_z - src.scale_z * reduce_z; | 75 | viewport.minDepth = src.translate_z - src.scale_z * reduce_z; |
| 73 | viewport.maxDepth = src.translate_z + src.scale_z; | 76 | viewport.maxDepth = src.translate_z + src.scale_z; |
| 74 | if (!device.IsExtDepthRangeUnrestrictedSupported()) { | 77 | if (!device.IsExtDepthRangeUnrestrictedSupported()) { |
diff --git a/src/video_core/texture_cache/texture_cache.h b/src/video_core/texture_cache/texture_cache.h index cfc7fe6e9..4edd4313b 100644 --- a/src/video_core/texture_cache/texture_cache.h +++ b/src/video_core/texture_cache/texture_cache.h | |||
| @@ -509,7 +509,9 @@ private: | |||
| 509 | } | 509 | } |
| 510 | const auto& final_params = new_surface->GetSurfaceParams(); | 510 | const auto& final_params = new_surface->GetSurfaceParams(); |
| 511 | if (cr_params.type != final_params.type) { | 511 | if (cr_params.type != final_params.type) { |
| 512 | BufferCopy(current_surface, new_surface); | 512 | if (Settings::values.use_accurate_gpu_emulation) { |
| 513 | BufferCopy(current_surface, new_surface); | ||
| 514 | } | ||
| 513 | } else { | 515 | } else { |
| 514 | std::vector<CopyParams> bricks = current_surface->BreakDown(final_params); | 516 | std::vector<CopyParams> bricks = current_surface->BreakDown(final_params); |
| 515 | for (auto& brick : bricks) { | 517 | for (auto& brick : bricks) { |