Linux Audio

Check our new training course

Loading...
v4.17
 1/* SPDX-License-Identifier: GPL-2.0 */
 2#ifndef _ASM_X86_BOOT_H
 3#define _ASM_X86_BOOT_H
 4
 5
 6#include <asm/pgtable_types.h>
 7#include <uapi/asm/boot.h>
 8
 9/* Physical address where kernel should be loaded. */
10#define LOAD_PHYSICAL_ADDR ((CONFIG_PHYSICAL_START \
11				+ (CONFIG_PHYSICAL_ALIGN - 1)) \
12				& ~(CONFIG_PHYSICAL_ALIGN - 1))
13
14/* Minimum kernel alignment, as a power of two */
15#ifdef CONFIG_X86_64
16# define MIN_KERNEL_ALIGN_LG2	PMD_SHIFT
17#else
18# define MIN_KERNEL_ALIGN_LG2	(PAGE_SHIFT + THREAD_SIZE_ORDER)
19#endif
20#define MIN_KERNEL_ALIGN	(_AC(1, UL) << MIN_KERNEL_ALIGN_LG2)
21
22#if (CONFIG_PHYSICAL_ALIGN & (CONFIG_PHYSICAL_ALIGN-1)) || \
23	(CONFIG_PHYSICAL_ALIGN < MIN_KERNEL_ALIGN)
24# error "Invalid value for CONFIG_PHYSICAL_ALIGN"
25#endif
26
27#ifdef CONFIG_KERNEL_BZIP2
28# define BOOT_HEAP_SIZE		0x400000
29#else /* !CONFIG_KERNEL_BZIP2 */
 
 
 
 
 
 
 
30# define BOOT_HEAP_SIZE		 0x10000
31#endif
32
33#ifdef CONFIG_X86_64
34# define BOOT_STACK_SIZE	0x4000
35
36# define BOOT_INIT_PGT_SIZE	(6*4096)
37# ifdef CONFIG_RANDOMIZE_BASE
38/*
39 * Assuming all cross the 512GB boundary:
40 * 1 page for level4
41 * (2+2)*4 pages for kernel, param, cmd_line, and randomized kernel
42 * 2 pages for first 2M (video RAM: CONFIG_X86_VERBOSE_BOOTUP).
43 * Total is 19 pages.
44 */
45#  ifdef CONFIG_X86_VERBOSE_BOOTUP
46#   define BOOT_PGT_SIZE	(19*4096)
47#  else /* !CONFIG_X86_VERBOSE_BOOTUP */
48#   define BOOT_PGT_SIZE	(17*4096)
49#  endif
50# else /* !CONFIG_RANDOMIZE_BASE */
51#  define BOOT_PGT_SIZE		BOOT_INIT_PGT_SIZE
52# endif
53
54#else /* !CONFIG_X86_64 */
55# define BOOT_STACK_SIZE	0x1000
56#endif
57
58#endif /* _ASM_X86_BOOT_H */
v6.2
 1/* SPDX-License-Identifier: GPL-2.0 */
 2#ifndef _ASM_X86_BOOT_H
 3#define _ASM_X86_BOOT_H
 4
 5
 6#include <asm/pgtable_types.h>
 7#include <uapi/asm/boot.h>
 8
 9/* Physical address where kernel should be loaded. */
10#define LOAD_PHYSICAL_ADDR ((CONFIG_PHYSICAL_START \
11				+ (CONFIG_PHYSICAL_ALIGN - 1)) \
12				& ~(CONFIG_PHYSICAL_ALIGN - 1))
13
14/* Minimum kernel alignment, as a power of two */
15#ifdef CONFIG_X86_64
16# define MIN_KERNEL_ALIGN_LG2	PMD_SHIFT
17#else
18# define MIN_KERNEL_ALIGN_LG2	(PAGE_SHIFT + THREAD_SIZE_ORDER)
19#endif
20#define MIN_KERNEL_ALIGN	(_AC(1, UL) << MIN_KERNEL_ALIGN_LG2)
21
22#if (CONFIG_PHYSICAL_ALIGN & (CONFIG_PHYSICAL_ALIGN-1)) || \
23	(CONFIG_PHYSICAL_ALIGN < MIN_KERNEL_ALIGN)
24# error "Invalid value for CONFIG_PHYSICAL_ALIGN"
25#endif
26
27#if defined(CONFIG_KERNEL_BZIP2)
28# define BOOT_HEAP_SIZE		0x400000
29#elif defined(CONFIG_KERNEL_ZSTD)
30/*
31 * Zstd needs to allocate the ZSTD_DCtx in order to decompress the kernel.
32 * The ZSTD_DCtx is ~160KB, so set the heap size to 192KB because it is a
33 * round number and to allow some slack.
34 */
35# define BOOT_HEAP_SIZE		 0x30000
36#else
37# define BOOT_HEAP_SIZE		 0x10000
38#endif
39
40#ifdef CONFIG_X86_64
41# define BOOT_STACK_SIZE	0x4000
42
43# define BOOT_INIT_PGT_SIZE	(6*4096)
44# ifdef CONFIG_RANDOMIZE_BASE
45/*
46 * Assuming all cross the 512GB boundary:
47 * 1 page for level4
48 * (2+2)*4 pages for kernel, param, cmd_line, and randomized kernel
49 * 2 pages for first 2M (video RAM: CONFIG_X86_VERBOSE_BOOTUP).
50 * Total is 19 pages.
51 */
52#  ifdef CONFIG_X86_VERBOSE_BOOTUP
53#   define BOOT_PGT_SIZE	(19*4096)
54#  else /* !CONFIG_X86_VERBOSE_BOOTUP */
55#   define BOOT_PGT_SIZE	(17*4096)
56#  endif
57# else /* !CONFIG_RANDOMIZE_BASE */
58#  define BOOT_PGT_SIZE		BOOT_INIT_PGT_SIZE
59# endif
60
61#else /* !CONFIG_X86_64 */
62# define BOOT_STACK_SIZE	0x1000
63#endif
64
65#endif /* _ASM_X86_BOOT_H */