|
@@ -706,6 +706,12 @@ 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);
|
|
|
+ /*
|
|
|
+ * 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))
|
|
|
+ continue;
|
|
|
size = min(to - gaddr, PMD_SIZE - (gaddr & ~PMD_MASK));
|
|
|
zap_page_range(vma, vmaddr, size);
|
|
|
}
|