From 28b82615a74d4137fb6333ff96d941a48e3175f5 Mon Sep 17 00:00:00 2001 From: smurf3tte <75271109+smurf3tte@users.noreply.github.com> Date: Mon, 21 Dec 2020 12:03:30 -0800 Subject: [PATCH] GameSettings: Patch for freezing in Gladius (GLSE64) This game can deadlock the CPU and GPU by setting FIFO breakpoints too infrequently, provided the CPU gets too far ahead, as can happen under Dolphin due to timing inaccuracies. The game never clears breakpoints, and it will skip setting them if the previous one has not been hit by the GPU. If the CPU gets far enough ahead it will reach the FIFO high water mark and trigger an overflow interrupt, causing the render thread to be suspended. The GPU will make forward progress until it hits the last set breakpoint. However, if the distance between that breakpoint and the FIFO write pointer is greater than the low water mark, then the GPU will never generate an underflow interrupt and the render thread will never be resumed. This patch forces the game to update the breakpoint unconditionally and has been tested on real hardware with no apparent ill effect. This patch covers the US release (GLSE64), but there are three more (GLSD64, GLSF64, GLSP64) that will likely require similar patches. --- Data/Sys/GameSettings/GLSE64.ini | 20 ++++++++++++++++++++ 1 file changed, 20 insertions(+) create mode 100644 Data/Sys/GameSettings/GLSE64.ini diff --git a/Data/Sys/GameSettings/GLSE64.ini b/Data/Sys/GameSettings/GLSE64.ini new file mode 100644 index 0000000000..0cee6fb0ca --- /dev/null +++ b/Data/Sys/GameSettings/GLSE64.ini @@ -0,0 +1,20 @@ +# GLSE64 - Gladius + +[OnFrame] +# This game can deadlock the CPU and GPU by setting FIFO breakpoints too +# infrequently, provided the CPU gets too far ahead, as can happen under Dolphin +# due to timing inaccuracies. The game never clears breakpoints, and it will +# skip setting them if the previous one has not been hit by the GPU. If the CPU +# gets far enough ahead it will reach the FIFO high water mark and trigger an +# overflow interrupt, causing the render thread to be suspended. The GPU will +# make forward progress until it hits the last set breakpoint. However, if the +# distance between that breakpoint and the FIFO write pointer is greater than +# the low water mark, then the GPU will never generate an underflow interrupt +# and the render thread will never be resumed. This patch forces the game to +# update the breakpoint unconditionally and has been tested on real hardware +# with no apparent ill effect. +$Fix freeze in opening cutscene +0x8010B4B0:dword:0x60000000 + +[OnFrame_Enabled] +$Fix freeze in opening cutscene