Tue, Apr 14, 2020 9:02:29 PM
This commit is contained in:
68
client/efi-mapper/kdmapper/utils.cpp
Normal file
68
client/efi-mapper/kdmapper/utils.cpp
Normal file
@@ -0,0 +1,68 @@
|
||||
#include "utils.hpp"
|
||||
|
||||
bool utils::ReadFileToMemory(const std::string& file_path, std::vector<uint8_t>* out_buffer)
|
||||
{
|
||||
std::ifstream file_ifstream(file_path, std::ios::binary);
|
||||
|
||||
if (!file_ifstream)
|
||||
return false;
|
||||
|
||||
out_buffer->assign((std::istreambuf_iterator<char>(file_ifstream)), std::istreambuf_iterator<char>());
|
||||
file_ifstream.close();
|
||||
|
||||
return true;
|
||||
}
|
||||
|
||||
bool utils::CreateFileFromMemory(const std::string& desired_file_path, const char* address, size_t size)
|
||||
{
|
||||
std::ofstream file_ofstream(desired_file_path.c_str(), std::ios_base::out | std::ios_base::binary);
|
||||
|
||||
if (!file_ofstream.write(address, size))
|
||||
{
|
||||
file_ofstream.close();
|
||||
return false;
|
||||
}
|
||||
|
||||
file_ofstream.close();
|
||||
return true;
|
||||
}
|
||||
|
||||
uint64_t utils::GetKernelModuleAddress(const std::string& module_name)
|
||||
{
|
||||
void* buffer = nullptr;
|
||||
DWORD buffer_size = 0;
|
||||
|
||||
NTSTATUS status = NtQuerySystemInformation(static_cast<SYSTEM_INFORMATION_CLASS>(nt::SystemModuleInformation), buffer, buffer_size, &buffer_size);
|
||||
|
||||
while (status == nt::STATUS_INFO_LENGTH_MISMATCH)
|
||||
{
|
||||
VirtualFree(buffer, 0, MEM_RELEASE);
|
||||
|
||||
buffer = VirtualAlloc(nullptr, buffer_size, MEM_COMMIT | MEM_RESERVE, PAGE_READWRITE);
|
||||
status = NtQuerySystemInformation(static_cast<SYSTEM_INFORMATION_CLASS>(nt::SystemModuleInformation), buffer, buffer_size, &buffer_size);
|
||||
}
|
||||
|
||||
if (!NT_SUCCESS(status))
|
||||
{
|
||||
VirtualFree(buffer, 0, MEM_RELEASE);
|
||||
return 0;
|
||||
}
|
||||
|
||||
const auto modules = static_cast<nt::PRTL_PROCESS_MODULES>(buffer);
|
||||
|
||||
for (auto i = 0u; i < modules->NumberOfModules; ++i)
|
||||
{
|
||||
const std::string current_module_name = std::string(reinterpret_cast<char*>(modules->Modules[i].FullPathName) + modules->Modules[i].OffsetToFileName);
|
||||
|
||||
if (!_stricmp(current_module_name.c_str(), module_name.c_str()))
|
||||
{
|
||||
const uint64_t result = reinterpret_cast<uint64_t>(modules->Modules[i].ImageBase);
|
||||
|
||||
VirtualFree(buffer, 0, MEM_RELEASE);
|
||||
return result;
|
||||
}
|
||||
}
|
||||
|
||||
VirtualFree(buffer, 0, MEM_RELEASE);
|
||||
return 0;
|
||||
}
|
||||
Reference in New Issue
Block a user