switch ( rc )
{
+ case HVMCOPY_okay:
+ break;
case HVMCOPY_bad_gva_to_gfn:
return X86EMUL_EXCEPTION;
- case HVMCOPY_unhandleable:
- return X86EMUL_UNHANDLEABLE;
case HVMCOPY_bad_gfn_to_mfn:
if ( access_type == hvm_access_insn_fetch )
return X86EMUL_UNHANDLEABLE;
}
return rc;
case HVMCOPY_gfn_paged_out:
- return X86EMUL_RETRY;
case HVMCOPY_gfn_shared:
return X86EMUL_RETRY;
default:
- break;
+ return X86EMUL_UNHANDLEABLE;
}
return X86EMUL_OKAY;
switch ( rc )
{
+ case HVMCOPY_okay:
+ break;
case HVMCOPY_bad_gva_to_gfn:
return X86EMUL_EXCEPTION;
- case HVMCOPY_unhandleable:
- return X86EMUL_UNHANDLEABLE;
case HVMCOPY_bad_gfn_to_mfn:
rc = hvmemul_linear_to_phys(addr, &gpa, chunk, &reps, pfec,
hvmemul_ctxt);
}
return rc;
case HVMCOPY_gfn_paged_out:
- return X86EMUL_RETRY;
case HVMCOPY_gfn_shared:
return X86EMUL_RETRY;
default:
- break;
+ return X86EMUL_UNHANDLEABLE;
}
return X86EMUL_OKAY;
rc = hvm_copy_to_guest_virt(
prev_tr.base, &tss, sizeof(tss), PFEC_page_present);
- if ( rc == HVMCOPY_bad_gva_to_gfn )
- goto out;
- if ( rc == HVMCOPY_gfn_paged_out )
- goto out;
- if ( rc == HVMCOPY_gfn_shared )
+ if ( rc != HVMCOPY_okay )
goto out;
rc = hvm_copy_from_guest_virt(
tr.base, &tss, sizeof(tss), PFEC_page_present);
if ( rc == HVMCOPY_bad_gva_to_gfn )
exn_raised = 1;
- if ( rc == HVMCOPY_gfn_paged_out )
- goto out;
- if ( rc == HVMCOPY_gfn_shared )
+ else if ( rc != HVMCOPY_okay )
goto out;
if ( (tss.trace & 1) && !exn_raised )