]> git.karo-electronics.de Git - karo-tx-linux.git/commitdiff
ARM: LPAE: Use a mask for physical addresses in page table entries
authorCatalin Marinas <catalin.marinas@arm.com>
Mon, 31 Jan 2011 13:50:41 +0000 (13:50 +0000)
committerCatalin Marinas <catalin.marinas@arm.com>
Tue, 14 Jun 2011 13:43:57 +0000 (14:43 +0100)
With LPAE, the physical address mask is 40-bit while the page table
entry is 64-bit. This patch introduces PHYS_MASK for the 2-level page
table format, defined as ~0UL.

Signed-off-by: Catalin Marinas <catalin.marinas@arm.com>
arch/arm/include/asm/pgtable-2level-hwdef.h
arch/arm/include/asm/pgtable.h

index 2b52c40edd80e83b25364adc37ef8611bedc61ab..5cfba15cb401e58d7b291fac12e7395683a9d61f 100644 (file)
@@ -88,4 +88,6 @@
 #define PTE_SMALL_AP_URO_SRW   (_AT(pteval_t, 0xaa) << 4)
 #define PTE_SMALL_AP_URW_SRW   (_AT(pteval_t, 0xff) << 4)
 
+#define PHYS_MASK              (~0UL)
+
 #endif
index 9618052a14bbdee045b634145a942302efd42208..8f9e1dd2ec7c294e2891c5ccde9b82495909dccf 100644 (file)
@@ -199,10 +199,10 @@ static inline pmd_t *pmd_offset(pud_t *pud, unsigned long addr)
 
 static inline pte_t *pmd_page_vaddr(pmd_t pmd)
 {
-       return __va(pmd_val(pmd) & PAGE_MASK);
+       return __va(pmd_val(pmd) & PHYS_MASK & (s32)PAGE_MASK);
 }
 
-#define pmd_page(pmd)          pfn_to_page(__phys_to_pfn(pmd_val(pmd)))
+#define pmd_page(pmd)          pfn_to_page(__phys_to_pfn(pmd_val(pmd) & PHYS_MASK))
 
 /* we don't need complex calculations here as the pmd is folded into the pgd */
 #define pmd_addr_end(addr,end) (end)
@@ -223,7 +223,7 @@ static inline pte_t *pmd_page_vaddr(pmd_t pmd)
 #define pte_offset_map(pmd,addr)       (__pte_map(pmd) + pte_index(addr))
 #define pte_unmap(pte)                 __pte_unmap(pte)
 
-#define pte_pfn(pte)           (pte_val(pte) >> PAGE_SHIFT)
+#define pte_pfn(pte)           ((pte_val(pte) & PHYS_MASK) >> PAGE_SHIFT)
 #define pfn_pte(pfn,prot)      __pte(__pfn_to_phys(pfn) | pgprot_val(prot))
 
 #define pte_page(pte)          pfn_to_page(pte_pfn(pte))