Commit 6439d1c6 authored by David S. Miller's avatar David S. Miller

sparc32: Un-btfixup PAGE_{NONE,COPY,READONLY,SHARED,KERNEL}.

That lets us also get rid of the run-time initialization of
protection_map[] and all the ugly module workarounds for
PAGE_KERNEL and PAGE_SHARED to deal with the fact that we
can't do btfixups for modular code.
Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
parent 3d827367
...@@ -32,11 +32,6 @@ extern unsigned long calc_highpages(void); ...@@ -32,11 +32,6 @@ extern unsigned long calc_highpages(void);
#define pmd_ERROR(e) __builtin_trap() #define pmd_ERROR(e) __builtin_trap()
#define pgd_ERROR(e) __builtin_trap() #define pgd_ERROR(e) __builtin_trap()
BTFIXUPDEF_INT(page_none)
BTFIXUPDEF_INT(page_copy)
BTFIXUPDEF_INT(page_readonly)
BTFIXUPDEF_INT(page_kernel)
#define PMD_SHIFT 22 #define PMD_SHIFT 22
#define PMD_SIZE (1UL << PMD_SHIFT) #define PMD_SIZE (1UL << PMD_SHIFT)
#define PMD_MASK (~(PMD_SIZE-1)) #define PMD_MASK (~(PMD_SIZE-1))
...@@ -51,18 +46,11 @@ BTFIXUPDEF_INT(page_kernel) ...@@ -51,18 +46,11 @@ BTFIXUPDEF_INT(page_kernel)
#define FIRST_USER_ADDRESS 0 #define FIRST_USER_ADDRESS 0
#define PTE_SIZE (PTRS_PER_PTE*4) #define PTE_SIZE (PTRS_PER_PTE*4)
#define PAGE_NONE __pgprot(BTFIXUP_INT(page_none)) #define PAGE_NONE SRMMU_PAGE_NONE
extern pgprot_t PAGE_SHARED; #define PAGE_SHARED SRMMU_PAGE_SHARED
#define PAGE_COPY __pgprot(BTFIXUP_INT(page_copy)) #define PAGE_COPY SRMMU_PAGE_COPY
#define PAGE_READONLY __pgprot(BTFIXUP_INT(page_readonly)) #define PAGE_READONLY SRMMU_PAGE_RDONLY
#define PAGE_KERNEL SRMMU_PAGE_KERNEL
extern unsigned long page_kernel;
#ifdef MODULE
#define PAGE_KERNEL page_kernel
#else
#define PAGE_KERNEL __pgprot(BTFIXUP_INT(page_kernel))
#endif
/* Top-level page directory */ /* Top-level page directory */
extern pgd_t swapper_pg_dir[1024]; extern pgd_t swapper_pg_dir[1024];
...@@ -71,28 +59,24 @@ extern void paging_init(void); ...@@ -71,28 +59,24 @@ extern void paging_init(void);
extern unsigned long ptr_in_current_pgd; extern unsigned long ptr_in_current_pgd;
/* Here is a trick, since mmap.c need the initializer elements for /* xwr */
* protection_map[] to be constant at compile time, I set the following #define __P000 PAGE_NONE
* to all zeros. I set it to the real values after I link in the #define __P001 PAGE_READONLY
* appropriate MMU page table routines at boot time. #define __P010 PAGE_COPY
*/ #define __P011 PAGE_COPY
#define __P000 __pgprot(0) #define __P100 PAGE_READONLY
#define __P001 __pgprot(0) #define __P101 PAGE_READONLY
#define __P010 __pgprot(0) #define __P110 PAGE_COPY
#define __P011 __pgprot(0) #define __P111 PAGE_COPY
#define __P100 __pgprot(0)
#define __P101 __pgprot(0) #define __S000 PAGE_NONE
#define __P110 __pgprot(0) #define __S001 PAGE_READONLY
#define __P111 __pgprot(0) #define __S010 PAGE_SHARED
#define __S011 PAGE_SHARED
#define __S000 __pgprot(0) #define __S100 PAGE_READONLY
#define __S001 __pgprot(0) #define __S101 PAGE_READONLY
#define __S010 __pgprot(0) #define __S110 PAGE_SHARED
#define __S011 __pgprot(0) #define __S111 PAGE_SHARED
#define __S100 __pgprot(0)
#define __S101 __pgprot(0)
#define __S110 __pgprot(0)
#define __S111 __pgprot(0)
extern int num_contexts; extern int num_contexts;
......
...@@ -44,9 +44,6 @@ EXPORT_SYMBOL(phys_base); ...@@ -44,9 +44,6 @@ EXPORT_SYMBOL(phys_base);
unsigned long pfn_base; unsigned long pfn_base;
EXPORT_SYMBOL(pfn_base); EXPORT_SYMBOL(pfn_base);
unsigned long page_kernel;
EXPORT_SYMBOL(page_kernel);
struct sparc_phys_banks sp_banks[SPARC_PHYS_BANKS+1]; struct sparc_phys_banks sp_banks[SPARC_PHYS_BANKS+1];
unsigned long sparc_unmapped_base; unsigned long sparc_unmapped_base;
...@@ -293,9 +290,6 @@ unsigned long __init bootmem_init(unsigned long *pages_avail) ...@@ -293,9 +290,6 @@ unsigned long __init bootmem_init(unsigned long *pages_avail)
extern void srmmu_paging_init(void); extern void srmmu_paging_init(void);
extern void device_scan(void); extern void device_scan(void);
pgprot_t PAGE_SHARED __read_mostly;
EXPORT_SYMBOL(PAGE_SHARED);
void __init paging_init(void) void __init paging_init(void)
{ {
switch(sparc_cpu_model) { switch(sparc_cpu_model) {
...@@ -315,23 +309,6 @@ void __init paging_init(void) ...@@ -315,23 +309,6 @@ void __init paging_init(void)
prom_halt(); prom_halt();
} }
/* Initialize the protection map with non-constant, MMU dependent values. */
protection_map[0] = PAGE_NONE;
protection_map[1] = PAGE_READONLY;
protection_map[2] = PAGE_COPY;
protection_map[3] = PAGE_COPY;
protection_map[4] = PAGE_READONLY;
protection_map[5] = PAGE_READONLY;
protection_map[6] = PAGE_COPY;
protection_map[7] = PAGE_COPY;
protection_map[8] = PAGE_NONE;
protection_map[9] = PAGE_READONLY;
protection_map[10] = PAGE_SHARED;
protection_map[11] = PAGE_SHARED;
protection_map[12] = PAGE_READONLY;
protection_map[13] = PAGE_READONLY;
protection_map[14] = PAGE_SHARED;
protection_map[15] = PAGE_SHARED;
btfixup(); btfixup();
prom_build_devicetree(); prom_build_devicetree();
of_fill_in_cpu_data(); of_fill_in_cpu_data();
......
...@@ -59,8 +59,6 @@ extern struct resource sparc_iomap; ...@@ -59,8 +59,6 @@ extern struct resource sparc_iomap;
extern unsigned long last_valid_pfn; extern unsigned long last_valid_pfn;
extern unsigned long page_kernel;
static pgd_t *srmmu_swapper_pg_dir; static pgd_t *srmmu_swapper_pg_dir;
#ifdef CONFIG_SMP #ifdef CONFIG_SMP
...@@ -2078,13 +2076,6 @@ void __init ld_mmu_srmmu(void) ...@@ -2078,13 +2076,6 @@ void __init ld_mmu_srmmu(void)
extern void ld_mmu_iounit(void); extern void ld_mmu_iounit(void);
extern void ___xchg32_sun4md(void); extern void ___xchg32_sun4md(void);
BTFIXUPSET_INT(page_none, pgprot_val(SRMMU_PAGE_NONE));
PAGE_SHARED = pgprot_val(SRMMU_PAGE_SHARED);
BTFIXUPSET_INT(page_copy, pgprot_val(SRMMU_PAGE_COPY));
BTFIXUPSET_INT(page_readonly, pgprot_val(SRMMU_PAGE_RDONLY));
BTFIXUPSET_INT(page_kernel, pgprot_val(SRMMU_PAGE_KERNEL));
page_kernel = pgprot_val(SRMMU_PAGE_KERNEL);
/* Functions */ /* Functions */
#ifndef CONFIG_SMP #ifndef CONFIG_SMP
BTFIXUPSET_CALL(___xchg32, ___xchg32_sun4md, BTFIXUPCALL_SWAPG1G2); BTFIXUPSET_CALL(___xchg32, ___xchg32_sun4md, BTFIXUPCALL_SWAPG1G2);
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment