blob: 1f5bee2c202fa559177ae964b5cb5ba5d22fad01 [file] [log] [blame]
H. Peter Anvin1965aae2008-10-22 22:26:29 -07001#ifndef _ASM_X86_SPARSEMEM_H
2#define _ASM_X86_SPARSEMEM_H
Thomas Gleixner8a423ff2008-01-30 13:30:37 +01003
4#ifdef CONFIG_SPARSEMEM
5/*
6 * generic non-linear memory support:
7 *
8 * 1) we will not split memory into more chunks than will fit into the flags
9 * field of the struct page
10 *
11 * SECTION_SIZE_BITS 2^n: size of each section
12 * MAX_PHYSADDR_BITS 2^n: max size of physical address space
13 * MAX_PHYSMEM_BITS 2^n: how much memory we can have in that space
14 *
15 */
16
Thomas Gleixner96a388d2007-10-11 11:20:03 +020017#ifdef CONFIG_X86_32
Thomas Gleixner8a423ff2008-01-30 13:30:37 +010018# ifdef CONFIG_X86_PAE
Jeremy Fitzhardingefb8e8372008-03-27 17:28:39 -070019# define SECTION_SIZE_BITS 29
Thomas Gleixner8a423ff2008-01-30 13:30:37 +010020# define MAX_PHYSADDR_BITS 36
21# define MAX_PHYSMEM_BITS 36
22# else
23# define SECTION_SIZE_BITS 26
24# define MAX_PHYSADDR_BITS 32
25# define MAX_PHYSMEM_BITS 32
26# endif
27#else /* CONFIG_X86_32 */
28# define SECTION_SIZE_BITS 27 /* matt - 128 is convenient right now */
Kirill A. Shutemov4c7c4482017-03-30 11:07:27 +030029# ifdef CONFIG_X86_5LEVEL
30# define MAX_PHYSADDR_BITS 52
31# define MAX_PHYSMEM_BITS 52
32# else
33# define MAX_PHYSADDR_BITS 44
34# define MAX_PHYSMEM_BITS 46
35# endif
Thomas Gleixner8a423ff2008-01-30 13:30:37 +010036#endif
37
38#endif /* CONFIG_SPARSEMEM */
H. Peter Anvin1965aae2008-10-22 22:26:29 -070039#endif /* _ASM_X86_SPARSEMEM_H */