diff options
Diffstat (limited to 'mm/memory.c')
-rw-r--r-- | mm/memory.c | 20 |
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) | |||
467 | struct page *vm_normal_page(struct vm_area_struct *vma, unsigned long addr, | 467 | struct 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)); | 497 | check_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 | */ |
507 | out: | 507 | out: |