diff options
author | Fire_Head <Fire-Head@users.noreply.github.com> | 2020-03-29 17:39:47 +0200 |
---|---|---|
committer | GitHub <noreply@github.com> | 2020-03-29 17:39:47 +0200 |
commit | a0b077574e95e49ad845a6c9dc1af906b17277f9 (patch) | |
tree | de9f8dbd0e3c06ffbb95b13c0637dfc3db3873c1 /src/core/patcher.cpp | |
parent | style & cosmetic fixes (diff) | |
parent | Merge pull request #367 from Sergeanur/wrappers_cleanup (diff) | |
download | re3-a0b077574e95e49ad845a6c9dc1af906b17277f9.tar re3-a0b077574e95e49ad845a6c9dc1af906b17277f9.tar.gz re3-a0b077574e95e49ad845a6c9dc1af906b17277f9.tar.bz2 re3-a0b077574e95e49ad845a6c9dc1af906b17277f9.tar.lz re3-a0b077574e95e49ad845a6c9dc1af906b17277f9.tar.xz re3-a0b077574e95e49ad845a6c9dc1af906b17277f9.tar.zst re3-a0b077574e95e49ad845a6c9dc1af906b17277f9.zip |
Diffstat (limited to '')
-rw-r--r-- | src/core/patcher.cpp | 57 |
1 files changed, 57 insertions, 0 deletions
diff --git a/src/core/patcher.cpp b/src/core/patcher.cpp index 5fdbdf8b..19ca5f07 100644 --- a/src/core/patcher.cpp +++ b/src/core/patcher.cpp @@ -1,6 +1,11 @@ #include "common.h" #include "patcher.h" +#include <algorithm> +#include <vector> + +#include <Windows.h> + StaticPatcher *StaticPatcher::ms_head; StaticPatcher::StaticPatcher(Patcher func) @@ -20,3 +25,55 @@ StaticPatcher::Apply() } ms_head = nil; } + +std::vector<uint32> usedAddresses; + +static DWORD protect[2]; +static uint32 protect_address; +static uint32 protect_size; + +void +Protect_internal(uint32 address, uint32 size) +{ + protect_address = address; + protect_size = size; + VirtualProtect((void*)address, size, PAGE_EXECUTE_READWRITE, &protect[0]); +} + +void +Unprotect_internal(void) +{ + VirtualProtect((void*)protect_address, protect_size, protect[0], &protect[1]); +} + +void +InjectHook_internal(uint32 address, uint32 hook, int type) +{ + if(std::any_of(usedAddresses.begin(), usedAddresses.end(), + [address](uint32 value) { return value == address; })) { + debug("Used address %#06x twice when injecting hook\n", address); + } + + usedAddresses.push_back(address); + + + switch(type){ + case PATCH_JUMP: + VirtualProtect((void*)address, 5, PAGE_EXECUTE_READWRITE, &protect[0]); + *(uint8*)address = 0xE9; + break; + case PATCH_CALL: + VirtualProtect((void*)address, 5, PAGE_EXECUTE_READWRITE, &protect[0]); + *(uint8*)address = 0xE8; + break; + default: + VirtualProtect((void*)(address + 1), 4, PAGE_EXECUTE_READWRITE, &protect[0]); + break; + } + + *(ptrdiff_t*)(address + 1) = hook - address - 5; + if(type == PATCH_NOTHING) + VirtualProtect((void*)(address + 1), 4, protect[0], &protect[1]); + else + VirtualProtect((void*)address, 5, protect[0], &protect[1]); +}
\ No newline at end of file |