From 00f2a30b71a036a3fd7688f3825ea36c9ca92295 Mon Sep 17 00:00:00 2001 From: omegadox Date: Fri, 13 Nov 2009 01:26:26 +0000 Subject: [PATCH] Some AR Fixes, and speedup Patch Event so AR can apply Code increments faster than the game execution, this helps fixes Jump code in some games. git-svn-id: https://dolphin-emu.googlecode.com/svn/trunk@4551 8ced0084-cf51-0410-be5f-012b33b47a6e --- Source/Core/Core/Src/ActionReplay.cpp | 41 ++++++++++++++---------- Source/Core/Core/Src/HW/SystemTimers.cpp | 3 +- Source/Core/Core/Src/PatchEngine.cpp | 1 + 3 files changed, 26 insertions(+), 19 deletions(-) diff --git a/Source/Core/Core/Src/ActionReplay.cpp b/Source/Core/Core/Src/ActionReplay.cpp index 7a752960a1..dd7452590e 100644 --- a/Source/Core/Core/Src/ActionReplay.cpp +++ b/Source/Core/Core/Src/ActionReplay.cpp @@ -51,7 +51,7 @@ enum ZCODE_END = 0x00, ZCODE_NORM = 0x02, ZCODE_ROW = 0x03, - ZCODE_MEM_COPY = 0x04, + ZCODE_04 = 0x04, // Conditonal Codes CONDTIONAL_IF_EQUAL = 0x01, @@ -227,16 +227,17 @@ void LogInfo(const char *format, ...) void RunAllActive() { - if (SConfig::GetInstance().m_LocalCoreStartupParameter.bEnableCheats) { + if (SConfig::GetInstance().m_LocalCoreStartupParameter.bEnableCheats) + { for (std::vector::iterator i = activeCodes.begin(); i != activeCodes.end(); ++i) { if (i->active) { - if (!RunCode(*i)) - i->active = false; + i->active = RunCode(*i); LogInfo("\n"); } } + if (!b_RanOnce) b_RanOnce = true; } @@ -292,16 +293,18 @@ bool RunCode(const ARCode &arcode) { LogInfo("Command: %08x", cmd); // Do Fill & Slide - if (doFillNSlide) { + if (doFillNSlide) + { doFillNSlide = false; LogInfo("Doing Fill And Slide"); if (!ZeroCode_FillAndSlide(val_last, addr, data)) return false; continue; - } + } // Memory Copy - if (doMemoryCopy) { + if (doMemoryCopy) + { doMemoryCopy = false; LogInfo("Doing Memory Copy"); if (!ZeroCode_MemoryCopy(val_last, addr, data)) @@ -310,7 +313,8 @@ bool RunCode(const ARCode &arcode) { } // ActionReplay program self modification codes - if (addr >= 0x00002000 && addr < 0x00003000) { + if (addr >= 0x00002000 && addr < 0x00003000) + { LogInfo("This action replay simulator does not support codes that modify Action Replay itself."); PanicAlert("This action replay simulator does not support codes that modify Action Replay itself."); return false; @@ -339,7 +343,7 @@ bool RunCode(const ARCode &arcode) { LogInfo("ZCode: Executes all codes in the same row, Set register 1BB4 to 1 (zcode not supported)"); PanicAlert("Zero 3 code not supported"); return false; - case ZCODE_MEM_COPY: // Fill & Slide or Memory Copy + case ZCODE_04: // Fill & Slide or Memory Copy if (((addr >> 25) & 0x03) == 0x3) { LogInfo("ZCode: Memory Copy"); @@ -554,7 +558,7 @@ bool Subtype_WriteToPointer(u32 addr, u32 data) bool Subtype_AddCode(u32 addr, u32 data) { // Used to incrment a value in memory - u32 new_addr = (addr & 0x01FFFFFF) | 0x80000000; + u32 new_addr = (addr & 0x81FFFFFF); u8 size = (addr >> 25) & 0x03; LogInfo("Hardware Address: %08x", new_addr); LogInfo("Size: %08x", size); @@ -585,12 +589,15 @@ bool Subtype_AddCode(u32 addr, u32 data) { LogInfo("32-bit floating Add"); LogInfo("--------"); - union conv {float x; u32 y;}; - conv c1; - c1.y = Memory::Read_U32(new_addr); - c1.x += (float)data; - Memory::Write_U32((u32)c1.x, new_addr); - LogInfo("Wrote %08x to address %08x", (u32)c1.x, new_addr); + + u32 read = Memory::Read_U32(new_addr); + float fread = *((float*)&read); + fread += (float)data; + u32 newval = *((u32*)&fread); + Memory::Write_U32(newval, new_addr); + LogInfo("Old Value %08x", read); + LogInfo("Increment %08x", data); + LogInfo("New value %08x", newval); LogInfo("--------"); break; } @@ -615,7 +622,7 @@ bool Subtype_MasterCodeAndWriteToCCXXXXXX(u32 addr, u32 data) bool ZeroCode_FillAndSlide(u32 val_last, u32 addr, u32 data) // This needs more testing { - u32 new_addr = (val_last & 0x01FFFFFF) | 0x80000000; + u32 new_addr = (val_last & 0x81FFFFFF); u8 size = (val_last >> 25) & 0x03; s16 addr_incr = (s16)(data & 0xFFFF); s8 val_incr = (s8)((data & 0xFF000000) >> 24); diff --git a/Source/Core/Core/Src/HW/SystemTimers.cpp b/Source/Core/Core/Src/HW/SystemTimers.cpp index 698e03ea4a..e013f90f93 100644 --- a/Source/Core/Core/Src/HW/SystemTimers.cpp +++ b/Source/Core/Core/Src/HW/SystemTimers.cpp @@ -235,8 +235,7 @@ void PatchEngineCallback(u64 userdata, int cyclesLate) // Patch mem and run the Action Replay PatchEngine::ApplyFramePatches(); PatchEngine::ApplyARPatches(); - - CoreTiming::ScheduleEvent((GetTicksPerSecond() / 60) - cyclesLate, et_PatchEngine); + CoreTiming::ScheduleEvent((CPU_CORE_CLOCK / 5000) - cyclesLate, et_PatchEngine); } void Init() diff --git a/Source/Core/Core/Src/PatchEngine.cpp b/Source/Core/Core/Src/PatchEngine.cpp index ec6cdd6849..6080c39b74 100644 --- a/Source/Core/Core/Src/PatchEngine.cpp +++ b/Source/Core/Core/Src/PatchEngine.cpp @@ -19,6 +19,7 @@ // Supports simple memory patches, and has a partial Action Replay implementation // in ActionReplay.cpp/h. +// TODO: Still even needed? Zelda WW now works with improved DSP code. // Zelda item hang fixes: // [Tue Aug 21 2007] [18:30:40] 0x802904b4 in US released // [Tue Aug 21 2007] [18:30:53] 0x80294d54 in EUR Demo version