From: Jan Kiszka <jan.kiszka@web.de>
To: Arthur Chunqi Li <yzt356@gmail.com>
Cc: kvm@vger.kernel.org, gleb@redhat.com, pbonzini@redhat.com
Subject: Re: [PATCH] KVM : Set success rflags when emulate VMXON/VMXOFF in nested virt
Date: Thu, 04 Jul 2013 07:22:07 +0200 [thread overview]
Message-ID: <51D5067F.80405@web.de> (raw)
In-Reply-To: <1372867517-32111-1-git-send-email-yzt356@gmail.com>
[-- Attachment #1: Type: text/plain, Size: 4595 bytes --]
On 2013-07-03 18:05, Arthur Chunqi Li wrote:
> Set success rflags after emulating VMXON/VMXOFF in nested environment.
>
> Re-arrange the code sequence of 3 functions,
> nested_vmx_succeed()/failValid()/failInvalid(), to avoid double
> declaration in the same file.
Just don't forget to provide corresponding test cases. But you can
collect trivial checks like these and do a single VMX startup/shutdown
test case that consists of several smaller test steps.
Jan
>
> Signed-off-by: Arthur Chunqi Li <yzt356@gmail.com>
> ---
> arch/x86/kvm/vmx.c | 85 ++++++++++++++++++++++++++--------------------------
> 1 file changed, 42 insertions(+), 43 deletions(-)
>
> diff --git a/arch/x86/kvm/vmx.c b/arch/x86/kvm/vmx.c
> index 260a919..423bc411 100644
> --- a/arch/x86/kvm/vmx.c
> +++ b/arch/x86/kvm/vmx.c
> @@ -5551,8 +5551,47 @@ static void nested_free_all_saved_vmcss(struct vcpu_vmx *vmx)
> free_loaded_vmcs(&vmx->vmcs01);
> }
>
> +/*
> + * The following 3 functions, nested_vmx_succeed()/failValid()/failInvalid(),
> + * set the success or error code of an emulated VMX instruction, as specified
> + * by Vol 2B, VMX Instruction Reference, "Conventions".
> + */
> +static void nested_vmx_succeed(struct kvm_vcpu *vcpu)
> +{
> + vmx_set_rflags(vcpu, vmx_get_rflags(vcpu)
> + & ~(X86_EFLAGS_CF | X86_EFLAGS_PF | X86_EFLAGS_AF |
> + X86_EFLAGS_ZF | X86_EFLAGS_SF | X86_EFLAGS_OF));
> +}
> +
> +static void nested_vmx_failInvalid(struct kvm_vcpu *vcpu)
> +{
> + vmx_set_rflags(vcpu, (vmx_get_rflags(vcpu)
> + & ~(X86_EFLAGS_PF | X86_EFLAGS_AF | X86_EFLAGS_ZF |
> + X86_EFLAGS_SF | X86_EFLAGS_OF))
> + | X86_EFLAGS_CF);
> +}
> +
> static void nested_vmx_failValid(struct kvm_vcpu *vcpu,
> - u32 vm_instruction_error);
> + u32 vm_instruction_error)
> +{
> + if (to_vmx(vcpu)->nested.current_vmptr == -1ull) {
> + /*
> + * failValid writes the error number to the current VMCS, which
> + * can't be done there isn't a current VMCS.
> + */
> + nested_vmx_failInvalid(vcpu);
> + return;
> + }
> + vmx_set_rflags(vcpu, (vmx_get_rflags(vcpu)
> + & ~(X86_EFLAGS_CF | X86_EFLAGS_PF | X86_EFLAGS_AF |
> + X86_EFLAGS_SF | X86_EFLAGS_OF))
> + | X86_EFLAGS_ZF);
> + get_vmcs12(vcpu)->vm_instruction_error = vm_instruction_error;
> + /*
> + * We don't need to force a shadow sync because
> + * VM_INSTRUCTION_ERROR is not shadowed
> + */
> +}
>
> /*
> * Emulate the VMXON instruction.
> @@ -5612,6 +5651,7 @@ static int handle_vmon(struct kvm_vcpu *vcpu)
> vmx->nested.vmxon = true;
>
> skip_emulated_instruction(vcpu);
> + nested_vmx_succeed(vcpu);
> return 1;
> }
>
> @@ -5696,6 +5736,7 @@ static int handle_vmoff(struct kvm_vcpu *vcpu)
> return 1;
> free_nested(to_vmx(vcpu));
> skip_emulated_instruction(vcpu);
> + nested_vmx_succeed(vcpu);
> return 1;
> }
>
> @@ -5752,48 +5793,6 @@ static int get_vmx_mem_address(struct kvm_vcpu *vcpu,
> return 0;
> }
>
> -/*
> - * The following 3 functions, nested_vmx_succeed()/failValid()/failInvalid(),
> - * set the success or error code of an emulated VMX instruction, as specified
> - * by Vol 2B, VMX Instruction Reference, "Conventions".
> - */
> -static void nested_vmx_succeed(struct kvm_vcpu *vcpu)
> -{
> - vmx_set_rflags(vcpu, vmx_get_rflags(vcpu)
> - & ~(X86_EFLAGS_CF | X86_EFLAGS_PF | X86_EFLAGS_AF |
> - X86_EFLAGS_ZF | X86_EFLAGS_SF | X86_EFLAGS_OF));
> -}
> -
> -static void nested_vmx_failInvalid(struct kvm_vcpu *vcpu)
> -{
> - vmx_set_rflags(vcpu, (vmx_get_rflags(vcpu)
> - & ~(X86_EFLAGS_PF | X86_EFLAGS_AF | X86_EFLAGS_ZF |
> - X86_EFLAGS_SF | X86_EFLAGS_OF))
> - | X86_EFLAGS_CF);
> -}
> -
> -static void nested_vmx_failValid(struct kvm_vcpu *vcpu,
> - u32 vm_instruction_error)
> -{
> - if (to_vmx(vcpu)->nested.current_vmptr == -1ull) {
> - /*
> - * failValid writes the error number to the current VMCS, which
> - * can't be done there isn't a current VMCS.
> - */
> - nested_vmx_failInvalid(vcpu);
> - return;
> - }
> - vmx_set_rflags(vcpu, (vmx_get_rflags(vcpu)
> - & ~(X86_EFLAGS_CF | X86_EFLAGS_PF | X86_EFLAGS_AF |
> - X86_EFLAGS_SF | X86_EFLAGS_OF))
> - | X86_EFLAGS_ZF);
> - get_vmcs12(vcpu)->vm_instruction_error = vm_instruction_error;
> - /*
> - * We don't need to force a shadow sync because
> - * VM_INSTRUCTION_ERROR is not shadowed
> - */
> -}
> -
> /* Emulate the VMCLEAR instruction */
> static int handle_vmclear(struct kvm_vcpu *vcpu)
> {
>
[-- Attachment #2: OpenPGP digital signature --]
[-- Type: application/pgp-signature, Size: 263 bytes --]
prev parent reply other threads:[~2013-07-04 5:22 UTC|newest]
Thread overview: 4+ messages / expand[flat|nested] mbox.gz Atom feed top
2013-07-03 16:05 [PATCH] KVM : Set success rflags when emulate VMXON/VMXOFF in nested virt Arthur Chunqi Li
2013-07-03 16:09 ` Arthur Chunqi Li
2013-07-04 6:06 ` Gleb Natapov
2013-07-04 5:22 ` Jan Kiszka [this message]
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=51D5067F.80405@web.de \
--to=jan.kiszka@web.de \
--cc=gleb@redhat.com \
--cc=kvm@vger.kernel.org \
--cc=pbonzini@redhat.com \
--cc=yzt356@gmail.com \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.