]> git.proxmox.com Git - mirror_ubuntu-artful-kernel.git/blame - arch/x86/include/asm/page_types.h
x86/mm/ASLR: Propagate base load address calculation
[mirror_ubuntu-artful-kernel.git] / arch / x86 / include / asm / page_types.h
CommitLineData
51c78eb3
JF
1#ifndef _ASM_X86_PAGE_DEFS_H
2#define _ASM_X86_PAGE_DEFS_H
3
4#include <linux/const.h>
45635ab5 5#include <linux/types.h>
f47233c2 6#include <asm/bootparam.h>
51c78eb3
JF
7
8/* PAGE_SHIFT determines the page size */
9#define PAGE_SHIFT 12
10#define PAGE_SIZE (_AC(1,UL) << PAGE_SHIFT)
11#define PAGE_MASK (~(PAGE_SIZE-1))
12
a416e9e1 13#define __PHYSICAL_MASK ((phys_addr_t)((1ULL << __PHYSICAL_MASK_SHIFT) - 1))
51c78eb3
JF
14#define __VIRTUAL_MASK ((1UL << __VIRTUAL_MASK_SHIFT) - 1)
15
16/* Cast PAGE_MASK to a signed type so that it is sign-extended if
17 virtual addresses are 32-bits but physical addresses are larger
18 (ie, 32-bit PAE). */
19#define PHYSICAL_PAGE_MASK (((signed long)PAGE_MASK) & __PHYSICAL_MASK)
20
51c78eb3
JF
21#define PMD_PAGE_SIZE (_AC(1, UL) << PMD_SHIFT)
22#define PMD_PAGE_MASK (~(PMD_PAGE_SIZE-1))
23
24#define HPAGE_SHIFT PMD_SHIFT
25#define HPAGE_SIZE (_AC(1,UL) << HPAGE_SHIFT)
26#define HPAGE_MASK (~(HPAGE_SIZE - 1))
27#define HUGETLB_PAGE_ORDER (HPAGE_SHIFT - PAGE_SHIFT)
28
29#define HUGE_MAX_HSTATE 2
30
31#define PAGE_OFFSET ((unsigned long)__PAGE_OFFSET)
32
33#define VM_DATA_DEFAULT_FLAGS \
34 (((current->personality & READ_IMPLIES_EXEC) ? VM_EXEC : 0 ) | \
35 VM_READ | VM_WRITE | VM_MAYREAD | VM_MAYWRITE | VM_MAYEXEC)
36
a0215061
KC
37#define __PHYSICAL_START ALIGN(CONFIG_PHYSICAL_START, \
38 CONFIG_PHYSICAL_ALIGN)
39
40#define __START_KERNEL (__START_KERNEL_map + __PHYSICAL_START)
41
51c78eb3
JF
42#ifdef CONFIG_X86_64
43#include <asm/page_64_types.h>
44#else
45#include <asm/page_32_types.h>
46#endif /* CONFIG_X86_64 */
47
48#ifndef __ASSEMBLY__
49
51c78eb3 50extern int devmem_is_allowed(unsigned long pagenr);
51c78eb3
JF
51
52extern unsigned long max_low_pfn_mapped;
53extern unsigned long max_pfn_mapped;
54
f47233c2
JK
55extern bool kaslr_enabled;
56
4ce7a869 57static inline phys_addr_t get_max_mapped(void)
45635ab5 58{
4ce7a869 59 return (phys_addr_t)max_pfn_mapped << PAGE_SHIFT;
45635ab5
YL
60}
61
66520ebc 62bool pfn_range_is_mapped(unsigned long start_pfn, unsigned long end_pfn);
dda56e13 63
66aa230e
JSR
64extern unsigned long init_memory_mapping(unsigned long start,
65 unsigned long end);
66
d8fc3afc 67extern void initmem_init(void);
66aa230e 68
51c78eb3
JF
69#endif /* !__ASSEMBLY__ */
70
71#endif /* _ASM_X86_PAGE_DEFS_H */