Commit f66055ab authored by Andrea Arcangeli's avatar Andrea Arcangeli Committed by Linus Torvalds

thp: verify pmd_trans_huge isn't leaking

pte_trans_huge must not leak in certain vmas like the mmio special pfn or
filebacked mappings.
Signed-off-by: default avatarAndrea Arcangeli <aarcange@redhat.com>
Acked-by: default avatarRik van Riel <riel@redhat.com>
Acked-by: default avatarMel Gorman <mel@csn.ul.ie>
Signed-off-by: default avatarAndrew Morton <akpm@linux-foundation.org>
Signed-off-by: default avatarLinus Torvalds <torvalds@linux-foundation.org>
parent 05759d38
...@@ -1451,6 +1451,7 @@ int __get_user_pages(struct task_struct *tsk, struct mm_struct *mm, ...@@ -1451,6 +1451,7 @@ int __get_user_pages(struct task_struct *tsk, struct mm_struct *mm,
pmd = pmd_offset(pud, pg); pmd = pmd_offset(pud, pg);
if (pmd_none(*pmd)) if (pmd_none(*pmd))
return i ? : -EFAULT; return i ? : -EFAULT;
VM_BUG_ON(pmd_trans_huge(*pmd));
pte = pte_offset_map(pmd, pg); pte = pte_offset_map(pmd, pg);
if (pte_none(*pte)) { if (pte_none(*pte)) {
pte_unmap(pte); pte_unmap(pte);
...@@ -1675,8 +1676,10 @@ pte_t *__get_locked_pte(struct mm_struct *mm, unsigned long addr, ...@@ -1675,8 +1676,10 @@ pte_t *__get_locked_pte(struct mm_struct *mm, unsigned long addr,
pud_t * pud = pud_alloc(mm, pgd, addr); pud_t * pud = pud_alloc(mm, pgd, addr);
if (pud) { if (pud) {
pmd_t * pmd = pmd_alloc(mm, pud, addr); pmd_t * pmd = pmd_alloc(mm, pud, addr);
if (pmd) if (pmd) {
VM_BUG_ON(pmd_trans_huge(*pmd));
return pte_alloc_map_lock(mm, pmd, addr, ptl); return pte_alloc_map_lock(mm, pmd, addr, ptl);
}
} }
return NULL; return NULL;
} }
...@@ -1895,6 +1898,7 @@ static inline int remap_pmd_range(struct mm_struct *mm, pud_t *pud, ...@@ -1895,6 +1898,7 @@ static inline int remap_pmd_range(struct mm_struct *mm, pud_t *pud,
pmd = pmd_alloc(mm, pud, addr); pmd = pmd_alloc(mm, pud, addr);
if (!pmd) if (!pmd)
return -ENOMEM; return -ENOMEM;
VM_BUG_ON(pmd_trans_huge(*pmd));
do { do {
next = pmd_addr_end(addr, end); next = pmd_addr_end(addr, end);
if (remap_pte_range(mm, pmd, addr, next, if (remap_pte_range(mm, pmd, addr, next,
...@@ -3471,6 +3475,7 @@ static int __follow_pte(struct mm_struct *mm, unsigned long address, ...@@ -3471,6 +3475,7 @@ static int __follow_pte(struct mm_struct *mm, unsigned long address,
goto out; goto out;
pmd = pmd_offset(pud, address); pmd = pmd_offset(pud, address);
VM_BUG_ON(pmd_trans_huge(*pmd));
if (pmd_none(*pmd) || unlikely(pmd_bad(*pmd))) if (pmd_none(*pmd) || unlikely(pmd_bad(*pmd)))
goto out; goto out;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment