diff options
author | Jeremy Fitzhardinge <jeremy@goop.org> | 2008-01-30 07:32:57 -0500 |
---|---|---|
committer | Ingo Molnar <mingo@elte.hu> | 2008-01-30 07:32:57 -0500 |
commit | 6fdc05d4794056e0b98901646c4b68c60a01d5eb (patch) | |
tree | a6cfb308becd6fe47c549084b29c3e9db3a07f68 | |
parent | c3bcfb57e1e64b9b2f8b2d90564826637e21c5ea (diff) |
x86: unify pgtable accessors which use
Make users of supported_pte_mask common. This has the side-effect of
introducing the variable for 32-bit non-PAE, but I think its a pretty
small cost to simplify the code.
Signed-off-by: Jeremy Fitzhardinge <jeremy@xensource.com>
Signed-off-by: Ingo Molnar <mingo@elte.hu>
Signed-off-by: Thomas Gleixner <tglx@linutronix.de>
-rw-r--r-- | arch/x86/mm/init_32.c | 5 | ||||
-rw-r--r-- | include/asm-x86/pgtable-2level.h | 2 | ||||
-rw-r--r-- | include/asm-x86/pgtable-3level.h | 14 | ||||
-rw-r--r-- | include/asm-x86/pgtable.h | 14 | ||||
-rw-r--r-- | include/asm-x86/pgtable_64.h | 18 |
5 files changed, 17 insertions, 36 deletions
diff --git a/arch/x86/mm/init_32.c b/arch/x86/mm/init_32.c index 29130970c19..04332c09ad1 100644 --- a/arch/x86/mm/init_32.c +++ b/arch/x86/mm/init_32.c | |||
@@ -478,11 +478,12 @@ void zap_low_mappings (void) | |||
478 | 478 | ||
479 | int nx_enabled = 0; | 479 | int nx_enabled = 0; |
480 | 480 | ||
481 | pteval_t __supported_pte_mask __read_mostly = ~_PAGE_NX; | ||
482 | EXPORT_SYMBOL_GPL(__supported_pte_mask); | ||
483 | |||
481 | #ifdef CONFIG_X86_PAE | 484 | #ifdef CONFIG_X86_PAE |
482 | 485 | ||
483 | static int disable_nx __initdata = 0; | 486 | static int disable_nx __initdata = 0; |
484 | u64 __supported_pte_mask __read_mostly = ~_PAGE_NX; | ||
485 | EXPORT_SYMBOL_GPL(__supported_pte_mask); | ||
486 | 487 | ||
487 | /* | 488 | /* |
488 | * noexec = on|off | 489 | * noexec = on|off |
diff --git a/include/asm-x86/pgtable-2level.h b/include/asm-x86/pgtable-2level.h index 84b03cf56a7..d3171c0cb15 100644 --- a/include/asm-x86/pgtable-2level.h +++ b/include/asm-x86/pgtable-2level.h | |||
@@ -53,8 +53,6 @@ static inline pte_t native_ptep_get_and_clear(pte_t *xp) | |||
53 | #define pte_page(x) pfn_to_page(pte_pfn(x)) | 53 | #define pte_page(x) pfn_to_page(pte_pfn(x)) |
54 | #define pte_none(x) (!(x).pte_low) | 54 | #define pte_none(x) (!(x).pte_low) |
55 | #define pte_pfn(x) (pte_val(x) >> PAGE_SHIFT) | 55 | #define pte_pfn(x) (pte_val(x) >> PAGE_SHIFT) |
56 | #define pfn_pte(pfn, prot) __pte(((pfn) << PAGE_SHIFT) | pgprot_val(prot)) | ||
57 | #define pfn_pmd(pfn, prot) __pmd(((pfn) << PAGE_SHIFT) | pgprot_val(prot)) | ||
58 | 56 | ||
59 | /* | 57 | /* |
60 | * All present pages are kernel-executable: | 58 | * All present pages are kernel-executable: |
diff --git a/include/asm-x86/pgtable-3level.h b/include/asm-x86/pgtable-3level.h index 9816346f7df..61a7d0029f6 100644 --- a/include/asm-x86/pgtable-3level.h +++ b/include/asm-x86/pgtable-3level.h | |||
@@ -158,20 +158,6 @@ static inline unsigned long pte_pfn(pte_t pte) | |||
158 | return (pte_val(pte) & ~_PAGE_NX) >> PAGE_SHIFT; | 158 | return (pte_val(pte) & ~_PAGE_NX) >> PAGE_SHIFT; |
159 | } | 159 | } |
160 | 160 | ||
161 | extern unsigned long long __supported_pte_mask; | ||
162 | |||
163 | static inline pte_t pfn_pte(unsigned long page_nr, pgprot_t pgprot) | ||
164 | { | ||
165 | return __pte((((unsigned long long)page_nr << PAGE_SHIFT) | | ||
166 | pgprot_val(pgprot)) & __supported_pte_mask); | ||
167 | } | ||
168 | |||
169 | static inline pmd_t pfn_pmd(unsigned long page_nr, pgprot_t pgprot) | ||
170 | { | ||
171 | return __pmd((((unsigned long long)page_nr << PAGE_SHIFT) | | ||
172 | pgprot_val(pgprot)) & __supported_pte_mask); | ||
173 | } | ||
174 | |||
175 | /* | 161 | /* |
176 | * Bits 0, 6 and 7 are taken in the low part of the pte, | 162 | * Bits 0, 6 and 7 are taken in the low part of the pte, |
177 | * put the 32 bits of offset into the high part. | 163 | * put the 32 bits of offset into the high part. |
diff --git a/include/asm-x86/pgtable.h b/include/asm-x86/pgtable.h index 4c03ff2246f..b29a122fc1f 100644 --- a/include/asm-x86/pgtable.h +++ b/include/asm-x86/pgtable.h | |||
@@ -141,6 +141,20 @@ static inline pte_t pte_mkwrite(pte_t pte) { return __pte(pte_val(pte) | _PAGE_R | |||
141 | static inline pte_t pte_mkhuge(pte_t pte) { return __pte(pte_val(pte) | _PAGE_PSE); } | 141 | static inline pte_t pte_mkhuge(pte_t pte) { return __pte(pte_val(pte) | _PAGE_PSE); } |
142 | static inline pte_t pte_clrhuge(pte_t pte) { return __pte(pte_val(pte) & ~_PAGE_PSE); } | 142 | static inline pte_t pte_clrhuge(pte_t pte) { return __pte(pte_val(pte) & ~_PAGE_PSE); } |
143 | 143 | ||
144 | extern pteval_t __supported_pte_mask; | ||
145 | |||
146 | static inline pte_t pfn_pte(unsigned long page_nr, pgprot_t pgprot) | ||
147 | { | ||
148 | return __pte((((phys_addr_t)page_nr << PAGE_SHIFT) | | ||
149 | pgprot_val(pgprot)) & __supported_pte_mask); | ||
150 | } | ||
151 | |||
152 | static inline pmd_t pfn_pmd(unsigned long page_nr, pgprot_t pgprot) | ||
153 | { | ||
154 | return __pmd((((phys_addr_t)page_nr << PAGE_SHIFT) | | ||
155 | pgprot_val(pgprot)) & __supported_pte_mask); | ||
156 | } | ||
157 | |||
144 | #endif /* __ASSEMBLY__ */ | 158 | #endif /* __ASSEMBLY__ */ |
145 | 159 | ||
146 | #ifdef CONFIG_X86_32 | 160 | #ifdef CONFIG_X86_32 |
diff --git a/include/asm-x86/pgtable_64.h b/include/asm-x86/pgtable_64.h index 84f47f9d789..57e4ebe0f7f 100644 --- a/include/asm-x86/pgtable_64.h +++ b/include/asm-x86/pgtable_64.h | |||
@@ -17,7 +17,6 @@ extern pud_t level3_kernel_pgt[512]; | |||
17 | extern pud_t level3_ident_pgt[512]; | 17 | extern pud_t level3_ident_pgt[512]; |
18 | extern pmd_t level2_kernel_pgt[512]; | 18 | extern pmd_t level2_kernel_pgt[512]; |
19 | extern pgd_t init_level4_pgt[]; | 19 | extern pgd_t init_level4_pgt[]; |
20 | extern unsigned long __supported_pte_mask; | ||
21 | 20 | ||
22 | #define swapper_pg_dir init_level4_pgt | 21 | #define swapper_pg_dir init_level4_pgt |
23 | 22 | ||
@@ -165,14 +164,6 @@ static inline unsigned long pmd_bad(pmd_t pmd) | |||
165 | #define pte_page(x) pfn_to_page(pte_pfn(x)) | 164 | #define pte_page(x) pfn_to_page(pte_pfn(x)) |
166 | #define pte_pfn(x) ((pte_val(x) & __PHYSICAL_MASK) >> PAGE_SHIFT) | 165 | #define pte_pfn(x) ((pte_val(x) & __PHYSICAL_MASK) >> PAGE_SHIFT) |
167 | 166 | ||
168 | static inline pte_t pfn_pte(unsigned long page_nr, pgprot_t pgprot) | ||
169 | { | ||
170 | pte_t pte; | ||
171 | pte_val(pte) = (page_nr << PAGE_SHIFT); | ||
172 | pte_val(pte) |= pgprot_val(pgprot); | ||
173 | pte_val(pte) &= __supported_pte_mask; | ||
174 | return pte; | ||
175 | } | ||
176 | struct vm_area_struct; | 167 | struct vm_area_struct; |
177 | 168 | ||
178 | static inline int ptep_test_and_clear_young(struct vm_area_struct *vma, unsigned long addr, pte_t *ptep) | 169 | static inline int ptep_test_and_clear_young(struct vm_area_struct *vma, unsigned long addr, pte_t *ptep) |
@@ -239,15 +230,6 @@ static inline void ptep_set_wrprotect(struct mm_struct *mm, unsigned long addr, | |||
239 | /* page, protection -> pte */ | 230 | /* page, protection -> pte */ |
240 | #define mk_pte(page, pgprot) pfn_pte(page_to_pfn(page), (pgprot)) | 231 | #define mk_pte(page, pgprot) pfn_pte(page_to_pfn(page), (pgprot)) |
241 | 232 | ||
242 | /* Change flags of a PTE */ | ||
243 | static inline pte_t pte_modify(pte_t pte, pgprot_t newprot) | ||
244 | { | ||
245 | pte_val(pte) &= _PAGE_CHG_MASK; | ||
246 | pte_val(pte) |= pgprot_val(newprot); | ||
247 | pte_val(pte) &= __supported_pte_mask; | ||
248 | return pte; | ||
249 | } | ||
250 | |||
251 | #define pte_index(address) \ | 233 | #define pte_index(address) \ |
252 | (((address) >> PAGE_SHIFT) & (PTRS_PER_PTE - 1)) | 234 | (((address) >> PAGE_SHIFT) & (PTRS_PER_PTE - 1)) |
253 | #define pte_offset_kernel(dir, address) ((pte_t *) pmd_page_vaddr(*(dir)) + \ | 235 | #define pte_offset_kernel(dir, address) ((pte_t *) pmd_page_vaddr(*(dir)) + \ |