From: Anthony Liguori <aliguori@us.ibm.com>
To: Eric B Munson <emunson@mgebm.net>
Cc: avi@redhat.com, mingo@redhat.com, x86@kernel.org, hpa@zytor.com,
arnd@arndb.de, linux-kernel@vger.kernel.org, kvm@vger.kernel.org,
linux-arch@vger.kernel.org, ryanh@linux.vnet.ibm.com
Subject: Re: [PATCH 3/6 V2] Add ioctl for KVM_GUEST_STOPPED
Date: Tue, 01 Nov 2011 14:32:16 -0500 [thread overview]
Message-ID: <4EB04940.2030506@us.ibm.com> (raw)
In-Reply-To: <1320091650-24682-4-git-send-email-emunson@mgebm.net>
On 10/31/2011 03:07 PM, Eric B Munson wrote:
> Now that we have a flag that will tell the guest it was suspended, create an
> interface for that communication using a KVM ioctl.
>
> Signed-off-by: Eric B Munson<emunson@mgebm.net>
> ---
> Changes from V1:
> Add kvm_set_host_stopped to arch/x86/jvm/x86.c instead of kvmclock.c
> Rename KVM_PAUSE_GUEST to KVM_GUEST_PAUSED
>
> arch/x86/include/asm/pvclock.h | 3 +++
> arch/x86/kvm/x86.c | 16 ++++++++++++++++
> include/linux/kvm.h | 2 ++
> 3 files changed, 21 insertions(+), 0 deletions(-)
>
> diff --git a/arch/x86/include/asm/pvclock.h b/arch/x86/include/asm/pvclock.h
> index 7d3ba41..9312814 100644
> --- a/arch/x86/include/asm/pvclock.h
> +++ b/arch/x86/include/asm/pvclock.h
> @@ -3,6 +3,7 @@
>
> #include<linux/clocksource.h>
> #include<asm/pvclock-abi.h>
> +#include<linux/kvm_host.h>
>
> /* some helper functions for xen and kvm pv clock sources */
> cycle_t pvclock_clocksource_read(struct pvclock_vcpu_time_info *src);
> @@ -13,6 +14,8 @@ void pvclock_read_wallclock(struct pvclock_wall_clock *wall,
> struct timespec *ts);
> void pvclock_resume(void);
>
> +void kvm_set_host_stopped(struct kvm_vcpu *vcpu);
This can't go in pvclock.h.
> +
> bool kvm_check_and_clear_host_stopped(int cpu);
>
> /*
> diff --git a/arch/x86/kvm/x86.c b/arch/x86/kvm/x86.c
> index c38efd7..592ac3b 100644
> --- a/arch/x86/kvm/x86.c
> +++ b/arch/x86/kvm/x86.c
> @@ -3295,6 +3295,11 @@ long kvm_arch_vcpu_ioctl(struct file *filp,
>
> goto out;
> }
> + case KVM_GUEST_PAUSED: {
> + r = 0;
> + kvm_set_host_stopped(vcpu);
> + break;
> + }
> default:
> r = -EINVAL;
> }
> @@ -6117,6 +6122,17 @@ int kvm_task_switch(struct kvm_vcpu *vcpu, u16 tss_selector, int reason,
> }
> EXPORT_SYMBOL_GPL(kvm_task_switch);
>
> +/*
> + * kvm_set_host_stopped() indicates to the guest kernel that it has been
> + * stopped by the hypervisor. This function will be called from the host only.
> + */
> +void kvm_set_host_stopped(struct kvm_vcpu *vcpu)
> +{
> + struct pvclock_vcpu_time_info *src =&vcpu->arch.hv_clock;
> + src->flags |= PVCLOCK_GUEST_STOPPED;
Shouldn't we throw some sort of error if you're trying to set a flag and
kvmclock isn't enabled?
Regards,
Anthony Liguori
> +}
> +EXPORT_SYMBOL_GPL(kvm_set_host_stopped);
> +
> int kvm_arch_vcpu_ioctl_set_sregs(struct kvm_vcpu *vcpu,
> struct kvm_sregs *sregs)
> {
> diff --git a/include/linux/kvm.h b/include/linux/kvm.h
> index f47fcd3..87cab0d 100644
> --- a/include/linux/kvm.h
> +++ b/include/linux/kvm.h
> @@ -763,6 +763,8 @@ struct kvm_clock_data {
> #define KVM_CREATE_SPAPR_TCE _IOW(KVMIO, 0xa8, struct kvm_create_spapr_tce)
> /* Available with KVM_CAP_RMA */
> #define KVM_ALLOCATE_RMA _IOR(KVMIO, 0xa9, struct kvm_allocate_rma)
> +/* VM is being stopped by host */
> +#define KVM_GUEST_PAUSED _IO(KVMIO, 0xaa)
>
> #define KVM_DEV_ASSIGN_ENABLE_IOMMU (1<< 0)
>
next prev parent reply other threads:[~2011-11-01 19:33 UTC|newest]
Thread overview: 16+ messages / expand[flat|nested] mbox.gz Atom feed top
2011-10-31 20:07 [PATCH 0/6 V2] Avoid soft lockup message when KVM is stopped by host Eric B Munson
2011-10-31 20:07 ` [PATCH 1/6 V2] Add flag to indicate that a vm was stopped by the host Eric B Munson
2011-11-01 19:22 ` Anthony Liguori
2011-10-31 20:07 ` [PATCH 2/6 V2] Add functions to check if the host has stopped the vm Eric B Munson
2011-11-01 19:28 ` Anthony Liguori
2011-11-01 20:07 ` Eric B Munson
2011-10-31 20:07 ` [PATCH 3/6 V2] Add ioctl for KVM_GUEST_STOPPED Eric B Munson
2011-11-01 19:32 ` Anthony Liguori [this message]
2011-11-01 20:11 ` Eric B Munson
2011-10-31 20:07 ` [PATCH 4/6 V2] Add generic stubs for kvm stop check functions Eric B Munson
2011-10-31 20:07 ` [PATCH 5/6 V2] Add check for suspended vm in softlockup detector Eric B Munson
2011-10-31 20:07 ` [PATCH 6/6 V2] Add age out of guest paused flag Eric B Munson
2011-11-01 19:34 ` Anthony Liguori
2011-11-01 19:51 ` Eric B Munson
2011-11-01 19:58 ` Anthony Liguori
2011-11-01 20:10 ` Eric B Munson
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=4EB04940.2030506@us.ibm.com \
--to=aliguori@us.ibm.com \
--cc=arnd@arndb.de \
--cc=avi@redhat.com \
--cc=emunson@mgebm.net \
--cc=hpa@zytor.com \
--cc=kvm@vger.kernel.org \
--cc=linux-arch@vger.kernel.org \
--cc=linux-kernel@vger.kernel.org \
--cc=mingo@redhat.com \
--cc=ryanh@linux.vnet.ibm.com \
--cc=x86@kernel.org \
/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.