From 56b5fc516739861bbe3b8d04b02c41237021960e Mon Sep 17 00:00:00 2001 From: chaoticgd <43898262+chaoticgd@users.noreply.github.com> Date: Mon, 25 Nov 2024 14:05:11 +0000 Subject: [PATCH] Debugger: Make sure the colours of functions are consistent across runs --- pcsx2-qt/Debugger/DisassemblyWidget.cpp | 11 ++++++++--- 1 file changed, 8 insertions(+), 3 deletions(-) diff --git a/pcsx2-qt/Debugger/DisassemblyWidget.cpp b/pcsx2-qt/Debugger/DisassemblyWidget.cpp index 887b8185ff0ce..9e70214bb0625 100644 --- a/pcsx2-qt/Debugger/DisassemblyWidget.cpp +++ b/pcsx2-qt/Debugger/DisassemblyWidget.cpp @@ -780,11 +780,16 @@ QColor DisassemblyWidget::GetAddressFunctionColor(u32 address) }; } - ccc::FunctionHandle handle = m_cpu->GetSymbolGuardian().FunctionOverlappingAddress(address).handle; - if (!handle.valid()) + // Use the address to pick the colour since the value of the handle may + // change from run to run. + ccc::Address function_address = + m_cpu->GetSymbolGuardian().FunctionOverlappingAddress(address).address; + if (!function_address.valid()) return palette().text().color(); - return colors[handle.value % colors.size()]; + // Chop off the first few bits of the address since functions will be + // aligned in memory. + return colors[(function_address.value >> 4) % colors.size()]; } QString DisassemblyWidget::FetchSelectionInfo(SelectionInfo selInfo)