summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--src/video_core/renderer_vulkan/vk_blit_screen.cpp2
-rw-r--r--src/video_core/renderer_vulkan/vk_rasterizer.cpp9
-rw-r--r--src/video_core/texture_cache/texture_cache.h4
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
63VkViewport GetViewportState(const VKDevice& device, const Maxwell& regs, std::size_t index) { 63VkViewport 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) {