On Tue, May 04, 2010 at 10:08:21PM +0900, Takuya Yoshikawa wrote: > Now that dirty bitmaps are accessible from user space, we export the > addresses of these to achieve zero-copy dirty log check: > > KVM_GET_USER_DIRTY_LOG_ADDR > > We also need an API for triggering dirty bitmap switch to take the full > advantage of double buffered bitmaps. > > KVM_SWITCH_DIRTY_LOG > > See the documentation in this patch for precise explanations. > > About performance improvement: the most important feature of switch API > is the lightness. In our test, this appeared in the form of improved > responses for GUI manipulations. > > Signed-off-by: Takuya Yoshikawa <yoshikawa.takuya@xxxxxxxxxxxxx> > Signed-off-by: Fernando Luis Vazquez Cao <fernando@xxxxxxxxxxxxx> > CC: Avi Kivity <avi@xxxxxxxxxx> > CC: Alexander Graf <agraf@xxxxxxx> > --- > Documentation/kvm/api.txt | 87 +++++++++++++++++++++++++++++++++++++++++++++ > arch/ia64/kvm/kvm-ia64.c | 27 +++++++++----- > arch/powerpc/kvm/book3s.c | 18 +++++++-- > arch/x86/kvm/x86.c | 44 ++++++++++++++++------- > include/linux/kvm.h | 11 ++++++ > include/linux/kvm_host.h | 4 ++- > virt/kvm/kvm_main.c | 63 +++++++++++++++++++++++++++++---- > 7 files changed, 220 insertions(+), 34 deletions(-) > > diff --git a/Documentation/kvm/api.txt b/Documentation/kvm/api.txt > index a237518..c106c83 100644 > --- a/Documentation/kvm/api.txt > +++ b/Documentation/kvm/api.txt > @@ -892,6 +892,93 @@ arguments. > This ioctl is only useful after KVM_CREATE_IRQCHIP. Without an in-kernel > irqchip, the multiprocessing state must be maintained by userspace. > > +4.39 KVM_GET_USER_DIRTY_LOG_ADDR > + > +Capability: KVM_CAP_USER_DIRTY_LOG (>=1 see below) > +Architectures: all > +Type: vm ioctl > +Parameters: struct kvm_user_dirty_log (in/out) > +Returns: 0 on success, -1 on error > + > +This ioctl makes it possible to use KVM_SWITCH_DIRTY_LOG (see 4.40) instead > +of the old dirty log manipulation by KVM_GET_DIRTY_LOG. > + > +A bit about KVM_CAP_USER_DIRTY_LOG > + > +Before this ioctl was introduced, dirty bitmaps for dirty page logging were > +allocated in the kernel's memory space. But we have now moved them to user > +space to get more flexiblity and performance. To achive this move without > +breaking the compatibility, we will split KVM_CAP_USER_DIRTY_LOG capability > +into a few generations which can be identified by its check extension > +return values. > + > +This KVM_GET_USER_DIRTY_LOG_ADDR belongs to the first generation with the > +KVM_SWITCH_DIRTY_LOG (4.40) and must be supported by all generations. > + > +What you get > + > +By using this, you can get paired bitmap addresses which are accessible from > +user space. See the explanation in 4.40 for the roles of these two bitmaps. > + > +How to Get > + > +Before calling this, you have to set the slot member of kvm_user_dirty_log > +to indicate the target memory slot. > + > +struct kvm_user_dirty_log { > + __u32 slot; > + __u32 flags; > + __u64 dirty_bitmap; > + __u64 dirty_bitmap_old; > +}; > + > +The addresses will be set in the paired members: dirty_bitmap and _old. Why not pass the bitmap address to the kernel, instead of having the kernel allocate it. Because apparently you plan to do that in a new generation anyway? Also, why does the kernel need to know about different bitmaps? One alternative would be: KVM_SWITCH_DIRTY_LOG passing the address of a bitmap. If the active bitmap was clean, it returns 0, no switch performed. If the active bitmap was dirty, the kernel switches to the new bitmap and returns 1. And the responsability of cleaning the new bitmap could also be left for userspace. -- To unsubscribe from this list: send the line "unsubscribe kvm-ia64" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html