Skip to content

Commit

Permalink
---
Browse files Browse the repository at this point in the history
yaml
---
r: 126239
b: refs/heads/master
c: 22b31ee
h: refs/heads/master
i:
  126237: 7cb5601
  126235: ac79112
  126231: 70927c4
  126223: 814b9fa
  126207: 430159b
v: v3
  • Loading branch information
Hugh Dickins authored and Linus Torvalds committed Jan 6, 2009
1 parent 2930bdc commit f570141
Show file tree
Hide file tree
Showing 4 changed files with 16 additions and 11 deletions.
2 changes: 1 addition & 1 deletion [refs]
Original file line number Diff line number Diff line change
@@ -1,2 +1,2 @@
---
refs/heads/master: 3dc147414ccad81dc33edb80774b1fed12a38c08
refs/heads/master: 22b31eec63e5f2e219a3ee15f456897272bc73e8
1 change: 1 addition & 0 deletions trunk/mm/internal.h
Original file line number Diff line number Diff line change
Expand Up @@ -49,6 +49,7 @@ extern void putback_lru_page(struct page *page);
/*
* in mm/page_alloc.c
*/
extern unsigned long highest_memmap_pfn;
extern void __free_pages_bootmem(struct page *page, unsigned int order);

/*
Expand Down
20 changes: 10 additions & 10 deletions trunk/mm/memory.c
Original file line number Diff line number Diff line change
Expand Up @@ -467,21 +467,18 @@ static inline int is_cow_mapping(unsigned int flags)
struct page *vm_normal_page(struct vm_area_struct *vma, unsigned long addr,
pte_t pte)
{
unsigned long pfn;
unsigned long pfn = pte_pfn(pte);

if (HAVE_PTE_SPECIAL) {
if (likely(!pte_special(pte))) {
VM_BUG_ON(!pfn_valid(pte_pfn(pte)));
return pte_page(pte);
}
VM_BUG_ON(!(vma->vm_flags & (VM_PFNMAP | VM_MIXEDMAP)));
if (likely(!pte_special(pte)))
goto check_pfn;
if (!(vma->vm_flags & (VM_PFNMAP | VM_MIXEDMAP)))
print_bad_pte(vma, addr, pte, NULL);
return NULL;
}

/* !HAVE_PTE_SPECIAL case follows: */

pfn = pte_pfn(pte);

if (unlikely(vma->vm_flags & (VM_PFNMAP|VM_MIXEDMAP))) {
if (vma->vm_flags & VM_MIXEDMAP) {
if (!pfn_valid(pfn))
Expand All @@ -497,11 +494,14 @@ struct page *vm_normal_page(struct vm_area_struct *vma, unsigned long addr,
}
}

VM_BUG_ON(!pfn_valid(pfn));
check_pfn:
if (unlikely(pfn > highest_memmap_pfn)) {
print_bad_pte(vma, addr, pte, NULL);
return NULL;
}

/*
* NOTE! We still have PageReserved() pages in the page tables.
*
* eg. VDSO mappings can cause them to exist.
*/
out:
Expand Down
4 changes: 4 additions & 0 deletions trunk/mm/page_alloc.c
Original file line number Diff line number Diff line change
Expand Up @@ -69,6 +69,7 @@ EXPORT_SYMBOL(node_states);

unsigned long totalram_pages __read_mostly;
unsigned long totalreserve_pages __read_mostly;
unsigned long highest_memmap_pfn __read_mostly;
int percpu_pagelist_fraction;

#ifdef CONFIG_HUGETLB_PAGE_SIZE_VARIABLE
Expand Down Expand Up @@ -2597,6 +2598,9 @@ void __meminit memmap_init_zone(unsigned long size, int nid, unsigned long zone,
unsigned long pfn;
struct zone *z;

if (highest_memmap_pfn < end_pfn - 1)
highest_memmap_pfn = end_pfn - 1;

z = &NODE_DATA(nid)->node_zones[zone];
for (pfn = start_pfn; pfn < end_pfn; pfn++) {
/*
Expand Down

0 comments on commit f570141

Please sign in to comment.