| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 1 | #ifndef _PPC_PAGE_H | 
|  | 2 | #define _PPC_PAGE_H | 
|  | 3 |  | 
| Benjamin Herrenschmidt | a7f290d | 2005-11-11 21:15:21 +1100 | [diff] [blame] | 4 | #include <asm/asm-compat.h> | 
|  | 5 |  | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 6 | /* PAGE_SHIFT determines the page size */ | 
|  | 7 | #define PAGE_SHIFT	12 | 
| Benjamin Herrenschmidt | a7f290d | 2005-11-11 21:15:21 +1100 | [diff] [blame] | 8 | #define PAGE_SIZE	(ASM_CONST(1) << PAGE_SHIFT) | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 9 |  | 
|  | 10 | /* | 
|  | 11 | * Subtle: this is an int (not an unsigned long) and so it | 
|  | 12 | * gets extended to 64 bits the way want (i.e. with 1s).  -- paulus | 
|  | 13 | */ | 
|  | 14 | #define PAGE_MASK	(~((1 << PAGE_SHIFT) - 1)) | 
|  | 15 |  | 
|  | 16 | #ifdef __KERNEL__ | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 17 |  | 
|  | 18 | /* This must match what is in arch/ppc/Makefile */ | 
|  | 19 | #define PAGE_OFFSET	CONFIG_KERNEL_START | 
|  | 20 | #define KERNELBASE	PAGE_OFFSET | 
| Paul Mackerras | e4de002 | 2006-05-09 16:00:59 +1000 | [diff] [blame] | 21 | #define is_kernel_addr(x)	((x) >= PAGE_OFFSET) | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 22 |  | 
|  | 23 | #ifndef __ASSEMBLY__ | 
|  | 24 |  | 
|  | 25 | /* | 
|  | 26 | * The basic type of a PTE - 64 bits for those CPUs with > 32 bit | 
|  | 27 | * physical addressing.  For now this just the IBM PPC440. | 
|  | 28 | */ | 
|  | 29 | #ifdef CONFIG_PTE_64BIT | 
|  | 30 | typedef unsigned long long pte_basic_t; | 
|  | 31 | #define PTE_SHIFT	(PAGE_SHIFT - 3)	/* 512 ptes per page */ | 
|  | 32 | #define PTE_FMT		"%16Lx" | 
|  | 33 | #else | 
|  | 34 | typedef unsigned long pte_basic_t; | 
|  | 35 | #define PTE_SHIFT	(PAGE_SHIFT - 2)	/* 1024 ptes per page */ | 
|  | 36 | #define PTE_FMT		"%.8lx" | 
|  | 37 | #endif | 
|  | 38 |  | 
| Paul Mackerras | 7c8c6b9 | 2005-10-06 12:23:33 +1000 | [diff] [blame] | 39 | /* align addr on a size boundary - adjust address up/down if needed */ | 
|  | 40 | #define _ALIGN_UP(addr,size)	(((addr)+((size)-1))&(~((size)-1))) | 
|  | 41 | #define _ALIGN_DOWN(addr,size)	((addr)&(~((size)-1))) | 
|  | 42 |  | 
|  | 43 | /* align addr on a size boundary - adjust address up if needed */ | 
|  | 44 | #define _ALIGN(addr,size)     _ALIGN_UP(addr,size) | 
|  | 45 |  | 
|  | 46 | /* to align the pointer to the (next) page boundary */ | 
|  | 47 | #define PAGE_ALIGN(addr)	_ALIGN(addr, PAGE_SIZE) | 
|  | 48 |  | 
|  | 49 |  | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 50 | #undef STRICT_MM_TYPECHECKS | 
|  | 51 |  | 
|  | 52 | #ifdef STRICT_MM_TYPECHECKS | 
|  | 53 | /* | 
|  | 54 | * These are used to make use of C type-checking.. | 
|  | 55 | */ | 
|  | 56 | typedef struct { pte_basic_t pte; } pte_t; | 
|  | 57 | typedef struct { unsigned long pmd; } pmd_t; | 
|  | 58 | typedef struct { unsigned long pgd; } pgd_t; | 
|  | 59 | typedef struct { unsigned long pgprot; } pgprot_t; | 
|  | 60 |  | 
|  | 61 | #define pte_val(x)	((x).pte) | 
|  | 62 | #define pmd_val(x)	((x).pmd) | 
|  | 63 | #define pgd_val(x)	((x).pgd) | 
|  | 64 | #define pgprot_val(x)	((x).pgprot) | 
|  | 65 |  | 
|  | 66 | #define __pte(x)	((pte_t) { (x) } ) | 
|  | 67 | #define __pmd(x)	((pmd_t) { (x) } ) | 
|  | 68 | #define __pgd(x)	((pgd_t) { (x) } ) | 
|  | 69 | #define __pgprot(x)	((pgprot_t) { (x) } ) | 
|  | 70 |  | 
|  | 71 | #else | 
|  | 72 | /* | 
|  | 73 | * .. while these make it easier on the compiler | 
|  | 74 | */ | 
|  | 75 | typedef pte_basic_t pte_t; | 
|  | 76 | typedef unsigned long pmd_t; | 
|  | 77 | typedef unsigned long pgd_t; | 
|  | 78 | typedef unsigned long pgprot_t; | 
|  | 79 |  | 
|  | 80 | #define pte_val(x)	(x) | 
|  | 81 | #define pmd_val(x)	(x) | 
|  | 82 | #define pgd_val(x)	(x) | 
|  | 83 | #define pgprot_val(x)	(x) | 
|  | 84 |  | 
|  | 85 | #define __pte(x)	(x) | 
|  | 86 | #define __pmd(x)	(x) | 
|  | 87 | #define __pgd(x)	(x) | 
|  | 88 | #define __pgprot(x)	(x) | 
|  | 89 |  | 
|  | 90 | #endif | 
|  | 91 |  | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 92 | struct page; | 
|  | 93 | extern void clear_pages(void *page, int order); | 
|  | 94 | static inline void clear_page(void *page) { clear_pages(page, 0); } | 
|  | 95 | extern void copy_page(void *to, void *from); | 
|  | 96 | extern void clear_user_page(void *page, unsigned long vaddr, struct page *pg); | 
|  | 97 | extern void copy_user_page(void *to, void *from, unsigned long vaddr, | 
|  | 98 | struct page *pg); | 
|  | 99 |  | 
|  | 100 | #ifndef CONFIG_APUS | 
|  | 101 | #define PPC_MEMSTART	0 | 
|  | 102 | #define PPC_PGSTART	0 | 
|  | 103 | #define PPC_MEMOFFSET	PAGE_OFFSET | 
|  | 104 | #else | 
|  | 105 | extern unsigned long ppc_memstart; | 
|  | 106 | extern unsigned long ppc_pgstart; | 
|  | 107 | extern unsigned long ppc_memoffset; | 
|  | 108 | #define PPC_MEMSTART	ppc_memstart | 
|  | 109 | #define PPC_PGSTART	ppc_pgstart | 
|  | 110 | #define PPC_MEMOFFSET	ppc_memoffset | 
|  | 111 | #endif | 
|  | 112 |  | 
|  | 113 | #if defined(CONFIG_APUS) && !defined(MODULE) | 
|  | 114 | /* map phys->virtual and virtual->phys for RAM pages */ | 
|  | 115 | static inline unsigned long ___pa(unsigned long v) | 
|  | 116 | { | 
|  | 117 | unsigned long p; | 
|  | 118 | asm volatile ("1: addis %0, %1, %2;" | 
|  | 119 | ".section \".vtop_fixup\",\"aw\";" | 
|  | 120 | ".align  1;" | 
|  | 121 | ".long   1b;" | 
|  | 122 | ".previous;" | 
|  | 123 | : "=r" (p) | 
|  | 124 | : "b" (v), "K" (((-PAGE_OFFSET) >> 16) & 0xffff)); | 
|  | 125 |  | 
|  | 126 | return p; | 
|  | 127 | } | 
|  | 128 | static inline void* ___va(unsigned long p) | 
|  | 129 | { | 
|  | 130 | unsigned long v; | 
|  | 131 | asm volatile ("1: addis %0, %1, %2;" | 
|  | 132 | ".section \".ptov_fixup\",\"aw\";" | 
|  | 133 | ".align  1;" | 
|  | 134 | ".long   1b;" | 
|  | 135 | ".previous;" | 
|  | 136 | : "=r" (v) | 
|  | 137 | : "b" (p), "K" (((PAGE_OFFSET) >> 16) & 0xffff)); | 
|  | 138 |  | 
|  | 139 | return (void*) v; | 
|  | 140 | } | 
|  | 141 | #else | 
|  | 142 | #define ___pa(vaddr) ((vaddr)-PPC_MEMOFFSET) | 
|  | 143 | #define ___va(paddr) ((paddr)+PPC_MEMOFFSET) | 
|  | 144 | #endif | 
|  | 145 |  | 
|  | 146 | extern int page_is_ram(unsigned long pfn); | 
|  | 147 |  | 
|  | 148 | #define __pa(x) ___pa((unsigned long)(x)) | 
|  | 149 | #define __va(x) ((void *)(___va((unsigned long)(x)))) | 
|  | 150 |  | 
| KAMEZAWA Hiroyuki | f68d4c9 | 2006-03-27 01:15:44 -0800 | [diff] [blame] | 151 | #define ARCH_PFN_OFFSET		(PPC_PGSTART) | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 152 | #define virt_to_page(kaddr)	pfn_to_page(__pa(kaddr) >> PAGE_SHIFT) | 
|  | 153 | #define page_to_virt(page)	__va(page_to_pfn(page) << PAGE_SHIFT) | 
|  | 154 |  | 
|  | 155 | #define pfn_valid(pfn)		(((pfn) - PPC_PGSTART) < max_mapnr) | 
|  | 156 | #define virt_addr_valid(kaddr)	pfn_valid(__pa(kaddr) >> PAGE_SHIFT) | 
|  | 157 |  | 
|  | 158 | /* Pure 2^n version of get_order */ | 
|  | 159 | extern __inline__ int get_order(unsigned long size) | 
|  | 160 | { | 
|  | 161 | int lz; | 
|  | 162 |  | 
|  | 163 | size = (size-1) >> PAGE_SHIFT; | 
|  | 164 | asm ("cntlzw %0,%1" : "=r" (lz) : "r" (size)); | 
|  | 165 | return 32 - lz; | 
|  | 166 | } | 
|  | 167 |  | 
|  | 168 | #endif /* __ASSEMBLY__ */ | 
|  | 169 |  | 
|  | 170 | #define VM_DATA_DEFAULT_FLAGS	(VM_READ | VM_WRITE | VM_EXEC | \ | 
|  | 171 | VM_MAYREAD | VM_MAYWRITE | VM_MAYEXEC) | 
|  | 172 |  | 
| Adrian Bunk | b3c2ffd | 2006-06-30 18:20:44 +0200 | [diff] [blame] | 173 | /* We do define AT_SYSINFO_EHDR but don't use the gate mechanism */ | 
| Benjamin Herrenschmidt | a7f290d | 2005-11-11 21:15:21 +1100 | [diff] [blame] | 174 | #define __HAVE_ARCH_GATE_AREA		1 | 
|  | 175 |  | 
| KAMEZAWA Hiroyuki | f68d4c9 | 2006-03-27 01:15:44 -0800 | [diff] [blame] | 176 | #include <asm-generic/memory_model.h> | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 177 | #endif /* __KERNEL__ */ | 
|  | 178 | #endif /* _PPC_PAGE_H */ |