From 0c0b074f71ef7710e1de1e63c48e98b516ca0b96 Mon Sep 17 00:00:00 2001 From: Izik Eidus Date: Sun, 11 Nov 2007 22:02:22 +0200 Subject: [PATCH] --- yaml --- r: 80716 b: refs/heads/master c: f9d46eb0e4a5b5e0926ca61c19f8c8bbb9496b28 h: refs/heads/master v: v3 --- [refs] | 2 +- trunk/drivers/kvm/kvm.h | 1 + trunk/drivers/kvm/kvm_main.c | 11 +++++++++++ 3 files changed, 13 insertions(+), 1 deletion(-) diff --git a/[refs] b/[refs] index ec7b69c0b1d0..cb3fd8d86ba5 100644 --- a/[refs] +++ b/[refs] @@ -1,2 +1,2 @@ --- -refs/heads/master: 1a6f4d7fbd11e539630cd5637311a4e55fae60ef +refs/heads/master: f9d46eb0e4a5b5e0926ca61c19f8c8bbb9496b28 diff --git a/trunk/drivers/kvm/kvm.h b/trunk/drivers/kvm/kvm.h index 3f5ffc37480d..64983240adca 100644 --- a/trunk/drivers/kvm/kvm.h +++ b/trunk/drivers/kvm/kvm.h @@ -520,6 +520,7 @@ struct page *gva_to_page(struct kvm_vcpu *vcpu, gva_t gva); extern struct page *bad_page; int is_error_page(struct page *page); +int kvm_is_error_hva(unsigned long addr); int kvm_set_memory_region(struct kvm *kvm, struct kvm_userspace_memory_region *mem, int user_alloc); diff --git a/trunk/drivers/kvm/kvm_main.c b/trunk/drivers/kvm/kvm_main.c index d395c987894e..dfb65e2f87ee 100644 --- a/trunk/drivers/kvm/kvm_main.c +++ b/trunk/drivers/kvm/kvm_main.c @@ -498,6 +498,17 @@ int is_error_page(struct page *page) } EXPORT_SYMBOL_GPL(is_error_page); +static inline unsigned long bad_hva(void) +{ + return PAGE_OFFSET; +} + +int kvm_is_error_hva(unsigned long addr) +{ + return addr == bad_hva(); +} +EXPORT_SYMBOL_GPL(kvm_is_error_hva); + gfn_t unalias_gfn(struct kvm *kvm, gfn_t gfn) { int i;