xref: /linux/arch/x86/include/asm/crash_reserve.h (revision eb01fe7abbe2d0b38824d2a93fdb4cc3eaf2ccc1)
1 /* SPDX-License-Identifier: GPL-2.0 */
2 #ifndef _X86_CRASH_RESERVE_H
3 #define _X86_CRASH_RESERVE_H
4 
5 /* 16M alignment for crash kernel regions */
6 #define CRASH_ALIGN             SZ_16M
7 
8 /*
9  * Keep the crash kernel below this limit.
10  *
11  * Earlier 32-bits kernels would limit the kernel to the low 512 MB range
12  * due to mapping restrictions.
13  *
14  * 64-bit kdump kernels need to be restricted to be under 64 TB, which is
15  * the upper limit of system RAM in 4-level paging mode. Since the kdump
16  * jump could be from 5-level paging to 4-level paging, the jump will fail if
17  * the kernel is put above 64 TB, and during the 1st kernel bootup there's
18  * no good way to detect the paging mode of the target kernel which will be
19  * loaded for dumping.
20  */
21 extern unsigned long swiotlb_size_or_default(void);
22 
23 #ifdef CONFIG_X86_32
24 # define CRASH_ADDR_LOW_MAX     SZ_512M
25 # define CRASH_ADDR_HIGH_MAX    SZ_512M
26 #else
27 # define CRASH_ADDR_LOW_MAX     SZ_4G
28 # define CRASH_ADDR_HIGH_MAX    SZ_64T
29 #endif
30 
31 # define DEFAULT_CRASH_KERNEL_LOW_SIZE crash_low_size_default()
32 
33 static inline unsigned long crash_low_size_default(void)
34 {
35 #ifdef CONFIG_X86_64
36 	return max(swiotlb_size_or_default() + (8UL << 20), 256UL << 20);
37 #else
38 	return 0;
39 #endif
40 }
41 
42 #endif /* _X86_CRASH_RESERVE_H */
43