hookSystem: avoid using manual mem management, fix leak

fixes #10790
This commit is contained in:
Vaxry
2025-06-19 11:58:07 +02:00
parent 9fb6b5d96b
commit e999ad664d
2 changed files with 13 additions and 14 deletions

View File

@@ -182,8 +182,8 @@ bool CFunctionHook::hook() {
return false;
}
m_originalBytes = malloc(ORIGSIZE);
memcpy(m_originalBytes, m_source, ORIGSIZE);
m_originalBytes.resize(ORIGSIZE);
memcpy(m_originalBytes.data(), m_source, ORIGSIZE);
// populate trampoline
memcpy(m_trampolineAddr, PROBEFIXEDASM.bytes.data(), HOOKSIZE); // first, original but fixed func bytes
@@ -235,7 +235,7 @@ bool CFunctionHook::unhook() {
mprotect((uint8_t*)m_source - ((uint64_t)m_source) % sysconf(_SC_PAGE_SIZE), sysconf(_SC_PAGE_SIZE), PROT_READ | PROT_WRITE | PROT_EXEC);
// write back original bytes
memcpy(m_source, m_originalBytes, m_hookLen);
memcpy(m_source, m_originalBytes.data(), m_hookLen);
// revert mprot
mprotect((uint8_t*)m_source - ((uint64_t)m_source) % sysconf(_SC_PAGE_SIZE), sysconf(_SC_PAGE_SIZE), PROT_READ | PROT_EXEC);
@@ -245,9 +245,7 @@ bool CFunctionHook::unhook() {
m_hookLen = 0;
m_trampoLen = 0;
m_trampolineAddr = nullptr; // no unmapping, it's managed by the HookSystem
m_originalBytes = nullptr;
free(m_originalBytes);
m_originalBytes.clear();
return true;
}

View File

@@ -2,6 +2,7 @@
#include <string>
#include <vector>
#include <cstddef>
#include "../helpers/memory/Memory.hpp"
#define HANDLE void*
@@ -23,15 +24,15 @@ class CFunctionHook {
void* m_original = nullptr;
private:
void* m_source = nullptr;
void* m_trampolineAddr = nullptr;
void* m_destination = nullptr;
size_t m_hookLen = 0;
size_t m_trampoLen = 0;
HANDLE m_owner = nullptr;
bool m_active = false;
void* m_source = nullptr;
void* m_trampolineAddr = nullptr;
void* m_destination = nullptr;
size_t m_hookLen = 0;
size_t m_trampoLen = 0;
HANDLE m_owner = nullptr;
bool m_active = false;
void* m_originalBytes = nullptr;
std::vector<unsigned char> m_originalBytes;
struct SInstructionProbe {
size_t len = 0;