|
@@ -708,11 +708,13 @@ void gmap_discard(struct gmap *gmap, unsigned long from, unsigned long to)
|
|
|
vmaddr |= gaddr & ~PMD_MASK;
|
|
|
/* Find vma in the parent mm */
|
|
|
vma = find_vma(gmap->mm, vmaddr);
|
|
|
+ if (!vma)
|
|
|
+ continue;
|
|
|
/*
|
|
|
* We do not discard pages that are backed by
|
|
|
* hugetlbfs, so we don't have to refault them.
|
|
|
*/
|
|
|
- if (vma && is_vm_hugetlb_page(vma))
|
|
|
+ if (is_vm_hugetlb_page(vma))
|
|
|
continue;
|
|
|
size = min(to - gaddr, PMD_SIZE - (gaddr & ~PMD_MASK));
|
|
|
zap_page_range(vma, vmaddr, size);
|