From a111ac1cb59d7e5ed0f59f9c29f87242a5218c1b Mon Sep 17 00:00:00 2001 From: Silent Date: Thu, 11 Dec 2014 01:15:05 +0100 Subject: [PATCH] German newsteam r2 support --- SAFix/SilentPatchSA.cpp | 113 ++++++++++++++++++++++++---------------- SilentPatch/MemoryMgr.h | 11 ++-- 2 files changed, 76 insertions(+), 48 deletions(-) diff --git a/SAFix/SilentPatchSA.cpp b/SAFix/SilentPatchSA.cpp index e35bb6c..61bc630 100644 --- a/SAFix/SilentPatchSA.cpp +++ b/SAFix/SilentPatchSA.cpp @@ -3128,54 +3128,24 @@ void Patch_SA_NewSteam_r2() { using namespace MemoryVP::DynBase; - // Nazi EXE? - if ( *(DWORD*)DynBaseAddress(0x49F810) == 0x64EC8B55 ) - { - // Regular + // No framedelay + InjectHook(0x54ECC6, DynBaseAddress(0x54ED0C), PATCH_JUMP); + Patch(0x54ED45, 0x4); + Nop(0x54ED47, 1); - // No framedelay - InjectHook(0x54ECC6, DynBaseAddress(0x54ED0C), PATCH_JUMP); - Patch(0x54ED45, 0x4); - Nop(0x54ED47, 1); + // Unlock 1.0/1.01 saves loading + Patch(0x5ED349, 0xE990); - // Unlock 1.0/1.01 saves loading - Patch(0x5ED349, 0xE990); - - // Old .set files working again - static const DWORD dwSetVersion = 6; - Patch(0x5904CA, &dwSetVersion); - Patch(0x5907AD, 6); - Patch(0x53EC4A, 6); - - // Disable re-initialization of DirectInput mouse device by the game - Patch(0x58A881, 0xEB); - Patch(0x58AA67, 0xEB); - Patch(0x58AB49, 0xEB); - } - else - { - // Nazi - - // No framedelay - InjectHook(0x54EC06, DynBaseAddress(0x54EC4C), PATCH_JUMP); - Patch(0x54EC85, 0x4); - Nop(0x54EC87, 1); - - // Unlock 1.0/1.01 saves loading - Patch(0x5ED349, 0xE990); - - // Old .set files working again - static const DWORD dwSetVersion = 6; - Patch(0x5904DA, &dwSetVersion); - Patch(0x5907BD, 6); - Patch(0x53EB9A, 6); - - // Disable re-initialization of DirectInput mouse device by the game - Patch(0x58A7D1, 0xEB); - Patch(0x58A9B7, 0xEB); - Patch(0x58AA99, 0xEB); - } + // Old .set files working again + static const DWORD dwSetVersion = 6; + Patch(0x5904CA, &dwSetVersion); + Patch(0x5907AD, 6); + Patch(0x53EC4A, 6); + // Disable re-initialization of DirectInput mouse device by the game + Patch(0x58A881, 0xEB); + Patch(0x58AA67, 0xEB); + Patch(0x58AB49, 0xEB); // Unlocked widescreen resolutions //Patch(0x779BAD, 0x607D); @@ -3185,6 +3155,7 @@ void Patch_SA_NewSteam_r2() Nop(0x7799DC, 2); // Make sure DirectInput mouse device is set non-exclusive (may not be needed?) + // TODO: Nazi exe Nop(0x77AB6F, 1); Patch(0x77AB70, 0x01B0); @@ -3205,6 +3176,57 @@ void Patch_SA_NewSteam_r2() Patch(0x73427A, &f43); } +void Patch_SA_NewSteam_r2_lv() +{ + using namespace MemoryVP::DynBase; + + // No framedelay + InjectHook(0x54EC06, DynBaseAddress(0x54EC4C), PATCH_JUMP); + Patch(0x54EC85, 0x4); + Nop(0x54EC87, 1); + + // Unlock 1.0/1.01 saves loading + Patch(0x5ED299, 0xE990); + + // Old .set files working again + static const DWORD dwSetVersion = 6; + Patch(0x59040A, &dwSetVersion); + Patch(0x5906ED, 6); + Patch(0x53EB9A, 6); + + // Disable re-initialization of DirectInput mouse device by the game + Patch(0x58A7C1, 0xEB); + Patch(0x58A9A7, 0xEB); + Patch(0x58AA89, 0xEB); + + // Unlocked widescreen resolutions + //Patch(0x779BAD, 0x607D); + Patch(0x779AB8, 0x697D); + Patch(0x7798C8, 0x9090117D); + Nop(0x779946, 2); + Nop(0x7798CC, 2); + + // Make sure DirectInput mouse device is set non-exclusive (may not be needed?) + Nop(0x77AA5F, 1); + Patch(0x77AA60, 0x01B0); + + // Default resolution to native resolution + RECT desktop; + GetWindowRect(GetDesktopWindow(), &desktop); + _snprintf(aNoDesktopMode, sizeof(aNoDesktopMode), "Cannot find %dx%dx32 video mode", desktop.right, desktop.bottom); + + Patch(0x77A30F, desktop.right); + Patch(0x77A314, desktop.bottom); + Patch(0x77A36B, aNoDesktopMode); + + + // Proper aspect ratios + static const float f43 = 4.0f/3.0f, f54 = 5.0f/4.0f, f169 = 16.0f/9.0f; + Patch(0x73414B, &f169); + Patch(0x734167, &f54); + Patch(0x73417A, &f43); +} + BOOL WINAPI DllMain(HINSTANCE hinstDLL, DWORD fdwReason, LPVOID lpvReserved) { @@ -3220,6 +3242,7 @@ BOOL WINAPI DllMain(HINSTANCE hinstDLL, DWORD fdwReason, LPVOID lpvReserved) else if ( *(DWORD*)DynBaseAddress(0x858D21) == 0x3539F633) Patch_SA_NewSteam_r1(); else if ( *(DWORD*)DynBaseAddress(0x858D51) == 0x3539F633) Patch_SA_NewSteam_r2(); + else if ( *(DWORD*)DynBaseAddress(0x858C61) == 0x3539F633) Patch_SA_NewSteam_r2_lv(); else return FALSE; } diff --git a/SilentPatch/MemoryMgr.h b/SilentPatch/MemoryMgr.h index b66ba2f..4453f5b 100644 --- a/SilentPatch/MemoryMgr.h +++ b/SilentPatch/MemoryMgr.h @@ -153,6 +153,12 @@ inline T AddressByVersion(DWORD address10, DWORD address11, DWORD addressSteam) *bVer = 4; *bEuropean = false; } + else if ( *(DWORD*)DynBaseAddress(0x858C61) == 0x3539F633 ) + { + // newsteam r2 lv + *bVer = 5; + *bEuropean = false; + } } switch ( *bVer ) @@ -181,11 +187,10 @@ inline T AddressByVersion(DWORD address10, DWORD address11, DWORD addressSteam) return (T)addressSteam; case 3: + case 4: + case 5: // TODO: DO return (T)GetDummy(); - case 4: - // TODO: DO - return (T)GetDummy(); default: assert(address10); // Adjust to EU if needed