diff options
author | Izik Eidus <izike@qumranet.com> | 2007-11-19 11:16:57 +0200 |
---|---|---|
committer | Avi Kivity <avi@qumranet.com> | 2007-11-19 16:05:19 +0200 |
commit | aa79833baa1491d6f8ed0158045eb92736194672 (patch) | |
tree | 750353aeea6159814e7ebf2ba780e3c1595ca3db | |
parent | 6589612b279ac8fc98dc32c2beaccaf73a123db3 (diff) |
kvm: simplify kvm_clear_guest_page()kvm-53rc2
Use kvm_write_guest_page() with empty_zero_page, instead of doing
kmap and memset.
Signed-off-by: Izik Eidus <izike@qumranet.com>
Signed-off-by: Avi Kivity <avi@qumranet.com>
-rw-r--r-- | drivers/kvm/kvm_main.c | 17 |
1 files changed, 1 insertions, 16 deletions
diff --git a/drivers/kvm/kvm_main.c b/drivers/kvm/kvm_main.c index bda733a44059..6c2c8e3e273a 100644 --- a/drivers/kvm/kvm_main.c +++ b/drivers/kvm/kvm_main.c @@ -633,22 +633,7 @@ int kvm_write_guest(struct kvm *kvm, gpa_t gpa, const void *data, int kvm_clear_guest_page(struct kvm *kvm, gfn_t gfn, int offset, int len) { - void *page_virt; - struct page *page; - - page = gfn_to_page(kvm, gfn); - if (is_error_page(page)) { - kvm_release_page(page); - return -EFAULT; - } - page_virt = kmap_atomic(page, KM_USER0); - - memset(page_virt + offset, 0, len); - - kunmap_atomic(page_virt, KM_USER0); - kvm_release_page(page); - mark_page_dirty(kvm, gfn); - return 0; + return kvm_write_guest_page(kvm, gfn, empty_zero_page, offset, len); } EXPORT_SYMBOL_GPL(kvm_clear_guest_page); |