94 lines
3.1 KiB
C++
Raw Normal View History

#include "FunctionData.h"
2024-11-27 20:44:36 +01:00
#include "utils/logger.h"
2024-11-27 20:44:36 +01:00
#include <function_patcher/function_patching.h>
#include <string>
FunctionData::FunctionData(void *paddress, void *vaddress,
const std::string_view name,
const function_replacement_library_type_t library,
void *replaceAddr, void *replaceCall,
const FunctionPatcherTargetProcess targetProcess) {
this->mPAddress = paddress;
this->mVAddress = vaddress;
this->mName = name;
this->mLibrary = library;
this->mTargetProcess = targetProcess;
this->mReplaceAddr = replaceAddr;
this->mReplaceCall = replaceCall;
}
FunctionData::~FunctionData() {
2024-11-27 20:44:36 +01:00
if (mHandle != 0) {
DEBUG_FUNCTION_LINE_WARN("Destroying FunctionData while it was still patched. This should never happen.");
RemovePatch();
}
}
const std::string &FunctionData::getName() const {
2024-11-27 20:44:36 +01:00
return this->mName;
}
function_replacement_library_type_t FunctionData::getLibrary() const {
2024-11-27 20:44:36 +01:00
return this->mLibrary;
}
const void *FunctionData::getPhysicalAddress() const {
2024-11-27 20:44:36 +01:00
return mPAddress;
}
const void *FunctionData::getVirtualAddress() const {
2024-11-27 20:44:36 +01:00
return mVAddress;
}
const void *FunctionData::getReplaceAddress() const {
2024-11-27 20:44:36 +01:00
return mReplaceAddr;
}
const void *FunctionData::getReplaceCall() const {
2024-11-27 20:44:36 +01:00
return mReplaceCall;
}
FunctionPatcherTargetProcess FunctionData::getTargetProcess() const {
2024-11-27 20:44:36 +01:00
return mTargetProcess;
}
bool FunctionData::AddPatch() {
2024-11-27 20:44:36 +01:00
if (mHandle == 0) {
function_replacement_data_t functionData = {
.version = FUNCTION_REPLACEMENT_DATA_STRUCT_VERSION,
.type = FUNCTION_PATCHER_REPLACE_BY_LIB_OR_ADDRESS,
2024-11-27 20:44:36 +01:00
.physicalAddr = reinterpret_cast<uint32_t>(this->mPAddress),
.virtualAddr = reinterpret_cast<uint32_t>(this->mVAddress),
.replaceAddr = reinterpret_cast<uint32_t>(this->mReplaceAddr),
.replaceCall = static_cast<uint32_t *>(this->mReplaceCall),
.targetProcess = this->mTargetProcess,
.ReplaceInRPL = {
2024-11-27 20:44:36 +01:00
.function_name = this->mName.c_str(),
.library = this->mLibrary,
}};
2024-11-27 20:44:36 +01:00
if (FunctionPatcher_AddFunctionPatch(&functionData, &mHandle, nullptr) != FUNCTION_PATCHER_RESULT_SUCCESS) {
DEBUG_FUNCTION_LINE_ERR("Failed to add patch for function (\"%s\" PA:%08X VA:%08X)", this->mName.c_str(), this->mPAddress, this->mVAddress);
return false;
}
} else {
DEBUG_FUNCTION_LINE("Function patch has already been added.");
}
return true;
}
bool FunctionData::RemovePatch() {
2024-11-27 20:44:36 +01:00
if (mHandle != 0) {
if (FunctionPatcher_RemoveFunctionPatch(mHandle) != FUNCTION_PATCHER_RESULT_SUCCESS) {
DEBUG_FUNCTION_LINE_ERR("Failed to remove patch for function");
return false;
}
2024-11-27 20:44:36 +01:00
mHandle = 0;
} else {
DEBUG_FUNCTION_LINE_VERBOSE("Was not patched.");
}
return true;
}