提交 1b2e2b73 编写于 作者: R Russell King 提交者: Russell King

[ARM] Cleanup arch/arm/mm a little

Move top_pmd into arch/arm/mm/mm.h - nothing outside arch/arm/mm
references it.

Move the repeated definition of TOP_PTE into mm/mm.h, as well as
a few function prototypes.
Signed-off-by: NRussell King <rmk+kernel@arm.linux.org.uk>
上级 e478bec0
...@@ -20,6 +20,8 @@ ...@@ -20,6 +20,8 @@
#include <asm/pgtable.h> #include <asm/pgtable.h>
#include <asm/tlbflush.h> #include <asm/tlbflush.h>
#include "mm.h"
/* /*
* 0xffff8000 to 0xffffffff is reserved for any ARM architecture * 0xffff8000 to 0xffffffff is reserved for any ARM architecture
* specific hacks for copying pages efficiently. * specific hacks for copying pages efficiently.
...@@ -27,8 +29,6 @@ ...@@ -27,8 +29,6 @@
#define minicache_pgprot __pgprot(L_PTE_PRESENT | L_PTE_YOUNG | \ #define minicache_pgprot __pgprot(L_PTE_PRESENT | L_PTE_YOUNG | \
L_PTE_CACHEABLE) L_PTE_CACHEABLE)
#define TOP_PTE(x) pte_offset_kernel(top_pmd, x)
static DEFINE_SPINLOCK(minicache_lock); static DEFINE_SPINLOCK(minicache_lock);
/* /*
......
...@@ -17,6 +17,8 @@ ...@@ -17,6 +17,8 @@
#include <asm/tlbflush.h> #include <asm/tlbflush.h>
#include <asm/cacheflush.h> #include <asm/cacheflush.h>
#include "mm.h"
#if SHMLBA > 16384 #if SHMLBA > 16384
#error FIX ME #error FIX ME
#endif #endif
...@@ -24,8 +26,6 @@ ...@@ -24,8 +26,6 @@
#define from_address (0xffff8000) #define from_address (0xffff8000)
#define to_address (0xffffc000) #define to_address (0xffffc000)
#define TOP_PTE(x) pte_offset_kernel(top_pmd, x)
static DEFINE_SPINLOCK(v6_lock); static DEFINE_SPINLOCK(v6_lock);
/* /*
......
...@@ -20,6 +20,8 @@ ...@@ -20,6 +20,8 @@
#include <asm/pgtable.h> #include <asm/pgtable.h>
#include <asm/tlbflush.h> #include <asm/tlbflush.h>
#include "mm.h"
/* /*
* 0xffff8000 to 0xffffffff is reserved for any ARM architecture * 0xffff8000 to 0xffffffff is reserved for any ARM architecture
* specific hacks for copying pages efficiently. * specific hacks for copying pages efficiently.
...@@ -29,8 +31,6 @@ ...@@ -29,8 +31,6 @@
#define minicache_pgprot __pgprot(L_PTE_PRESENT | L_PTE_YOUNG | \ #define minicache_pgprot __pgprot(L_PTE_PRESENT | L_PTE_YOUNG | \
L_PTE_CACHEABLE) L_PTE_CACHEABLE)
#define TOP_PTE(x) pte_offset_kernel(top_pmd, x)
static DEFINE_SPINLOCK(minicache_lock); static DEFINE_SPINLOCK(minicache_lock);
/* /*
......
...@@ -15,12 +15,12 @@ ...@@ -15,12 +15,12 @@
#include <asm/system.h> #include <asm/system.h>
#include <asm/tlbflush.h> #include <asm/tlbflush.h>
#include "mm.h"
#ifdef CONFIG_CPU_CACHE_VIPT #ifdef CONFIG_CPU_CACHE_VIPT
#define ALIAS_FLUSH_START 0xffff4000 #define ALIAS_FLUSH_START 0xffff4000
#define TOP_PTE(x) pte_offset_kernel(top_pmd, x)
static void flush_pfn_alias(unsigned long pfn, unsigned long vaddr) static void flush_pfn_alias(unsigned long pfn, unsigned long vaddr)
{ {
unsigned long to = ALIAS_FLUSH_START + (CACHE_COLOUR(vaddr) << PAGE_SHIFT); unsigned long to = ALIAS_FLUSH_START + (CACHE_COLOUR(vaddr) << PAGE_SHIFT);
......
...@@ -25,6 +25,8 @@ ...@@ -25,6 +25,8 @@
#include <asm/mach/arch.h> #include <asm/mach/arch.h>
#include <asm/mach/map.h> #include <asm/mach/map.h>
#include "mm.h"
DEFINE_PER_CPU(struct mmu_gather, mmu_gathers); DEFINE_PER_CPU(struct mmu_gather, mmu_gathers);
extern pgd_t swapper_pg_dir[PTRS_PER_PGD]; extern pgd_t swapper_pg_dir[PTRS_PER_PGD];
...@@ -44,6 +46,11 @@ static struct meminfo meminfo __initdata = { 0, }; ...@@ -44,6 +46,11 @@ static struct meminfo meminfo __initdata = { 0, };
*/ */
struct page *empty_zero_page; struct page *empty_zero_page;
/*
* The pmd table for the upper-most set of pages.
*/
pmd_t *top_pmd;
void show_mem(void) void show_mem(void)
{ {
int free = 0, total = 0, reserved = 0; int free = 0, total = 0, reserved = 0;
...@@ -83,16 +90,6 @@ void show_mem(void) ...@@ -83,16 +90,6 @@ void show_mem(void)
printk("%d pages swap cached\n", cached); printk("%d pages swap cached\n", cached);
} }
static inline pmd_t *pmd_off(pgd_t *pgd, unsigned long virt)
{
return pmd_offset(pgd, virt);
}
static inline pmd_t *pmd_off_k(unsigned long virt)
{
return pmd_off(pgd_offset_k(virt), virt);
}
#define for_each_nodebank(iter,mi,no) \ #define for_each_nodebank(iter,mi,no) \
for (iter = 0; iter < mi->nr_banks; iter++) \ for (iter = 0; iter < mi->nr_banks; iter++) \
if (mi->bank[iter].node == no) if (mi->bank[iter].node == no)
...@@ -229,9 +226,6 @@ static __init void reserve_node_zero(pg_data_t *pgdat) ...@@ -229,9 +226,6 @@ static __init void reserve_node_zero(pg_data_t *pgdat)
reserve_bootmem_node(pgdat, PHYS_OFFSET, res_size); reserve_bootmem_node(pgdat, PHYS_OFFSET, res_size);
} }
void __init build_mem_type_table(void);
void __init create_mapping(struct map_desc *md);
static unsigned long __init static unsigned long __init
bootmem_init_node(int node, int initrd_node, struct meminfo *mi) bootmem_init_node(int node, int initrd_node, struct meminfo *mi)
{ {
......
...@@ -23,6 +23,8 @@ ...@@ -23,6 +23,8 @@
#include <asm/mach/map.h> #include <asm/mach/map.h>
#include "mm.h"
#define CPOLICY_UNCACHED 0 #define CPOLICY_UNCACHED 0
#define CPOLICY_BUFFERED 1 #define CPOLICY_BUFFERED 1
#define CPOLICY_WRITETHROUGH 2 #define CPOLICY_WRITETHROUGH 2
...@@ -35,8 +37,6 @@ pgprot_t pgprot_kernel; ...@@ -35,8 +37,6 @@ pgprot_t pgprot_kernel;
EXPORT_SYMBOL(pgprot_kernel); EXPORT_SYMBOL(pgprot_kernel);
pmd_t *top_pmd;
struct cachepolicy { struct cachepolicy {
const char policy[16]; const char policy[16];
unsigned int cr_mask; unsigned int cr_mask;
...@@ -142,16 +142,6 @@ __setup("noalign", noalign_setup); ...@@ -142,16 +142,6 @@ __setup("noalign", noalign_setup);
#define FIRST_KERNEL_PGD_NR (FIRST_USER_PGD_NR + USER_PTRS_PER_PGD) #define FIRST_KERNEL_PGD_NR (FIRST_USER_PGD_NR + USER_PTRS_PER_PGD)
static inline pmd_t *pmd_off(pgd_t *pgd, unsigned long virt)
{
return pmd_offset(pgd, virt);
}
static inline pmd_t *pmd_off_k(unsigned long virt)
{
return pmd_off(pgd_offset_k(virt), virt);
}
/* /*
* need to get a 16k page for level 1 * need to get a 16k page for level 1
*/ */
......
/* the upper-most page table pointer */
extern pmd_t *top_pmd;
#define TOP_PTE(x) pte_offset_kernel(top_pmd, x)
static inline pmd_t *pmd_off(pgd_t *pgd, unsigned long virt)
{
return pmd_offset(pgd, virt);
}
static inline pmd_t *pmd_off_k(unsigned long virt)
{
return pmd_off(pgd_offset_k(virt), virt);
}
struct map_desc;
void __init build_mem_type_table(void);
void __init create_mapping(struct map_desc *md);
...@@ -174,9 +174,6 @@ typedef unsigned long pgprot_t; ...@@ -174,9 +174,6 @@ typedef unsigned long pgprot_t;
#endif /* STRICT_MM_TYPECHECKS */ #endif /* STRICT_MM_TYPECHECKS */
/* the upper-most page table pointer */
extern pmd_t *top_pmd;
#endif /* CONFIG_MMU */ #endif /* CONFIG_MMU */
#include <asm/memory.h> #include <asm/memory.h>
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册