X-Git-Url: http://v3vee.org/palacios/gitweb/gitweb.cgi?a=blobdiff_plain;f=palacios%2Fsrc%2Fpalacios%2Fvm_guest_mem.c;h=3f6be1e12563527510f96f33bedc0a9f78522960;hb=89e97330b5358593b7e7d823ca017ef17a59d44d;hp=c88ecd2ab912026f837a5ded0813fced0cccecd3;hpb=52bcd30a848d41e4ad84b237f3f6bec2600da3a9;p=palacios.releases.git diff --git a/palacios/src/palacios/vm_guest_mem.c b/palacios/src/palacios/vm_guest_mem.c index c88ecd2..3f6be1e 100644 --- a/palacios/src/palacios/vm_guest_mem.c +++ b/palacios/src/palacios/vm_guest_mem.c @@ -65,8 +65,8 @@ int host_pa_to_host_va(addr_t host_pa, addr_t * host_va) { -int guest_pa_to_host_pa(struct guest_info * guest_info, addr_t guest_pa, addr_t * host_pa) { - struct v3_shadow_region * shdw_reg = v3_get_shadow_region(guest_info, guest_pa); +int guest_pa_to_host_pa(struct guest_info * info, addr_t guest_pa, addr_t * host_pa) { + struct v3_shadow_region * shdw_reg = v3_get_shadow_region(info->vm_info, info->cpu_id, guest_pa); if (shdw_reg == NULL) { PrintError("In GPA->HPA: Could not find address in shadow map (addr=%p) (NULL REGION)\n", @@ -74,14 +74,13 @@ int guest_pa_to_host_pa(struct guest_info * guest_info, addr_t guest_pa, addr_t return -1; } - if ((shdw_reg->host_type == SHDW_REGION_INVALID) || - (shdw_reg->host_type == SHDW_REGION_FULL_HOOK)) { + if (shdw_reg->host_type == SHDW_REGION_FULL_HOOK) { PrintError("In GPA->HPA: Could not find address in shadow map (addr=%p) (reg_type=%s)\n", (void *)guest_pa, v3_shdw_region_type_to_str(shdw_reg->host_type)); return -1; } - *host_pa = v3_get_shadow_addr(shdw_reg, guest_pa); + *host_pa = v3_get_shadow_addr(shdw_reg, info->cpu_id, guest_pa); return 0; }