blob: 8f09518d4cfce259a81927dd9f11b7595ea63837 [file] [log] [blame]
b.liue9582032025-04-17 19:18:16 +08001# SPDX-License-Identifier: GPL-2.0-only
2#
3# Copyright (C) 2006-2020 OpenWrt.org
4
5ifdef CONFIG_STRIP_KERNEL_EXPORTS
6 KERNEL_MAKEOPTS_IMAGE += \
7 EXTRA_LDSFLAGS="-I$(KERNEL_BUILD_DIR) -include symtab.h"
8endif
9
10INITRAMFS_EXTRA_FILES ?= $(GENERIC_PLATFORM_DIR)/image/initramfs-base-files.txt
11
12export HOST_EXTRACFLAGS=-I$(STAGING_DIR_HOST)/include
13
14# defined in quilt.mk
15Kernel/Patch:=$(Kernel/Patch/Default)
16
17ifneq (,$(findstring .xz,$(LINUX_SOURCE)))
18 LINUX_CAT:=xzcat
19else
20 LINUX_CAT:=$(STAGING_DIR_HOST)/bin/libdeflate-gzip -dc
21endif
22
23ifeq ($(strip $(CONFIG_EXTERNAL_KERNEL_TREE)),"")
24 ifeq ($(strip $(CONFIG_KERNEL_GIT_CLONE_URI)),"")
25 define Kernel/Prepare/Default
26 $(LINUX_CAT) $(DL_DIR)/$(LINUX_SOURCE) | $(TAR) -C $(KERNEL_BUILD_DIR) $(TAR_OPTIONS)
27 $(Kernel/Patch)
28 $(if $(QUILT),touch $(LINUX_DIR)/.quilt_used)
29 endef
30 else
31 define Kernel/Prepare/Default
32 $(LINUX_CAT) $(DL_DIR)/$(LINUX_SOURCE) | $(TAR) -C $(KERNEL_BUILD_DIR) $(TAR_OPTIONS)
33 endef
34 endif
35else
36 define Kernel/Prepare/Default
37 mkdir -p $(KERNEL_BUILD_DIR)
38 if [ -d $(LINUX_DIR) ]; then \
39 rmdir $(LINUX_DIR); \
40 fi
41 ifeq ($(wildcard $(PATCH_DIR)),)
42 ln -s $(CONFIG_EXTERNAL_KERNEL_TREE) $(LINUX_DIR)
43 else
44 cp -a $(CONFIG_EXTERNAL_KERNEL_TREE) $(LINUX_DIR)
45 $(if $(QUILT),rm -rf $(LINUX_DIR)/patches; mkdir -p $(LINUX_DIR)/patches)
46 find $(LINUX_DIR)/ -name \*.rej -or -name \*.orig | $(XARGS) rm -f
47 $(call PatchDir,$(LINUX_DIR),$(PATCH_DIR),)
48 $(if $(QUILT),touch $(LINUX_DIR)/.quilt_used)
49 endif
50 if [ -d $(LINUX_DIR)/user_headers ]; then \
51 rm -rf $(LINUX_DIR)/user_headers; \
52 fi
53 endef
54endif
55
56ifeq ($(CONFIG_TARGET_ROOTFS_INITRAMFS),y)
57 ifeq ($(CONFIG_SECURE_IMA),y)
58 define Kernel/SetInitramfs/PreConfigure
59 grep -v INITRAMFS $(2)/.config.old > $(2)/.config
60 echo 'CONFIG_INITRAMFS_SOURCE="../../target/linux/mmp/files/initramfs"' >> $(2)/.config
61 endef
62 else
63 ifeq ($(CONFIG_TARGET_ROOTFS_INITRAMFS_SEPARATE),y)
64 define Kernel/SetInitramfs/PreConfigure
65 { \
66 grep -v -e CONFIG_BLK_DEV_INITRD $(2)/.config.old > $(2)/.config; \
67 echo 'CONFIG_BLK_DEV_INITRD=y' >> $(2)/.config; \
68 echo 'CONFIG_INITRAMFS_SOURCE=""' >> $(2)/.config; \
69 }
70 endef
71 else
72 ifeq ($(strip $(CONFIG_EXTERNAL_CPIO)),"")
73 define Kernel/SetInitramfs/PreConfigure
74 { \
75 grep -v -e INITRAMFS -e CONFIG_RD_ -e CONFIG_BLK_DEV_INITRD $(2)/.config.old > $(2)/.config; \
76 echo 'CONFIG_BLK_DEV_INITRD=y' >> $(2)/.config; \
77 echo 'CONFIG_INITRAMFS_SOURCE="$(strip $(1) $(INITRAMFS_EXTRA_FILES))"' >> $(2)/.config; \
78 }
79 endef
80 else
81 define Kernel/SetInitramfs/PreConfigure
82 { \
83 grep -v INITRAMFS $(2)/.config.old > $(2)/.config; \
84 echo 'CONFIG_INITRAMFS_SOURCE="$(call qstrip,$(CONFIG_EXTERNAL_CPIO))"' >> $(2)/.config; \
85 }
86 endef
87 endif
88 endif
89 endif
90
91 define Kernel/SetInitramfs
92 { \
93 rm -f $(2)/.config.prev; \
94 mv $(2)/.config $(2)/.config.old; \
95 $(call Kernel/SetInitramfs/PreConfigure,$(1),$(2)); \
96 echo "# CONFIG_INITRAMFS_PRESERVE_MTIME is not set" >> $(2)/.config; \
97 $(if $(CONFIG_TARGET_ROOTFS_INITRAMFS_SEPARATE),,echo "CONFIG_INITRAMFS_ROOT_UID=$(shell id -u)" >> $(2)/.config;) \
98 $(if $(CONFIG_TARGET_ROOTFS_INITRAMFS_SEPARATE),,echo "CONFIG_INITRAMFS_ROOT_GID=$(shell id -g)" >> $(2)/.config;) \
99 $(if $(CONFIG_TARGET_ROOTFS_INITRAMFS_SEPARATE), \
100 echo "# CONFIG_INITRAMFS_FORCE is not set" >> $(2)/.config;, \
101 $(if $(CONFIG_TARGET_INITRAMFS_FORCE), \
102 echo "CONFIG_INITRAMFS_FORCE=y" >> $(2)/.config;, \
103 echo "# CONFIG_INITRAMFS_FORCE is not set" >> $(2)/.config;)) \
104 $(if $(CONFIG_TARGET_INITRAMFS_COMPRESSION_NONE), \
105 echo "CONFIG_INITRAMFS_COMPRESSION_NONE=y" >> $(2)/.config;, \
106 echo "# CONFIG_INITRAMFS_COMPRESSION_NONE is not set" >> $(2)/.config; ) \
107 $(foreach ALGO,GZIP BZIP2 LZMA LZO XZ LZ4 ZSTD, \
108 $(if $(CONFIG_TARGET_INITRAMFS_COMPRESSION_$(ALGO)), \
109 echo "CONFIG_INITRAMFS_COMPRESSION_$(ALGO)=y" >> $(2)/.config; $\, \
110 echo "# CONFIG_INITRAMFS_COMPRESSION_$(ALGO) is not set" >> $(2)/.config; $\) \
111 $(if $(CONFIG_TARGET_INITRAMFS_COMPRESSION_$(ALGO)), \
112 echo "CONFIG_RD_$(ALGO)=y" >> $(2)/.config; $\, \
113 echo "# CONFIG_RD_$(ALGO) is not set" >> $(2)/.config; $\) \
114 ) \
115 }
116 endef
117else
118endif
119
120define Kernel/SetNoInitramfs
121 mv $(LINUX_DIR)/.config.set $(LINUX_DIR)/.config.old
122 grep -v INITRAMFS $(LINUX_DIR)/.config.old > $(LINUX_DIR)/.config.set
123 echo 'CONFIG_INITRAMFS_SOURCE=""' >> $(LINUX_DIR)/.config.set
124 echo '# CONFIG_INITRAMFS_FORCE is not set' >> $(LINUX_DIR)/.config.set
125 echo "# CONFIG_INITRAMFS_PRESERVE_MTIME is not set" >> $(LINUX_DIR)/.config.set
126endef
127
128define Kernel/Configure/Default
129 rm -f $(LINUX_DIR)/localversion
130 $(LINUX_CONF_CMD) > $(LINUX_DIR)/.config.target
131# copy CONFIG_KERNEL_* settings over to .config.target
132 awk '/^(#[[:space:]]+)?CONFIG_KERNEL/{sub("CONFIG_KERNEL_","CONFIG_");print}' $(TOPDIR)/.config >> $(LINUX_DIR)/.config.target
133 echo "# CONFIG_KALLSYMS_EXTRA_PASS is not set" >> $(LINUX_DIR)/.config.target
134 echo "# CONFIG_KALLSYMS_ALL is not set" >> $(LINUX_DIR)/.config.target
135 echo "CONFIG_KALLSYMS_UNCOMPRESSED=y" >> $(LINUX_DIR)/.config.target
136 $(SCRIPT_DIR)/package-metadata.pl kconfig $(TMP_DIR)/.packageinfo $(TOPDIR)/.config $(KERNEL_PATCHVER) > $(LINUX_DIR)/.config.override
137 $(SCRIPT_DIR)/kconfig.pl 'm+' '+' $(LINUX_DIR)/.config.target /dev/null $(LINUX_DIR)/.config.override > $(LINUX_DIR)/.config.set
138 $(call Kernel/SetNoInitramfs)
139 rm -rf $(KERNEL_BUILD_DIR)/modules
140 cmp -s $(LINUX_DIR)/.config.set $(LINUX_DIR)/.config.prev || { \
141 cp $(LINUX_DIR)/.config.set $(LINUX_DIR)/.config; \
142 cp $(LINUX_DIR)/.config.set $(LINUX_DIR)/.config.prev; \
143 }
144 $(_SINGLE) [ -d $(LINUX_DIR)/user_headers ] || $(KERNEL_MAKE) $(if $(findstring uml,$(BOARD)),ARCH=$(ARCH)) INSTALL_HDR_PATH=$(LINUX_DIR)/user_headers headers_install
145 grep '=[ym]' $(LINUX_DIR)/.config.set | LC_ALL=C sort | $(MKHASH) md5 > $(LINUX_DIR)/.vermagic
146endef
147
148define Kernel/Configure/Initramfs
149 $(call Kernel/SetInitramfs,$(1),$(2))
150endef
151
152define Kernel/CompileModules/Default
153 rm -f $(LINUX_DIR)/vmlinux $(LINUX_DIR)/System.map
154 +$(KERNEL_MAKE) $(if $(KERNELNAME),$(KERNELNAME),all) modules
155 # If .config did not change, use the previous timestamp to avoid package rebuilds
156 cmp -s $(LINUX_DIR)/.config $(LINUX_DIR)/.config.modules.save && \
157 mv $(LINUX_DIR)/.config.modules.save $(LINUX_DIR)/.config; \
158 $(CP) $(LINUX_DIR)/.config $(LINUX_DIR)/.config.modules.save
159endef
160
161OBJCOPY_STRIP = -R .reginfo -R .notes -R .note -R .comment -R .mdebug -R .note.gnu.build-id
162
163# AMD64 shares the location with x86
164ifeq ($(LINUX_KARCH),x86_64)
165IMAGES_DIR:=../../x86/boot
166endif
167
168# $1: image suffix
169# $2: Per Device Rootfs ID
170define Kernel/CopyImage
171 cmp -s $(LINUX_DIR)$(2)/vmlinux $(KERNEL_BUILD_DIR)/vmlinux$(1).debug$(2) || { \
172 $(KERNEL_CROSS)objcopy -O binary $(OBJCOPY_STRIP) -S $(LINUX_DIR)$(2)/vmlinux $(LINUX_KERNEL)$(1)$(2); \
173 $(KERNEL_CROSS)objcopy $(OBJCOPY_STRIP) -S $(LINUX_DIR)$(2)/vmlinux $(KERNEL_BUILD_DIR)/vmlinux$(1).elf$(2); \
174 $(CP) $(LINUX_DIR)$(2)/vmlinux $(KERNEL_BUILD_DIR)/vmlinux$(1).debug$(2); \
175 $(foreach k, \
176 $(if $(KERNEL_IMAGES),$(KERNEL_IMAGES),$(filter-out vmlinux dtbs,$(KERNELNAME))), \
177 $(CP) $(LINUX_DIR)$(2)/arch/$(LINUX_KARCH)/boot/$(IMAGES_DIR)/$(k) $(KERNEL_BUILD_DIR)/$(k)$(1)$(2); \
178 ) \
179 }
180endef
181
182define Kernel/CompileImage/Default
183 rm -f $(TARGET_DIR)/init
184 +$(KERNEL_MAKE) $(KERNEL_MAKEOPTS_IMAGE) $(if $(KERNELNAME),$(KERNELNAME),all)
185 $(call Kernel/CopyImage)
186endef
187
188define Kernel/PrepareConfigPerRootfs
189 { \
190 [ ! -d "$(1)" ] || rm -rf $(1); \
191 mkdir $(1) && $(CP) -T $(LINUX_DIR) $(1); \
192 touch $(1)/.config; \
193 }
194endef
195
196ifneq ($(CONFIG_TARGET_ROOTFS_INITRAMFS),)
197# $1: Custom TARGET_DIR. If omitted TARGET_DIR is used.
198# $2: If defined Generate Per Rootfs Kernel Directory and use it
199# For Separate Initramf with $2 declared, skip kernel compile, it has
200# already been done previously on generic image build
201define Kernel/CompileImage/Initramfs
202 $(call locked,{ \
203 $(if $(2),$(call Kernel/PrepareConfigPerRootfs,$(LINUX_DIR)$(2));) \
204 $(call Kernel/Configure/Initramfs,$(if $(1),$(1),$(TARGET_DIR)),$(LINUX_DIR)$(2)); \
205 $(CP) $(GENERIC_PLATFORM_DIR)/other-files/init $(if $(1),$(1),$(TARGET_DIR))/init; \
206 $(if $(SOURCE_DATE_EPOCH),touch -hcd "@$(SOURCE_DATE_EPOCH)" $(if $(1),$(1),$(TARGET_DIR)) $(if $(1),$(1),$(TARGET_DIR))/init;) \
207 rm -rf $(LINUX_DIR)$(2)/usr/initramfs_data.cpio*; \
208 $(if $(CONFIG_TARGET_ROOTFS_INITRAMFS_SEPARATE), \
209 $(call locked,{ \
210 $(if $(call qstrip,$(CONFIG_EXTERNAL_CPIO)), \
211 $(CP) $(CONFIG_EXTERNAL_CPIO) $(KERNEL_BUILD_DIR)/initrd$(2).cpio;,\
212 ( cd $(if $(1),$(1),$(TARGET_DIR)); find . | LC_ALL=C sort | $(STAGING_DIR_HOST)/bin/cpio --reproducible -o -H newc -R 0:0 > $(KERNEL_BUILD_DIR)/initrd$(2).cpio );) \
213 $(if $(SOURCE_DATE_EPOCH), \
214 touch -hcd "@$(SOURCE_DATE_EPOCH)" $(KERNEL_BUILD_DIR)/initrd$(2).cpio;) \
215 $(if $(CONFIG_TARGET_INITRAMFS_COMPRESSION_BZIP2), \
216 $(STAGING_DIR_HOST)/bin/bzip2 -9 -c < $(KERNEL_BUILD_DIR)/initrd$(2).cpio > $(KERNEL_BUILD_DIR)/initrd$(2).cpio.bzip2;) \
217 $(if $(CONFIG_TARGET_INITRAMFS_COMPRESSION_GZIP), \
218 $(STAGING_DIR_HOST)/bin/libdeflate-gzip -n -f -S .gzip -12 $(KERNEL_BUILD_DIR)/initrd$(2).cpio;) \
219 $(if $(CONFIG_TARGET_INITRAMFS_COMPRESSION_LZ4), \
220 $(STAGING_DIR_HOST)/bin/lz4c -l -c1 -fz --favor-decSpeed $(KERNEL_BUILD_DIR)/initrd$(2).cpio;) \
221 $(if $(CONFIG_TARGET_INITRAMFS_COMPRESSION_LZMA), \
222 $(STAGING_DIR_HOST)/bin/lzma e -lc1 -lp2 -pb2 $(KERNEL_BUILD_DIR)/initrd$(2).cpio $(KERNEL_BUILD_DIR)/initrd$(2).cpio.lzma;) \
223 $(if $(CONFIG_TARGET_INITRAMFS_COMPRESSION_LZO), \
224 $(STAGING_DIR_HOST)/bin/lzop -9 -f $(KERNEL_BUILD_DIR)/initrd$(2).cpio;) \
225 $(if $(CONFIG_TARGET_INITRAMFS_COMPRESSION_XZ), \
226 $(STAGING_DIR_HOST)/bin/xz -T$(if $(filter 1,$(NPROC)),2,0) -9 -fz --check=crc32 $(KERNEL_BUILD_DIR)/initrd$(2).cpio;) \
227 $(if $(CONFIG_TARGET_INITRAMFS_COMPRESSION_ZSTD), \
228 $(STAGING_DIR_HOST)/bin/zstd -T0 -f -o $(KERNEL_BUILD_DIR)/initrd$(2).cpio.zstd $(KERNEL_BUILD_DIR)/initrd$(2).cpio;) \
229 }, gen-cpio$(2)); \
230 $(if $(2),,$(KERNEL_MAKE) $(KERNEL_MAKEOPTS_IMAGE) $(if $(KERNELNAME),$(KERNELNAME),all);),\
231 $(KERNEL_MAKE) $(if $(2),-C $(LINUX_DIR)$(2)) $(KERNEL_MAKEOPTS_IMAGE) $(if $(KERNELNAME),$(KERNELNAME),all);) \
232 $(call Kernel/CopyImage,-initramfs,$(2)); \
233 $(if $(2),rm -rf $(LINUX_DIR)$(2);) \
234 }, gen-initramfs$(2));
235endef
236else
237define Kernel/CompileImage/Initramfs
238endef
239endif
240
241define Kernel/Clean/Default
242 rm -f $(KERNEL_BUILD_DIR)/linux-$(LINUX_VERSION)/.configured
243 rm -f $(LINUX_KERNEL)
244 $(_SINGLE)$(MAKE) -C $(KERNEL_BUILD_DIR)/linux-$(LINUX_VERSION) clean
245endef