提交 9e8f0fbf 编写于 作者: P Paolo Bonzini

KVM: nSVM: rename functions and variables according to vmcbXY nomenclature

Now that SVM is using a separate vmcb01 and vmcb02 (and also uses the vmcb12
naming) we can give clearer names to functions that write to and read
from those VMCBs.  Likewise, variables and parameters can be renamed
from nested_vmcb to vmcb12.
Signed-off-by: NPaolo Bonzini <pbonzini@redhat.com>
上级 193015ad
...@@ -274,8 +274,8 @@ static bool nested_vmcb_checks(struct vcpu_svm *svm, struct vmcb *vmcb12) ...@@ -274,8 +274,8 @@ static bool nested_vmcb_checks(struct vcpu_svm *svm, struct vmcb *vmcb12)
return nested_vmcb_check_controls(&vmcb12->control); return nested_vmcb_check_controls(&vmcb12->control);
} }
static void load_nested_vmcb_control(struct vcpu_svm *svm, static void nested_load_control_from_vmcb12(struct vcpu_svm *svm,
struct vmcb_control_area *control) struct vmcb_control_area *control)
{ {
copy_vmcb_control_area(&svm->nested.ctl, control); copy_vmcb_control_area(&svm->nested.ctl, control);
...@@ -287,9 +287,9 @@ static void load_nested_vmcb_control(struct vcpu_svm *svm, ...@@ -287,9 +287,9 @@ static void load_nested_vmcb_control(struct vcpu_svm *svm,
/* /*
* Synchronize fields that are written by the processor, so that * Synchronize fields that are written by the processor, so that
* they can be copied back into the nested_vmcb. * they can be copied back into the vmcb12.
*/ */
void sync_nested_vmcb_control(struct vcpu_svm *svm) void nested_sync_control_from_vmcb02(struct vcpu_svm *svm)
{ {
u32 mask; u32 mask;
svm->nested.ctl.event_inj = svm->vmcb->control.event_inj; svm->nested.ctl.event_inj = svm->vmcb->control.event_inj;
...@@ -317,8 +317,8 @@ void sync_nested_vmcb_control(struct vcpu_svm *svm) ...@@ -317,8 +317,8 @@ void sync_nested_vmcb_control(struct vcpu_svm *svm)
* Transfer any event that L0 or L1 wanted to inject into L2 to * Transfer any event that L0 or L1 wanted to inject into L2 to
* EXIT_INT_INFO. * EXIT_INT_INFO.
*/ */
static void nested_vmcb_save_pending_event(struct vcpu_svm *svm, static void nested_save_pending_event_to_vmcb12(struct vcpu_svm *svm,
struct vmcb *vmcb12) struct vmcb *vmcb12)
{ {
struct kvm_vcpu *vcpu = &svm->vcpu; struct kvm_vcpu *vcpu = &svm->vcpu;
u32 exit_int_info = 0; u32 exit_int_info = 0;
...@@ -395,7 +395,7 @@ void nested_vmcb02_compute_g_pat(struct vcpu_svm *svm) ...@@ -395,7 +395,7 @@ void nested_vmcb02_compute_g_pat(struct vcpu_svm *svm)
svm->nested.vmcb02.ptr->save.g_pat = svm->vmcb01.ptr->save.g_pat; svm->nested.vmcb02.ptr->save.g_pat = svm->vmcb01.ptr->save.g_pat;
} }
static void nested_prepare_vmcb_save(struct vcpu_svm *svm, struct vmcb *vmcb12) static void nested_vmcb02_prepare_save(struct vcpu_svm *svm, struct vmcb *vmcb12)
{ {
nested_vmcb02_compute_g_pat(svm); nested_vmcb02_compute_g_pat(svm);
...@@ -424,7 +424,7 @@ static void nested_prepare_vmcb_save(struct vcpu_svm *svm, struct vmcb *vmcb12) ...@@ -424,7 +424,7 @@ static void nested_prepare_vmcb_save(struct vcpu_svm *svm, struct vmcb *vmcb12)
svm->vmcb->save.cpl = vmcb12->save.cpl; svm->vmcb->save.cpl = vmcb12->save.cpl;
} }
static void nested_prepare_vmcb_control(struct vcpu_svm *svm) static void nested_vmcb02_prepare_control(struct vcpu_svm *svm)
{ {
const u32 mask = V_INTR_MASKING_MASK | V_GIF_ENABLE_MASK | V_GIF_MASK; const u32 mask = V_INTR_MASKING_MASK | V_GIF_ENABLE_MASK | V_GIF_MASK;
...@@ -486,11 +486,11 @@ int enter_svm_guest_mode(struct vcpu_svm *svm, u64 vmcb12_gpa, ...@@ -486,11 +486,11 @@ int enter_svm_guest_mode(struct vcpu_svm *svm, u64 vmcb12_gpa,
WARN_ON(svm->vmcb == svm->nested.vmcb02.ptr); WARN_ON(svm->vmcb == svm->nested.vmcb02.ptr);
nested_svm_vmloadsave(svm->vmcb01.ptr, svm->nested.vmcb02.ptr); nested_svm_vmloadsave(svm->vmcb01.ptr, svm->nested.vmcb02.ptr);
load_nested_vmcb_control(svm, &vmcb12->control); nested_load_control_from_vmcb12(svm, &vmcb12->control);
svm_switch_vmcb(svm, &svm->nested.vmcb02); svm_switch_vmcb(svm, &svm->nested.vmcb02);
nested_prepare_vmcb_control(svm); nested_vmcb02_prepare_control(svm);
nested_prepare_vmcb_save(svm, vmcb12); nested_vmcb02_prepare_save(svm, vmcb12);
ret = nested_svm_load_cr3(&svm->vcpu, vmcb12->save.cr3, ret = nested_svm_load_cr3(&svm->vcpu, vmcb12->save.cr3,
nested_npt_enabled(svm)); nested_npt_enabled(svm));
...@@ -655,7 +655,7 @@ int nested_svm_vmexit(struct vcpu_svm *svm) ...@@ -655,7 +655,7 @@ int nested_svm_vmexit(struct vcpu_svm *svm)
vmcb12->control.exit_info_2 = vmcb->control.exit_info_2; vmcb12->control.exit_info_2 = vmcb->control.exit_info_2;
if (vmcb12->control.exit_code != SVM_EXIT_ERR) if (vmcb12->control.exit_code != SVM_EXIT_ERR)
nested_vmcb_save_pending_event(svm, vmcb12); nested_save_pending_event_to_vmcb12(svm, vmcb12);
if (svm->nrips_enabled) if (svm->nrips_enabled)
vmcb12->control.next_rip = vmcb->control.next_rip; vmcb12->control.next_rip = vmcb->control.next_rip;
...@@ -1227,11 +1227,11 @@ static int svm_set_nested_state(struct kvm_vcpu *vcpu, ...@@ -1227,11 +1227,11 @@ static int svm_set_nested_state(struct kvm_vcpu *vcpu,
if (svm->current_vmcb == &svm->vmcb01) if (svm->current_vmcb == &svm->vmcb01)
svm->nested.vmcb02.ptr->save = svm->vmcb01.ptr->save; svm->nested.vmcb02.ptr->save = svm->vmcb01.ptr->save;
svm->vmcb01.ptr->save = *save; svm->vmcb01.ptr->save = *save;
load_nested_vmcb_control(svm, ctl); nested_load_control_from_vmcb12(svm, ctl);
svm_switch_vmcb(svm, &svm->nested.vmcb02); svm_switch_vmcb(svm, &svm->nested.vmcb02);
nested_prepare_vmcb_control(svm); nested_vmcb02_prepare_control(svm);
kvm_make_request(KVM_REQ_GET_NESTED_STATE_PAGES, vcpu); kvm_make_request(KVM_REQ_GET_NESTED_STATE_PAGES, vcpu);
ret = 0; ret = 0;
......
...@@ -2124,7 +2124,7 @@ static int vmmcall_interception(struct vcpu_svm *svm) ...@@ -2124,7 +2124,7 @@ static int vmmcall_interception(struct vcpu_svm *svm)
static int vmload_interception(struct vcpu_svm *svm) static int vmload_interception(struct vcpu_svm *svm)
{ {
struct vmcb *nested_vmcb; struct vmcb *vmcb12;
struct kvm_host_map map; struct kvm_host_map map;
int ret; int ret;
...@@ -2138,11 +2138,11 @@ static int vmload_interception(struct vcpu_svm *svm) ...@@ -2138,11 +2138,11 @@ static int vmload_interception(struct vcpu_svm *svm)
return 1; return 1;
} }
nested_vmcb = map.hva; vmcb12 = map.hva;
ret = kvm_skip_emulated_instruction(&svm->vcpu); ret = kvm_skip_emulated_instruction(&svm->vcpu);
nested_svm_vmloadsave(nested_vmcb, svm->vmcb); nested_svm_vmloadsave(vmcb12, svm->vmcb);
kvm_vcpu_unmap(&svm->vcpu, &map, true); kvm_vcpu_unmap(&svm->vcpu, &map, true);
return ret; return ret;
...@@ -2150,7 +2150,7 @@ static int vmload_interception(struct vcpu_svm *svm) ...@@ -2150,7 +2150,7 @@ static int vmload_interception(struct vcpu_svm *svm)
static int vmsave_interception(struct vcpu_svm *svm) static int vmsave_interception(struct vcpu_svm *svm)
{ {
struct vmcb *nested_vmcb; struct vmcb *vmcb12;
struct kvm_host_map map; struct kvm_host_map map;
int ret; int ret;
...@@ -2164,11 +2164,11 @@ static int vmsave_interception(struct vcpu_svm *svm) ...@@ -2164,11 +2164,11 @@ static int vmsave_interception(struct vcpu_svm *svm)
return 1; return 1;
} }
nested_vmcb = map.hva; vmcb12 = map.hva;
ret = kvm_skip_emulated_instruction(&svm->vcpu); ret = kvm_skip_emulated_instruction(&svm->vcpu);
nested_svm_vmloadsave(svm->vmcb, nested_vmcb); nested_svm_vmloadsave(svm->vmcb, vmcb12);
kvm_vcpu_unmap(&svm->vcpu, &map, true); kvm_vcpu_unmap(&svm->vcpu, &map, true);
return ret; return ret;
...@@ -3949,7 +3949,7 @@ static __no_kcsan fastpath_t svm_vcpu_run(struct kvm_vcpu *vcpu) ...@@ -3949,7 +3949,7 @@ static __no_kcsan fastpath_t svm_vcpu_run(struct kvm_vcpu *vcpu)
svm->next_rip = 0; svm->next_rip = 0;
if (is_guest_mode(&svm->vcpu)) { if (is_guest_mode(&svm->vcpu)) {
sync_nested_vmcb_control(svm); nested_sync_control_from_vmcb02(svm);
svm->nested.nested_run_pending = 0; svm->nested.nested_run_pending = 0;
} }
......
...@@ -437,8 +437,7 @@ static inline bool nested_exit_on_nmi(struct vcpu_svm *svm) ...@@ -437,8 +437,7 @@ static inline bool nested_exit_on_nmi(struct vcpu_svm *svm)
return vmcb_is_intercept(&svm->nested.ctl, INTERCEPT_NMI); return vmcb_is_intercept(&svm->nested.ctl, INTERCEPT_NMI);
} }
int enter_svm_guest_mode(struct vcpu_svm *svm, u64 vmcb_gpa, int enter_svm_guest_mode(struct vcpu_svm *svm, u64 vmcb_gpa, struct vmcb *vmcb12);
struct vmcb *nested_vmcb);
void svm_leave_nested(struct vcpu_svm *svm); void svm_leave_nested(struct vcpu_svm *svm);
void svm_free_nested(struct vcpu_svm *svm); void svm_free_nested(struct vcpu_svm *svm);
int svm_allocate_nested(struct vcpu_svm *svm); int svm_allocate_nested(struct vcpu_svm *svm);
...@@ -450,7 +449,7 @@ int nested_svm_check_permissions(struct vcpu_svm *svm); ...@@ -450,7 +449,7 @@ int nested_svm_check_permissions(struct vcpu_svm *svm);
int nested_svm_check_exception(struct vcpu_svm *svm, unsigned nr, int nested_svm_check_exception(struct vcpu_svm *svm, unsigned nr,
bool has_error_code, u32 error_code); bool has_error_code, u32 error_code);
int nested_svm_exit_special(struct vcpu_svm *svm); int nested_svm_exit_special(struct vcpu_svm *svm);
void sync_nested_vmcb_control(struct vcpu_svm *svm); void nested_sync_control_from_vmcb02(struct vcpu_svm *svm);
void nested_vmcb02_compute_g_pat(struct vcpu_svm *svm); void nested_vmcb02_compute_g_pat(struct vcpu_svm *svm);
void svm_switch_vmcb(struct vcpu_svm *svm, struct kvm_vmcb_info *target_vmcb); void svm_switch_vmcb(struct vcpu_svm *svm, struct kvm_vmcb_info *target_vmcb);
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册