#include <palacios/vm_guest.h>
#include <palacios/vmm_mem_hook.h>
#include <palacios/vmm_emulator.h>
+#include <palacios/vm_guest_mem.h>
struct mem_hook {
static int handle_mem_hook(struct guest_info * info, addr_t guest_va, addr_t guest_pa,
- struct v3_shadow_region * reg, pf_error_t access_info) {
+ struct v3_mem_region * reg, pf_error_t access_info) {
struct mem_hook * hook = reg->priv_data;
+ struct v3_mem_hooks * hooks = &(info->vm_info->mem_hooks);
addr_t op_addr = 0;
if (reg->flags.alloced == 0) {
- op_addr = hook->hook_hva;
+ if (hook->hook_hva & 0xfff) {
+ op_addr = (addr_t)(hooks->hook_hvas + (PAGE_SIZE * info->cpu_id));
+ } else {
+ op_addr = hook->hook_hva;
+ }
} else {
- op_addr = (addr_t)V3_VAddr((void *)v3_get_shadow_addr(reg, info->cpu_id, guest_pa));
+ if (v3_gpa_to_hva(info, guest_pa, &op_addr) == -1) {
+ PrintError("Could not translate hook address (%p)\n", (void *)guest_pa);
+ return -1;
+ }
}
if (access_info.write == 1) {
// Write Operation
-
if (v3_emulate_write_op(info, guest_va, guest_pa, op_addr,
hook->write, hook->priv_data) == -1) {
PrintError("Write Full Hook emulation failed\n");
addr_t guest_addr_start, addr_t guest_addr_end, addr_t host_addr,
int (*write)(struct guest_info * core, addr_t guest_addr, void * src, uint_t length, void * priv_data),
void * priv_data) {
- struct v3_shadow_region * entry = NULL;
+ struct v3_mem_region * entry = NULL;
struct mem_hook * hook = V3_Malloc(sizeof(struct mem_hook));
// struct v3_mem_hooks * hooks = &(vm->mem_hooks);
entry->flags.exec = 1;
entry->flags.alloced = 1;
- if (v3_insert_shadow_region(vm, entry) == -1) {
+ if (v3_insert_mem_region(vm, entry) == -1) {
V3_Free(entry);
V3_Free(hook);
return -1;
int (*write)(struct guest_info * core, addr_t guest_addr, void * src, uint_t length, void * priv_data),
void * priv_data) {
- struct v3_shadow_region * entry = NULL;
+ struct v3_mem_region * entry = NULL;
struct mem_hook * hook = V3_Malloc(sizeof(struct mem_hook));
- struct v3_mem_hooks * hooks = &(vm->mem_hooks);
+ // struct v3_mem_hooks * hooks = &(vm->mem_hooks);
memset(hook, 0, sizeof(struct mem_hook));
hook->write = write;
hook->read = read;
hook->priv_data = priv_data;
- hook->hook_hva = (addr_t)hooks->hook_hvas + (PAGE_SIZE_4KB * core_id);
+ hook->hook_hva = (addr_t)0xfff;
entry = v3_create_mem_region(vm, core_id, guest_addr_start, guest_addr_end);
entry->unhandled = handle_mem_hook;
entry->priv_data = hook;
- if (v3_insert_shadow_region(vm, entry)) {
+ if (v3_insert_mem_region(vm, entry)) {
V3_Free(entry);
V3_Free(hook);
return -1;
// This will unhook the memory hook registered at start address
// We do not support unhooking subregions
int v3_unhook_mem(struct v3_vm_info * vm, uint16_t core_id, addr_t guest_addr_start) {
- struct v3_shadow_region * reg = v3_get_shadow_region(vm, core_id, guest_addr_start);
+ struct v3_mem_region * reg = v3_get_mem_region(vm, core_id, guest_addr_start);
struct mem_hook * hook = reg->priv_data;
V3_Free(hook);
- v3_delete_shadow_region(vm, reg);
+ v3_delete_mem_region(vm, reg);
return 0;
}