x86: move more pagetable-related definitions into pgtable*.h
[linux-2.6/linux-2.6-openrd.git] / arch / x86 / include / asm / page_32_types.h
blobf1e4a79a6e415702ab6930cedce937afc3e71d54
1 #ifndef _ASM_X86_PAGE_32_DEFS_H
2 #define _ASM_X86_PAGE_32_DEFS_H
4 #include <linux/const.h>
6 /*
7 * This handles the memory map.
9 * A __PAGE_OFFSET of 0xC0000000 means that the kernel has
10 * a virtual address space of one gigabyte, which limits the
11 * amount of physical memory you can use to about 950MB.
13 * If you want more physical memory than this then see the CONFIG_HIGHMEM4G
14 * and CONFIG_HIGHMEM64G options in the kernel configuration.
16 #define __PAGE_OFFSET _AC(CONFIG_PAGE_OFFSET, UL)
18 #ifdef CONFIG_4KSTACKS
19 #define THREAD_ORDER 0
20 #else
21 #define THREAD_ORDER 1
22 #endif
23 #define THREAD_SIZE (PAGE_SIZE << THREAD_ORDER)
25 #define STACKFAULT_STACK 0
26 #define DOUBLEFAULT_STACK 1
27 #define NMI_STACK 0
28 #define DEBUG_STACK 0
29 #define MCE_STACK 0
30 #define N_EXCEPTION_STACKS 1
32 #ifdef CONFIG_X86_PAE
33 /* 44=32+12, the limit we can fit into an unsigned long pfn */
34 #define __PHYSICAL_MASK_SHIFT 44
35 #define __VIRTUAL_MASK_SHIFT 32
37 #else /* !CONFIG_X86_PAE */
38 #define __PHYSICAL_MASK_SHIFT 32
39 #define __VIRTUAL_MASK_SHIFT 32
40 #endif /* CONFIG_X86_PAE */
42 #ifndef __ASSEMBLY__
45 * This much address space is reserved for vmalloc() and iomap()
46 * as well as fixmap mappings.
48 extern unsigned int __VMALLOC_RESERVE;
49 extern int sysctl_legacy_va_layout;
51 extern void find_low_pfn_range(void);
52 extern unsigned long init_memory_mapping(unsigned long start,
53 unsigned long end);
54 extern void initmem_init(unsigned long, unsigned long);
55 extern void free_initmem(void);
56 extern void setup_bootmem_allocator(void);
58 #endif /* !__ASSEMBLY__ */
60 #endif /* _ASM_X86_PAGE_32_DEFS_H */