From 0ef0c36704c2ba79cd9c80e649c953c3fc0bfb5e Mon Sep 17 00:00:00 2001 From: Connor McLaughlin Date: Sun, 17 May 2020 18:46:56 +1000 Subject: [PATCH] GPU: Align display widths to 4 pixels Documentation thanks to nocash. Fixes line on edge in X2 - No Relief, Gunbird. --- src/core/gpu.cpp | 27 ++++++++++++--------------- 1 file changed, 12 insertions(+), 15 deletions(-) diff --git a/src/core/gpu.cpp b/src/core/gpu.cpp index a00a236e8..c91516d5f 100644 --- a/src/core/gpu.cpp +++ b/src/core/gpu.cpp @@ -500,9 +500,8 @@ void GPU::UpdateCRTCDisplayParameters() const u8 height_shift = BoolToUInt8(m_GPUSTAT.In480iMode()); // Determine screen size. - cs.display_width = std::max( - ((cs.horizontal_active_end - cs.horizontal_active_start) + (cs.dot_clock_divider - 1)) / cs.dot_clock_divider, 1u); - cs.display_height = std::max((cs.vertical_active_end - cs.vertical_active_start) << height_shift, 1u); + cs.display_width = (((cs.horizontal_active_end - cs.horizontal_active_start) / cs.dot_clock_divider) + 2u) & ~3u; + cs.display_height = (cs.vertical_active_end - cs.vertical_active_start) << height_shift; // Determine if we need to adjust the VRAM rectangle (because the display is starting outside the visible area) or add // padding. @@ -521,21 +520,19 @@ void GPU::UpdateCRTCDisplayParameters() if (horizontal_display_end <= cs.horizontal_active_end) { - cs.display_vram_width = std::max( - (((horizontal_display_end - - std::min(horizontal_display_end, std::max(horizontal_display_start, cs.horizontal_active_start))) + - (cs.dot_clock_divider - 1)) / - cs.dot_clock_divider), - 1u); + const u16 active_ticks = + horizontal_display_end - + std::min(horizontal_display_end, std::max(horizontal_display_start, cs.horizontal_active_start)); + + cs.display_vram_width = ((active_ticks / cs.dot_clock_divider) + 2u) & ~3u; } else { - cs.display_vram_width = std::max( - (((cs.horizontal_active_end - - std::min(cs.horizontal_active_end, std::max(horizontal_display_start, cs.horizontal_active_start))) + - (cs.dot_clock_divider - 1)) / - cs.dot_clock_divider), - 1u); + const u16 active_ticks = + cs.horizontal_active_end - + std::min(cs.horizontal_active_end, std::max(horizontal_display_start, cs.horizontal_active_start)); + + cs.display_vram_width = ((active_ticks / cs.dot_clock_divider) + 2u) & ~3u; } if (vertical_display_start >= cs.vertical_active_start)