* [PATCH] KVM: add KVM_SYNC_SHADOW_WITH_USER ioctl (v2)
@ 2008-01-09 18:17 Marcelo Tosatti
2008-01-12 19:59 ` Avi Kivity
0 siblings, 1 reply; 4+ messages in thread
From: Marcelo Tosatti @ 2008-01-09 18:17 UTC (permalink / raw)
To: Anthony Liguori; +Cc: kvm-devel
Export nukeing of shadow MMU pages through an ioctl, required for
consistency on balloon inflate.
Changes:
- Move to x86-specific kvm_arch_vm_ioctl()
- Grab mmap_sem
Index: kvm.quilt/arch/x86/kvm/x86.c
===================================================================
--- kvm.quilt.orig/arch/x86/kvm/x86.c
+++ kvm.quilt/arch/x86/kvm/x86.c
@@ -680,6 +680,7 @@ int kvm_dev_ioctl_check_extension(long e
case KVM_CAP_USER_MEMORY:
case KVM_CAP_SET_TSS_ADDR:
case KVM_CAP_EXT_CPUID:
+ case KVM_CAP_SYNC_SHADOW_WITH_USER:
r = 1;
break;
case KVM_CAP_VAPIC:
@@ -1505,6 +1506,13 @@ long kvm_arch_vm_ioctl(struct file *filp
r = 0;
break;
}
+ case KVM_SYNC_SHADOW_WITH_USER: {
+ r = 0;
+ down_read(¤t->mm->mmap_sem);
+ kvm_mmu_zap_all(kvm);
+ up_read(¤t->mm->mmap_sem);
+ break;
+ }
default:
;
}
Index: kvm.quilt/include/linux/kvm.h
===================================================================
--- kvm.quilt.orig/include/linux/kvm.h
+++ kvm.quilt/include/linux/kvm.h
@@ -249,6 +249,7 @@ struct kvm_vapic_addr {
#define KVM_CAP_SET_TSS_ADDR 4
#define KVM_CAP_EXT_CPUID 5
#define KVM_CAP_VAPIC 6
+#define KVM_CAP_SYNC_SHADOW_WITH_USER 7
/*
* ioctls for VM fds
@@ -267,6 +268,7 @@ struct kvm_vapic_addr {
#define KVM_GET_DIRTY_LOG _IOW(KVMIO, 0x42, struct kvm_dirty_log)
#define KVM_SET_MEMORY_ALIAS _IOW(KVMIO, 0x43, struct kvm_memory_alias)
#define KVM_GET_SUPPORTED_CPUID _IOWR(KVMIO, 0x48, struct kvm_cpuid2)
+#define KVM_SYNC_SHADOW_WITH_USER _IO(KVMIO, 0x49)
/* Device model IOC */
#define KVM_CREATE_IRQCHIP _IO(KVMIO, 0x60)
#define KVM_IRQ_LINE _IOW(KVMIO, 0x61, struct kvm_irq_level)
-------------------------------------------------------------------------
Check out the new SourceForge.net Marketplace.
It's the best place to buy or sell services for
just about anything Open Source.
http://ad.doubleclick.net/clk;164216239;13503038;w?http://sf.net/marketplace
^ permalink raw reply [flat|nested] 4+ messages in thread* Re: [PATCH] KVM: add KVM_SYNC_SHADOW_WITH_USER ioctl (v2) 2008-01-09 18:17 [PATCH] KVM: add KVM_SYNC_SHADOW_WITH_USER ioctl (v2) Marcelo Tosatti @ 2008-01-12 19:59 ` Avi Kivity [not found] ` <47891C10.8060803-atKUWr5tajBWk0Htik3J/w@public.gmane.org> 0 siblings, 1 reply; 4+ messages in thread From: Avi Kivity @ 2008-01-12 19:59 UTC (permalink / raw) To: Marcelo Tosatti; +Cc: kvm-devel Marcelo Tosatti wrote: > Export nukeing of shadow MMU pages through an ioctl, required for > consistency on balloon inflate. > > With mmu notifiers (posted two minutes after this) shadow is implicitly synced with userspace. Since it seems to be progressing rapidly, I won't apply this patch in the hope that mmu notifiers can be ready for 2.6.25. -- Any sufficiently difficult bug is indistinguishable from a feature. ------------------------------------------------------------------------- Check out the new SourceForge.net Marketplace. It's the best place to buy or sell services for just about anything Open Source. http://ad.doubleclick.net/clk;164216239;13503038;w?http://sf.net/marketplace ^ permalink raw reply [flat|nested] 4+ messages in thread
[parent not found: <47891C10.8060803-atKUWr5tajBWk0Htik3J/w@public.gmane.org>]
* Re: [PATCH] KVM: add KVM_SYNC_SHADOW_WITH_USER ioctl (v2) [not found] ` <47891C10.8060803-atKUWr5tajBWk0Htik3J/w@public.gmane.org> @ 2008-01-12 20:28 ` Anthony Liguori [not found] ` <47892303.6030602-r/Jw6+rmf7HQT0dZR+AlfA@public.gmane.org> 0 siblings, 1 reply; 4+ messages in thread From: Anthony Liguori @ 2008-01-12 20:28 UTC (permalink / raw) To: Avi Kivity; +Cc: Marcelo Tosatti, kvm-devel Avi Kivity wrote: > Marcelo Tosatti wrote: >> Export nukeing of shadow MMU pages through an ioctl, required for >> consistency on balloon inflate. >> >> > > With mmu notifiers (posted two minutes after this) shadow is > implicitly synced with userspace. Since it seems to be progressing > rapidly, I won't apply this patch in the hope that mmu notifiers can > be ready for 2.6.25. Does that mean that we'll only support ballooning on host kernels > 2.6.25 are you going to do judo with debug registers to implement it for older kernels? Regards, Anthony Liguori ------------------------------------------------------------------------- Check out the new SourceForge.net Marketplace. It's the best place to buy or sell services for just about anything Open Source. http://ad.doubleclick.net/clk;164216239;13503038;w?http://sf.net/marketplace ^ permalink raw reply [flat|nested] 4+ messages in thread
[parent not found: <47892303.6030602-r/Jw6+rmf7HQT0dZR+AlfA@public.gmane.org>]
* Re: [PATCH] KVM: add KVM_SYNC_SHADOW_WITH_USER ioctl (v2) [not found] ` <47892303.6030602-r/Jw6+rmf7HQT0dZR+AlfA@public.gmane.org> @ 2008-01-12 20:57 ` Avi Kivity 0 siblings, 0 replies; 4+ messages in thread From: Avi Kivity @ 2008-01-12 20:57 UTC (permalink / raw) To: Anthony Liguori; +Cc: Marcelo Tosatti, kvm-devel Anthony Liguori wrote: >>> >> >> With mmu notifiers (posted two minutes after this) shadow is >> implicitly synced with userspace. Since it seems to be progressing >> rapidly, I won't apply this patch in the hope that mmu notifiers can >> be ready for 2.6.25. > > Does that mean that we'll only support ballooning on host kernels > > 2.6.25 are you going to do judo with debug registers to implement it > for older kernels? Good question. We may choose not to support it (distros may backport it if they wish), or do some evil hackery, or apply KVM_SYNC_SHADOW_WITH_USER _only_ to the external module. -- Any sufficiently difficult bug is indistinguishable from a feature. ------------------------------------------------------------------------- Check out the new SourceForge.net Marketplace. It's the best place to buy or sell services for just about anything Open Source. http://ad.doubleclick.net/clk;164216239;13503038;w?http://sf.net/marketplace ^ permalink raw reply [flat|nested] 4+ messages in thread
end of thread, other threads:[~2008-01-12 20:57 UTC | newest]
Thread overview: 4+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2008-01-09 18:17 [PATCH] KVM: add KVM_SYNC_SHADOW_WITH_USER ioctl (v2) Marcelo Tosatti
2008-01-12 19:59 ` Avi Kivity
[not found] ` <47891C10.8060803-atKUWr5tajBWk0Htik3J/w@public.gmane.org>
2008-01-12 20:28 ` Anthony Liguori
[not found] ` <47892303.6030602-r/Jw6+rmf7HQT0dZR+AlfA@public.gmane.org>
2008-01-12 20:57 ` Avi Kivity
This is a public inbox, see mirroring instructions for how to clone and mirror all data and code used for this inbox