|  | /* SPDX-License-Identifier: GPL-2.0 */ | 
|  | #ifndef _ASM_X86_SPARSEMEM_H | 
|  | #define _ASM_X86_SPARSEMEM_H | 
|  |  | 
|  | #ifdef CONFIG_SPARSEMEM | 
|  | /* | 
|  | * generic non-linear memory support: | 
|  | * | 
|  | * 1) we will not split memory into more chunks than will fit into the flags | 
|  | *    field of the struct page | 
|  | * | 
|  | * SECTION_SIZE_BITS		2^n: size of each section | 
|  | * MAX_PHYSMEM_BITS		2^n: max size of physical address space | 
|  | * | 
|  | */ | 
|  |  | 
|  | #ifdef CONFIG_X86_32 | 
|  | # ifdef CONFIG_X86_PAE | 
|  | #  define SECTION_SIZE_BITS	29 | 
|  | #  define MAX_PHYSMEM_BITS	36 | 
|  | # else | 
|  | #  define SECTION_SIZE_BITS	26 | 
|  | #  define MAX_PHYSMEM_BITS	32 | 
|  | # endif | 
|  | #else /* CONFIG_X86_32 */ | 
|  | # define SECTION_SIZE_BITS	27 /* matt - 128 is convenient right now */ | 
|  | # define MAX_PHYSMEM_BITS	(pgtable_l5_enabled() ? 52 : 46) | 
|  | #endif | 
|  |  | 
|  | #endif /* CONFIG_SPARSEMEM */ | 
|  |  | 
|  | #ifndef __ASSEMBLY__ | 
|  | #ifdef CONFIG_NUMA_KEEP_MEMINFO | 
|  | extern int phys_to_target_node(phys_addr_t start); | 
|  | #define phys_to_target_node phys_to_target_node | 
|  | extern int memory_add_physaddr_to_nid(u64 start); | 
|  | #define memory_add_physaddr_to_nid memory_add_physaddr_to_nid | 
|  | #endif | 
|  | #endif /* __ASSEMBLY__ */ | 
|  |  | 
|  | #endif /* _ASM_X86_SPARSEMEM_H */ |