mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git
synced 2025-01-10 07:00:48 +00:00
KVM: Fix *nopage() in kvm_main.c
*nopage() in kvm_main.c should only store the type of mmap() fault if the pointers are not NULL. This patch fixes the problem. Signed-off-by: Nguyen Anh Quynh <aquynh@gmail.com> Signed-off-by: Avi Kivity <avi@qumranet.com>
This commit is contained in:
parent
81fe96bde7
commit
cd0d913797
@ -2285,7 +2285,6 @@ static struct page *kvm_vcpu_nopage(struct vm_area_struct *vma,
|
||||
unsigned long pgoff;
|
||||
struct page *page;
|
||||
|
||||
*type = VM_FAULT_MINOR;
|
||||
pgoff = ((address - vma->vm_start) >> PAGE_SHIFT) + vma->vm_pgoff;
|
||||
if (pgoff == 0)
|
||||
page = virt_to_page(vcpu->run);
|
||||
@ -2294,6 +2293,9 @@ static struct page *kvm_vcpu_nopage(struct vm_area_struct *vma,
|
||||
else
|
||||
return NOPAGE_SIGBUS;
|
||||
get_page(page);
|
||||
if (type != NULL)
|
||||
*type = VM_FAULT_MINOR;
|
||||
|
||||
return page;
|
||||
}
|
||||
|
||||
@ -2768,12 +2770,14 @@ static struct page *kvm_vm_nopage(struct vm_area_struct *vma,
|
||||
unsigned long pgoff;
|
||||
struct page *page;
|
||||
|
||||
*type = VM_FAULT_MINOR;
|
||||
pgoff = ((address - vma->vm_start) >> PAGE_SHIFT) + vma->vm_pgoff;
|
||||
page = gfn_to_page(kvm, pgoff);
|
||||
if (!page)
|
||||
return NOPAGE_SIGBUS;
|
||||
get_page(page);
|
||||
if (type != NULL)
|
||||
*type = VM_FAULT_MINOR;
|
||||
|
||||
return page;
|
||||
}
|
||||
|
||||
|
Loading…
x
Reference in New Issue
Block a user