|
@@ -188,8 +188,12 @@ static int walk_hugetlb_range(unsigned long addr, unsigned long end,
|
|
|
do {
|
|
|
next = hugetlb_entry_end(h, addr, end);
|
|
|
pte = huge_pte_offset(walk->mm, addr & hmask, sz);
|
|
|
- if (pte && walk->hugetlb_entry)
|
|
|
+
|
|
|
+ if (pte)
|
|
|
err = walk->hugetlb_entry(pte, hmask, addr, next, walk);
|
|
|
+ else if (walk->pte_hole)
|
|
|
+ err = walk->pte_hole(addr, next, walk);
|
|
|
+
|
|
|
if (err)
|
|
|
break;
|
|
|
} while (addr = next, addr != end);
|