mirror of
https://github.com/CookiePLMonster/SilentPatch.git
synced 2025-01-01 16:53:01 +05:00
Big update to MemoryMgr - streamlined, removed code duplication, addresses now in one place
This commit is contained in:
parent
b454985d8b
commit
157a99f0c1
2 changed files with 163 additions and 147 deletions
|
@ -62,21 +62,20 @@ inline AT DynBaseAddress(AT address)
|
||||||
return (ptrdiff_t)GetModuleHandle(nullptr) - 0x400000 + address;
|
return (ptrdiff_t)GetModuleHandle(nullptr) - 0x400000 + address;
|
||||||
}
|
}
|
||||||
|
|
||||||
#if defined _GTA_III
|
|
||||||
|
|
||||||
namespace Memory
|
namespace Memory
|
||||||
{
|
{
|
||||||
namespace internal
|
namespace internal
|
||||||
{
|
{
|
||||||
|
#if defined _GTA_III
|
||||||
inline void InitializeVersions()
|
inline void InitializeVersions()
|
||||||
{
|
{
|
||||||
signed char* bVer = GetVer();
|
signed char* bVer = GetVer();
|
||||||
|
|
||||||
if ( *bVer == -1 )
|
if ( *bVer == -1 )
|
||||||
{
|
{
|
||||||
if (*(uint32_t*)0x5C1E70 == 0x53E58955) *bVer = 0;
|
if (*(uint32_t*)0x5C1E75 == 0xB85548EC) *bVer = 0;
|
||||||
else if (*(uint32_t*)0x5C2130 == 0x53E58955) *bVer = 1;
|
else if (*(uint32_t*)0x5C2135 == 0xB85548EC) *bVer = 1;
|
||||||
else if (*(uint32_t*)0x5C6FD0 == 0x53E58955) *bVer = 2;
|
else if (*(uint32_t*)0x5C6FD5 == 0xB85548EC) *bVer = 2;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -106,24 +105,18 @@ namespace Memory
|
||||||
return address10;
|
return address10;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
#elif defined _GTA_VC
|
#elif defined _GTA_VC
|
||||||
|
|
||||||
namespace Memory
|
|
||||||
{
|
|
||||||
namespace internal
|
|
||||||
{
|
|
||||||
inline void InitializeVersions()
|
inline void InitializeVersions()
|
||||||
{
|
{
|
||||||
signed char* bVer = GetVer();
|
signed char* bVer = GetVer();
|
||||||
|
|
||||||
if ( *bVer == -1 )
|
if ( *bVer == -1 )
|
||||||
{
|
{
|
||||||
if (*(uint32_t*)0x667BF0 == 0x53E58955) *bVer = 0;
|
if (*(uint32_t*)0x667BF5 == 0xB85548EC) *bVer = 0;
|
||||||
else if (*(uint32_t*)0x667C40 == 0x53E58955) *bVer = 1;
|
else if (*(uint32_t*)0x667C45 == 0xB85548EC) *bVer = 1;
|
||||||
else if (*(uint32_t*)0x666BA0 == 0x53E58955) *bVer = 2;
|
else if (*(uint32_t*)0x666BA5 == 0xB85548EC) *bVer = 2;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -153,72 +146,105 @@ namespace Memory
|
||||||
return address10;
|
return address10;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
#elif defined _GTA_SA
|
#elif defined _GTA_SA
|
||||||
|
|
||||||
namespace Memory
|
inline bool TryMatch_10()
|
||||||
{
|
|
||||||
namespace internal
|
|
||||||
{
|
{
|
||||||
inline void InitializeVersions()
|
|
||||||
{
|
|
||||||
signed char* bVer = GetVer();
|
|
||||||
|
|
||||||
if ( *bVer == -1 )
|
|
||||||
{
|
|
||||||
bool* bEuropean = GetEuropean();
|
|
||||||
|
|
||||||
if ( *(uint32_t*)DynBaseAddress(0x82457C) == 0x94BF )
|
if ( *(uint32_t*)DynBaseAddress(0x82457C) == 0x94BF )
|
||||||
{
|
{
|
||||||
// 1.0 US
|
// 1.0 US
|
||||||
*bVer = 0;
|
*GetVer() = 0;
|
||||||
*bEuropean = false;
|
*GetEuropean() = false;
|
||||||
|
return true;
|
||||||
}
|
}
|
||||||
else if ( *(uint32_t*)DynBaseAddress(0x8245BC) == 0x94BF )
|
if ( *(uint32_t*)DynBaseAddress(0x8245BC) == 0x94BF )
|
||||||
{
|
{
|
||||||
// 1.0 EU
|
// 1.0 EU
|
||||||
*bVer = 0;
|
*GetVer() = 0;
|
||||||
*bEuropean = true;
|
*GetEuropean() = true;
|
||||||
|
return true;
|
||||||
}
|
}
|
||||||
else if ( *(uint32_t*)DynBaseAddress(0x8252FC) == 0x94BF )
|
return false;
|
||||||
{
|
|
||||||
// 1.01 US
|
|
||||||
*bVer = 1;
|
|
||||||
*bEuropean = false;
|
|
||||||
}
|
|
||||||
else if ( *(uint32_t*)DynBaseAddress(0x82533C) == 0x94BF )
|
|
||||||
{
|
|
||||||
// 1.01 EU
|
|
||||||
*bVer = 1;
|
|
||||||
*bEuropean = true;
|
|
||||||
}
|
|
||||||
else if (*(uint32_t*)DynBaseAddress(0x85EC4A) == 0x94BF )
|
|
||||||
{
|
|
||||||
// 3.0
|
|
||||||
*bVer = 2;
|
|
||||||
*bEuropean = false;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
else if ( *(uint32_t*)DynBaseAddress(0x858D21) == 0x3539F633 )
|
inline bool TryMatch_11()
|
||||||
|
{
|
||||||
|
if ( *(uint32_t*)DynBaseAddress(0x8252FC) == 0x94BF )
|
||||||
|
{
|
||||||
|
// 1.01 US
|
||||||
|
*GetVer() = 1;
|
||||||
|
*GetEuropean() = false;
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
if ( *(uint32_t*)DynBaseAddress(0x82533C) == 0x94BF )
|
||||||
|
{
|
||||||
|
// 1.01 EU
|
||||||
|
*GetVer() = 1;
|
||||||
|
*GetEuropean() = true;
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
inline bool TryMatch_30()
|
||||||
|
{
|
||||||
|
if (*(uint32_t*)DynBaseAddress(0x85EC4A) == 0x94BF )
|
||||||
|
{
|
||||||
|
// 3.0
|
||||||
|
*GetVer() = 2;
|
||||||
|
*GetEuropean() = false;
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
inline bool TryMatch_newsteam_r1()
|
||||||
|
{
|
||||||
|
if ( *(uint32_t*)DynBaseAddress(0x858D21) == 0x3539F633 )
|
||||||
{
|
{
|
||||||
// newsteam r1
|
// newsteam r1
|
||||||
*bVer = 3;
|
*GetVer() = 3;
|
||||||
*bEuropean = false;
|
*GetEuropean() = false;
|
||||||
|
return true;
|
||||||
}
|
}
|
||||||
else if ( *(uint32_t*)DynBaseAddress(0x858D51) == 0x3539F633 )
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
inline bool TryMatch_newsteam_r2()
|
||||||
|
{
|
||||||
|
if ( *(uint32_t*)DynBaseAddress(0x858D51) == 0x3539F633 )
|
||||||
{
|
{
|
||||||
// newsteam r2
|
// newsteam r2
|
||||||
*bVer = 4;
|
*GetVer() = 4;
|
||||||
*bEuropean = false;
|
*GetEuropean() = false;
|
||||||
|
return true;
|
||||||
}
|
}
|
||||||
else if ( *(uint32_t*)DynBaseAddress(0x858C61) == 0x3539F633 )
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
inline bool TryMatch_newsteam_r2_lv()
|
||||||
|
{
|
||||||
|
if ( *(uint32_t*)DynBaseAddress(0x858C61) == 0x3539F633 )
|
||||||
{
|
{
|
||||||
// newsteam r2 lv
|
// newsteam r2 lv
|
||||||
*bVer = 5;
|
*GetVer() = 5;
|
||||||
*bEuropean = false;
|
*GetEuropean() = false;
|
||||||
|
return true;
|
||||||
}
|
}
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
inline void InitializeVersions()
|
||||||
|
{
|
||||||
|
if ( *GetVer() == -1 )
|
||||||
|
{
|
||||||
|
if ( TryMatch_10() ) return;
|
||||||
|
if ( TryMatch_11() ) return;
|
||||||
|
if ( TryMatch_30() ) return;
|
||||||
|
if ( TryMatch_newsteam_r1() ) return;
|
||||||
|
if ( TryMatch_newsteam_r2() ) return;
|
||||||
|
if ( TryMatch_newsteam_r2_lv() ) return;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -228,19 +254,7 @@ namespace Memory
|
||||||
|
|
||||||
if ( *bVer == -1 )
|
if ( *bVer == -1 )
|
||||||
{
|
{
|
||||||
bool* bEuropean = GetEuropean();
|
if ( !TryMatch_10() )
|
||||||
|
|
||||||
if ( *(uint32_t*)0x82457C == 0x94BF )
|
|
||||||
{
|
|
||||||
*bVer = 0;
|
|
||||||
*bEuropean = false;
|
|
||||||
}
|
|
||||||
else if ( *(uint32_t*)0x8245BC == 0x94BF )
|
|
||||||
{
|
|
||||||
*bVer = 0;
|
|
||||||
*bEuropean = true;
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
{
|
||||||
#ifdef assert
|
#ifdef assert
|
||||||
assert(!"AddressByRegion_10 on non-1.0 EXE!");
|
assert(!"AddressByRegion_10 on non-1.0 EXE!");
|
||||||
|
@ -255,19 +269,7 @@ namespace Memory
|
||||||
|
|
||||||
if ( *bVer == -1 )
|
if ( *bVer == -1 )
|
||||||
{
|
{
|
||||||
bool* bEuropean = GetEuropean();
|
if ( !TryMatch_11() )
|
||||||
|
|
||||||
if ( *(uint32_t*)0x8252FC == 0x94BF )
|
|
||||||
{
|
|
||||||
*bVer = 1;
|
|
||||||
*bEuropean = false;
|
|
||||||
}
|
|
||||||
else if ( *(uint32_t*)0x82533C == 0x94BF )
|
|
||||||
{
|
|
||||||
*bVer = 1;
|
|
||||||
*bEuropean = true;
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
{
|
||||||
#ifdef assert
|
#ifdef assert
|
||||||
assert(!"AddressByRegion_11 on non-1.01 EXE!");
|
assert(!"AddressByRegion_11 on non-1.01 EXE!");
|
||||||
|
@ -276,12 +278,35 @@ namespace Memory
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
inline uintptr_t AdjustAddress_10(uintptr_t address10)
|
||||||
|
{
|
||||||
|
if ( *GetEuropean() && address10 > 0x7466D0 )
|
||||||
|
{
|
||||||
|
if ( address10 < 0x7BA940 )
|
||||||
|
address10 += 0x50;
|
||||||
|
else
|
||||||
|
address10 += 0x40;
|
||||||
|
}
|
||||||
|
return address10;
|
||||||
|
}
|
||||||
|
|
||||||
|
inline uintptr_t AdjustAddress_11(uintptr_t address11)
|
||||||
|
{
|
||||||
|
if ( !(*GetEuropean()) && address11 > 0x746FA0 )
|
||||||
|
{
|
||||||
|
if ( address11 < 0x7BB240 )
|
||||||
|
address11 -= 0x50;
|
||||||
|
else
|
||||||
|
address11 -= 0x40;
|
||||||
|
}
|
||||||
|
return address11;
|
||||||
|
}
|
||||||
|
|
||||||
inline uintptr_t AddressByVersion(uintptr_t address10, uintptr_t address11, uintptr_t addressSteam, uintptr_t addressNewsteamR2, uintptr_t addressNewsteamR2_LV)
|
inline uintptr_t AddressByVersion(uintptr_t address10, uintptr_t address11, uintptr_t addressSteam, uintptr_t addressNewsteamR2, uintptr_t addressNewsteamR2_LV)
|
||||||
{
|
{
|
||||||
InitializeVersions();
|
InitializeVersions();
|
||||||
|
|
||||||
signed char bVer = *GetVer();
|
signed char bVer = *GetVer();
|
||||||
const bool bEuropean = *GetEuropean();
|
|
||||||
|
|
||||||
switch ( bVer )
|
switch ( bVer )
|
||||||
{
|
{
|
||||||
|
@ -295,14 +320,7 @@ namespace Memory
|
||||||
return GetDummy();
|
return GetDummy();
|
||||||
|
|
||||||
// Adjust to US if needed
|
// Adjust to US if needed
|
||||||
if ( bEuropean && address11 > 0x746FA0 )
|
return AdjustAddress_11(address11);
|
||||||
{
|
|
||||||
if ( address11 < 0x7BB240 )
|
|
||||||
address11 -= 0x50;
|
|
||||||
else
|
|
||||||
address11 -= 0x40;
|
|
||||||
}
|
|
||||||
return address11;
|
|
||||||
case 2:
|
case 2:
|
||||||
#ifdef assert
|
#ifdef assert
|
||||||
assert(addressSteam);
|
assert(addressSteam);
|
||||||
|
@ -335,14 +353,7 @@ namespace Memory
|
||||||
assert(address10);
|
assert(address10);
|
||||||
#endif
|
#endif
|
||||||
// Adjust to EU if needed
|
// Adjust to EU if needed
|
||||||
if ( bEuropean && address10 > 0x7466D0 )
|
return AdjustAddress_10(address10);
|
||||||
{
|
|
||||||
if ( address10 < 0x7BA940 )
|
|
||||||
address10 += 0x50;
|
|
||||||
else
|
|
||||||
address10 += 0x40;
|
|
||||||
}
|
|
||||||
return address10;
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -350,40 +361,29 @@ namespace Memory
|
||||||
{
|
{
|
||||||
InitializeRegion_10();
|
InitializeRegion_10();
|
||||||
|
|
||||||
const bool bEuropean = *GetEuropean();
|
|
||||||
|
|
||||||
// Adjust to EU if needed
|
// Adjust to EU if needed
|
||||||
if ( bEuropean && address10 > 0x7466D0 )
|
return AdjustAddress_10(address10);
|
||||||
{
|
|
||||||
if ( address10 < 0x7BA940 )
|
|
||||||
address10 += 0x50;
|
|
||||||
else
|
|
||||||
address10 += 0x40;
|
|
||||||
}
|
|
||||||
return address10;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
inline uintptr_t AddressByRegion_11(uintptr_t address11)
|
inline uintptr_t AddressByRegion_11(uintptr_t address11)
|
||||||
{
|
{
|
||||||
InitializeRegion_11();
|
InitializeRegion_11();
|
||||||
|
|
||||||
const bool bEuropean = *GetEuropean();
|
|
||||||
|
|
||||||
// Adjust to US if needed
|
// Adjust to US if needed
|
||||||
if ( !bEuropean && address11 > 0x746FA0 )
|
return AdjustAddress_11(address11);
|
||||||
|
}
|
||||||
|
|
||||||
|
#else
|
||||||
|
|
||||||
|
inline void InitializeVersions()
|
||||||
{
|
{
|
||||||
if ( address11 < 0x7BB240 )
|
|
||||||
address11 -= 0x50;
|
|
||||||
else
|
|
||||||
address11 -= 0x40;
|
|
||||||
}
|
}
|
||||||
return address11;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
#if defined _GTA_III || defined _GTA_VC
|
#if defined _GTA_III || defined _GTA_VC
|
||||||
|
|
||||||
template<typename T>
|
template<typename T>
|
||||||
|
@ -420,6 +420,21 @@ inline T AddressByRegion_11(uintptr_t address11)
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
namespace Memory
|
||||||
|
{
|
||||||
|
struct VersionInfo
|
||||||
|
{
|
||||||
|
int8_t version;
|
||||||
|
bool european;
|
||||||
|
};
|
||||||
|
|
||||||
|
inline VersionInfo GetVersion()
|
||||||
|
{
|
||||||
|
Memory::internal::InitializeVersions();
|
||||||
|
return { *Memory::internal::GetVer(), *Memory::internal::GetEuropean() };
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
namespace Memory
|
namespace Memory
|
||||||
{
|
{
|
||||||
template<typename T, typename AT>
|
template<typename T, typename AT>
|
||||||
|
|
|
@ -715,7 +715,7 @@ void DrawRect_HalfPixel_Steam(CRect& rect, const CRGBA& rgba)
|
||||||
char* GetMyDocumentsPathSA()
|
char* GetMyDocumentsPathSA()
|
||||||
{
|
{
|
||||||
static char cUserFilesPath[MAX_PATH];
|
static char cUserFilesPath[MAX_PATH];
|
||||||
static char* const ppTempBufPtr = *Memory::internal::GetVer() == 0 ? *AddressByRegion_10<char**>(0x744FE5) : cUserFilesPath;
|
static char* const ppTempBufPtr = Memory::GetVersion().version == 0 ? *AddressByRegion_10<char**>(0x744FE5) : cUserFilesPath;
|
||||||
|
|
||||||
static bool initPath = [&] () {
|
static bool initPath = [&] () {
|
||||||
char** const ppUserFilesDir = AddressByVersion<char**>(0x74503F, 0x74586F, 0x77EE50, 0x77902B, 0x778F1B);
|
char** const ppUserFilesDir = AddressByVersion<char**>(0x74503F, 0x74586F, 0x77EE50, 0x77902B, 0x778F1B);
|
||||||
|
@ -1707,7 +1707,7 @@ void __declspec(naked) TrailerDoubleRWheelsFix2_Steam()
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
static void* LoadFLAC_JumpBack = AddressByVersion<void*>(0x4F3743, *Memory::internal::GetVer() == 1 ? (*(BYTE*)0x4F3A50 == 0x6A ? 0x4F3BA3 : 0x5B6B81) : 0, 0x4FFC3F);
|
static void* LoadFLAC_JumpBack = AddressByVersion<void*>(0x4F3743, Memory::GetVersion().version == 1 ? (*(BYTE*)0x4F3A50 == 0x6A ? 0x4F3BA3 : 0x5B6B81) : 0, 0x4FFC3F);
|
||||||
void __declspec(naked) LoadFLAC()
|
void __declspec(naked) LoadFLAC()
|
||||||
{
|
{
|
||||||
_asm
|
_asm
|
||||||
|
@ -4666,14 +4666,15 @@ BOOL WINAPI DllMain(HINSTANCE hinstDLL, DWORD fdwReason, LPVOID lpvReserved)
|
||||||
std::unique_ptr<ScopedUnprotect::Unprotect> Protect = ScopedUnprotect::UnprotectSectionOrFullModule( hInstance, ".text" );
|
std::unique_ptr<ScopedUnprotect::Unprotect> Protect = ScopedUnprotect::UnprotectSectionOrFullModule( hInstance, ".text" );
|
||||||
ScopedUnprotect::Section Protect2( hInstance, ".rdata" );
|
ScopedUnprotect::Section Protect2( hInstance, ".rdata" );
|
||||||
|
|
||||||
if (*(DWORD*)DynBaseAddress(0x82457C) == 0x94BF || *(DWORD*)DynBaseAddress(0x8245BC) == 0x94BF) Patch_SA_10();
|
const int8_t version = Memory::GetVersion().version;
|
||||||
else if (*(DWORD*)DynBaseAddress(0x8252FC) == 0x94BF || *(DWORD*)DynBaseAddress(0x82533C) == 0x94BF) Patch_SA_11(); // Not supported anymore
|
if ( version == 0 ) Patch_SA_10();
|
||||||
else if (*(DWORD*)DynBaseAddress(0x85EC4A) == 0x94BF) Patch_SA_Steam(); // Not supported anymore
|
else if ( version == 1 ) Patch_SA_11(); // Not supported anymore
|
||||||
|
else if ( version == 2 ) Patch_SA_Steam(); // Not supported anymore
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
if ( *(DWORD*)DynBaseAddress(0x858D21) == 0x3539F633) Patch_SA_NewSteam_r1();
|
if ( version == 3 ) Patch_SA_NewSteam_r1();
|
||||||
else if ( *(DWORD*)DynBaseAddress(0x858D51) == 0x3539F633) Patch_SA_NewSteam_r2();
|
else if ( version == 4 ) Patch_SA_NewSteam_r2();
|
||||||
else if ( *(DWORD*)DynBaseAddress(0x858C61) == 0x3539F633) Patch_SA_NewSteam_r2_lv();
|
else if ( version == 5 ) Patch_SA_NewSteam_r2_lv();
|
||||||
Patch_SA_NewSteam_Common();
|
Patch_SA_NewSteam_Common();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue