mirror of
https://github.com/momo5502/hypervisor.git
synced 2025-04-19 13:42:55 +00:00
Small cleanup
This commit is contained in:
parent
965dd3a5bc
commit
85904bfd13
@ -37,34 +37,15 @@ namespace
|
||||
return STATUS_SUCCESS;
|
||||
}
|
||||
|
||||
void apply_hook(const hook_request& request)
|
||||
vmx::ept_translation_hint* generate_translation_hints(uint32_t process_id, const void* target_address, size_t size)
|
||||
{
|
||||
auto* buffer = new uint8_t[request.source_data_size];
|
||||
if (!buffer)
|
||||
vmx::ept_translation_hint* translation_hints{nullptr};
|
||||
|
||||
thread::kernel_thread t([&translation_hints, process_id, target_address, size]
|
||||
{
|
||||
throw std::runtime_error("Failed to copy buffer");
|
||||
}
|
||||
debug_log("Looking up process: %d\n", process_id);
|
||||
|
||||
vmx::ept_translation_hint* translation_hints = nullptr;
|
||||
auto destructor = utils::finally([&translation_hints, &buffer]()
|
||||
{
|
||||
delete[] buffer;
|
||||
vmx::ept::free_translation_hints(translation_hints);
|
||||
});
|
||||
|
||||
memcpy(buffer, request.source_data, request.source_data_size);
|
||||
|
||||
auto* hypervisor = hypervisor::get_instance();
|
||||
if (!hypervisor)
|
||||
{
|
||||
throw std::runtime_error("Hypervisor not installed");
|
||||
}
|
||||
|
||||
thread::kernel_thread t([&translation_hints, r = request]
|
||||
{
|
||||
debug_log("Pid: %d | Address: %p\n", r.process_id, r.target_address);
|
||||
|
||||
const auto process_handle = process::find_process_by_id(r.process_id);
|
||||
const auto process_handle = process::find_process_by_id(process_id);
|
||||
if (!process_handle || !process_handle.is_alive())
|
||||
{
|
||||
debug_log("Bad process\n");
|
||||
@ -78,18 +59,46 @@ namespace
|
||||
}
|
||||
|
||||
process::scoped_process_attacher attacher{process_handle};
|
||||
translation_hints = vmx::ept::generate_translation_hints(r.target_address, r.source_data_size);
|
||||
|
||||
debug_log("Generating translation hints for address: %p\n", target_address);
|
||||
translation_hints = vmx::ept::generate_translation_hints(target_address, size);
|
||||
});
|
||||
|
||||
t.join();
|
||||
|
||||
return translation_hints;
|
||||
}
|
||||
|
||||
void apply_hook(const hook_request& request)
|
||||
{
|
||||
auto* hypervisor = hypervisor::get_instance();
|
||||
if (!hypervisor)
|
||||
{
|
||||
throw std::runtime_error("Hypervisor not installed");
|
||||
}
|
||||
|
||||
std::unique_ptr<uint8_t[]> buffer(new uint8_t[request.source_data_size]);
|
||||
if (!buffer)
|
||||
{
|
||||
throw std::runtime_error("Failed to copy buffer");
|
||||
}
|
||||
|
||||
vmx::ept_translation_hint* translation_hints = nullptr;
|
||||
auto destructor = utils::finally([&translation_hints]()
|
||||
{
|
||||
vmx::ept::free_translation_hints(translation_hints);
|
||||
});
|
||||
|
||||
memcpy(buffer.get(), request.source_data, request.source_data_size);
|
||||
translation_hints = generate_translation_hints(request.process_id, request.target_address, request.source_data_size);
|
||||
|
||||
if (!translation_hints)
|
||||
{
|
||||
debug_log("Failed to generate tranlsation hints\n");
|
||||
return;
|
||||
}
|
||||
|
||||
hypervisor->install_ept_hook(request.target_address, buffer, request.source_data_size,
|
||||
hypervisor->install_ept_hook(request.target_address, buffer.get(), request.source_data_size,
|
||||
translation_hints);
|
||||
}
|
||||
|
||||
|
@ -132,4 +132,14 @@ namespace std
|
||||
struct is_array<T[N]> : std::true_type
|
||||
{
|
||||
};
|
||||
|
||||
|
||||
template<class T>
|
||||
struct remove_extent { typedef T type; };
|
||||
|
||||
template<class T>
|
||||
struct remove_extent<T[]> { typedef T type; };
|
||||
|
||||
template<class T, std::size_t N>
|
||||
struct remove_extent<T[N]> { typedef T type; };
|
||||
}
|
||||
|
@ -7,9 +7,11 @@ namespace std
|
||||
class unique_ptr
|
||||
{
|
||||
public:
|
||||
using value_type = typename remove_extent<T>::type;
|
||||
|
||||
unique_ptr() = default;
|
||||
|
||||
unique_ptr(T* pointer)
|
||||
unique_ptr(value_type* pointer)
|
||||
: pointer_(pointer)
|
||||
{
|
||||
}
|
||||
@ -44,22 +46,27 @@ namespace std
|
||||
unique_ptr(const unique_ptr<T>& obj) = delete;
|
||||
unique_ptr& operator=(const unique_ptr<T>& obj) = delete;
|
||||
|
||||
T* operator->()
|
||||
value_type* get()
|
||||
{
|
||||
return this->pointer_;
|
||||
}
|
||||
|
||||
const T* operator->() const
|
||||
value_type* operator->()
|
||||
{
|
||||
return this->pointer_;
|
||||
}
|
||||
|
||||
T& operator*()
|
||||
const value_type* operator->() const
|
||||
{
|
||||
return this->pointer_;
|
||||
}
|
||||
|
||||
value_type& operator*()
|
||||
{
|
||||
return *this->pointer_;
|
||||
}
|
||||
|
||||
const T& operator*() const
|
||||
const value_type& operator*() const
|
||||
{
|
||||
return *this->pointer_;
|
||||
}
|
||||
@ -71,7 +78,7 @@ namespace std
|
||||
|
||||
private:
|
||||
static constexpr auto is_array_type = is_array<T>::value;
|
||||
T* pointer_{nullptr};
|
||||
value_type* pointer_{nullptr};
|
||||
|
||||
void delete_pointer() const
|
||||
{
|
||||
|
Loading…
x
Reference in New Issue
Block a user