aboutsummaryrefslogtreecommitdiffstats
path: root/mm/memory.c
diff options
context:
space:
mode:
Diffstat (limited to 'mm/memory.c')
-rw-r--r--mm/memory.c20
1 files changed, 10 insertions, 10 deletions
diff --git a/mm/memory.c b/mm/memory.c
index cda04b19f733..890095f5f36d 100644
--- a/mm/memory.c
+++ b/mm/memory.c
@@ -467,21 +467,18 @@ static inline int is_cow_mapping(unsigned int flags)
467struct page *vm_normal_page(struct vm_area_struct *vma, unsigned long addr, 467struct page *vm_normal_page(struct vm_area_struct *vma, unsigned long addr,
468 pte_t pte) 468 pte_t pte)
469{ 469{
470 unsigned long pfn; 470 unsigned long pfn = pte_pfn(pte);
471 471
472 if (HAVE_PTE_SPECIAL) { 472 if (HAVE_PTE_SPECIAL) {
473 if (likely(!pte_special(pte))) { 473 if (likely(!pte_special(pte)))
474 VM_BUG_ON(!pfn_valid(pte_pfn(pte))); 474 goto check_pfn;
475 return pte_page(pte); 475 if (!(vma->vm_flags & (VM_PFNMAP | VM_MIXEDMAP)))
476 } 476 print_bad_pte(vma, addr, pte, NULL);
477 VM_BUG_ON(!(vma->vm_flags & (VM_PFNMAP | VM_MIXEDMAP)));
478 return NULL; 477 return NULL;
479 } 478 }
480 479
481 /* !HAVE_PTE_SPECIAL case follows: */ 480 /* !HAVE_PTE_SPECIAL case follows: */
482 481
483 pfn = pte_pfn(pte);
484
485 if (unlikely(vma->vm_flags & (VM_PFNMAP|VM_MIXEDMAP))) { 482 if (unlikely(vma->vm_flags & (VM_PFNMAP|VM_MIXEDMAP))) {
486 if (vma->vm_flags & VM_MIXEDMAP) { 483 if (vma->vm_flags & VM_MIXEDMAP) {
487 if (!pfn_valid(pfn)) 484 if (!pfn_valid(pfn))
@@ -497,11 +494,14 @@ struct page *vm_normal_page(struct vm_area_struct *vma, unsigned long addr,
497 } 494 }
498 } 495 }
499 496
500 VM_BUG_ON(!pfn_valid(pfn)); 497check_pfn:
498 if (unlikely(pfn > highest_memmap_pfn)) {
499 print_bad_pte(vma, addr, pte, NULL);
500 return NULL;
501 }
501 502
502 /* 503 /*
503 * NOTE! We still have PageReserved() pages in the page tables. 504 * NOTE! We still have PageReserved() pages in the page tables.
504 *
505 * eg. VDSO mappings can cause them to exist. 505 * eg. VDSO mappings can cause them to exist.
506 */ 506 */
507out: 507out: