diff options
| author | Jeff Garzik <jgarzik@pobox.com> | 2005-10-04 10:16:31 -0400 |
|---|---|---|
| committer | Jeff Garzik <jgarzik@pobox.com> | 2005-10-04 10:16:31 -0400 |
| commit | 2ee73cc2d507df7b28050fba5d08bd33dd34848c (patch) | |
| tree | af5f33b265318e0f4b61f788691fe4f780ec402c /include/asm-generic/pgtable.h | |
| parent | c1d9728ecc5b560465df3c0c0d3b3825c2710b40 (diff) | |
| parent | ed39f731ab2e77e58122232f6e27333331d7793d (diff) | |
Merge /spare/repo/linux-2.6/
Diffstat (limited to 'include/asm-generic/pgtable.h')
| -rw-r--r-- | include/asm-generic/pgtable.h | 13 |
1 files changed, 13 insertions, 0 deletions
diff --git a/include/asm-generic/pgtable.h b/include/asm-generic/pgtable.h index f86c1e549466..ff28c8b31f58 100644 --- a/include/asm-generic/pgtable.h +++ b/include/asm-generic/pgtable.h | |||
| @@ -158,6 +158,19 @@ static inline void ptep_set_wrprotect(struct mm_struct *mm, unsigned long addres | |||
| 158 | #define lazy_mmu_prot_update(pte) do { } while (0) | 158 | #define lazy_mmu_prot_update(pte) do { } while (0) |
| 159 | #endif | 159 | #endif |
| 160 | 160 | ||
| 161 | #ifndef __HAVE_ARCH_MULTIPLE_ZERO_PAGE | ||
| 162 | #define move_pte(pte, prot, old_addr, new_addr) (pte) | ||
| 163 | #else | ||
| 164 | #define move_pte(pte, prot, old_addr, new_addr) \ | ||
| 165 | ({ \ | ||
| 166 | pte_t newpte = (pte); \ | ||
| 167 | if (pte_present(pte) && pfn_valid(pte_pfn(pte)) && \ | ||
| 168 | pte_page(pte) == ZERO_PAGE(old_addr)) \ | ||
| 169 | newpte = mk_pte(ZERO_PAGE(new_addr), (prot)); \ | ||
| 170 | newpte; \ | ||
| 171 | }) | ||
| 172 | #endif | ||
| 173 | |||
| 161 | /* | 174 | /* |
| 162 | * When walking page tables, get the address of the next boundary, | 175 | * When walking page tables, get the address of the next boundary, |
| 163 | * or the end address of the range if that comes earlier. Although no | 176 | * or the end address of the range if that comes earlier. Although no |
