blob: 3e2e3ca63048790b662ac24961250929a0d71fac [file] [log] [blame]
Linus Torvalds1da177e2005-04-16 15:20:36 -07001#ifndef _X86_64_PAGE_H
2#define _X86_64_PAGE_H
3
Jeremy Fitzhardinge11b7c7d2008-01-30 13:32:44 +01004#define PAGETABLE_LEVELS 4
Linus Torvalds1da177e2005-04-16 15:20:36 -07005
Jeremy Fitzhardinge11b7c7d2008-01-30 13:32:44 +01006#define THREAD_ORDER 1
7#define THREAD_SIZE (PAGE_SIZE << THREAD_ORDER)
8#define CURRENT_MASK (~(THREAD_SIZE-1))
9
10#define EXCEPTION_STACK_ORDER 0
11#define EXCEPTION_STKSZ (PAGE_SIZE << EXCEPTION_STACK_ORDER)
12
13#define DEBUG_STACK_ORDER (EXCEPTION_STACK_ORDER + 1)
14#define DEBUG_STKSZ (PAGE_SIZE << DEBUG_STACK_ORDER)
15
16#define IRQSTACK_ORDER 2
17#define IRQSTACKSIZE (PAGE_SIZE << IRQSTACK_ORDER)
18
19#define STACKFAULT_STACK 1
20#define DOUBLEFAULT_STACK 2
21#define NMI_STACK 3
22#define DEBUG_STACK 4
23#define MCE_STACK 5
24#define N_EXCEPTION_STACKS 5 /* hw limit: 7 */
25
Andi Kleenfbff3c22008-02-04 16:48:09 +010026#define PUD_PAGE_SIZE (_AC(1, UL) << PUD_SHIFT)
27#define PUD_PAGE_MASK (~(PUD_PAGE_SIZE-1))
28
Jeremy Fitzhardinge11b7c7d2008-01-30 13:32:44 +010029#define __PAGE_OFFSET _AC(0xffff810000000000, UL)
30
31#define __PHYSICAL_START CONFIG_PHYSICAL_START
32#define __KERNEL_ALIGN 0x200000
33
34/*
35 * Make sure kernel is aligned to 2MB address. Catching it at compile
36 * time is better. Change your config file and compile the kernel
37 * for a 2MB aligned address (CONFIG_PHYSICAL_START)
38 */
39#if (CONFIG_PHYSICAL_START % __KERNEL_ALIGN) != 0
40#error "CONFIG_PHYSICAL_START must be a multiple of 2MB"
41#endif
42
43#define __START_KERNEL (__START_KERNEL_map + __PHYSICAL_START)
44#define __START_KERNEL_map _AC(0xffffffff80000000, UL)
45
46/* See Documentation/x86_64/mm.txt for a description of the memory map. */
47#define __PHYSICAL_MASK_SHIFT 46
48#define __VIRTUAL_MASK_SHIFT 48
49
Ingo Molnar88f3aec2008-02-21 11:04:11 +010050/*
51 * Kernel image size is limited to 128 MB (see level2_kernel_pgt in
52 * arch/x86/kernel/head_64.S), and it is mapped here:
53 */
54#define KERNEL_TEXT_SIZE (128*1024*1024)
55#define KERNEL_TEXT_START _AC(0xffffffff80000000, UL)
Linus Torvalds1da177e2005-04-16 15:20:36 -070056
Linus Torvalds1da177e2005-04-16 15:20:36 -070057#ifndef __ASSEMBLY__
Jeremy Fitzhardinge11b7c7d2008-01-30 13:32:44 +010058void clear_page(void *page);
59void copy_page(void *to, void *from);
Linus Torvalds1da177e2005-04-16 15:20:36 -070060
Jeremy Fitzhardinge11b7c7d2008-01-30 13:32:44 +010061extern unsigned long end_pfn;
62extern unsigned long end_pfn_map;
63extern unsigned long phys_base;
Linus Torvalds1da177e2005-04-16 15:20:36 -070064
Jeremy Fitzhardinge11b7c7d2008-01-30 13:32:44 +010065extern unsigned long __phys_addr(unsigned long);
66#define __phys_reloc_hide(x) (x)
Linus Torvalds1da177e2005-04-16 15:20:36 -070067
Jeremy Fitzhardinge11b7c7d2008-01-30 13:32:44 +010068/*
69 * These are used to make use of C type-checking..
70 */
71typedef unsigned long pteval_t;
72typedef unsigned long pmdval_t;
73typedef unsigned long pudval_t;
74typedef unsigned long pgdval_t;
75typedef unsigned long pgprotval_t;
76typedef unsigned long phys_addr_t;
77
Martin Schwidefsky2f569af2008-02-08 04:22:04 -080078typedef struct page *pgtable_t;
79
Jeremy Fitzhardinge11b7c7d2008-01-30 13:32:44 +010080typedef struct { pteval_t pte; } pte_t;
81
Jeremy Fitzhardinge11b7c7d2008-01-30 13:32:44 +010082#define vmemmap ((struct page *)VMEMMAP_START)
83
84#endif /* !__ASSEMBLY__ */
David Woodhousecd469e02006-04-27 15:48:08 +010085
Jeremy Fitzhardinge83a51012008-01-30 13:32:41 +010086#ifdef CONFIG_FLATMEM
87#define pfn_valid(pfn) ((pfn) < end_pfn)
88#endif
89
90
Linus Torvalds1da177e2005-04-16 15:20:36 -070091#endif /* _X86_64_PAGE_H */