Loading...
1#
2# kbuild file for usr - including initramfs image
3#
4
5klibcdirs:;
6PHONY += klibcdirs
7
8
9# Bzip2
10suffix_$(CONFIG_RD_BZIP2) = .bz2
11
12# Lzma
13suffix_$(CONFIG_RD_LZMA) = .lzma
14
15# XZ
16suffix_$(CONFIG_RD_XZ) = .xz
17
18# Lzo
19suffix_$(CONFIG_RD_LZO) = .lzo
20
21# Lz4
22suffix_$(CONFIG_RD_LZ4) = .lz4
23
24# Gzip
25suffix_$(CONFIG_RD_GZIP) = .gz
26
27AFLAGS_initramfs_data.o += -DINITRAMFS_IMAGE="usr/initramfs_data.cpio$(suffix_y)"
28
29# Generate builtin.o based on initramfs_data.o
30obj-$(CONFIG_BLK_DEV_INITRD) := initramfs_data.o
31
32# initramfs_data.o contains the compressed initramfs_data.cpio image.
33# The image is included using .incbin, a dependency which is not
34# tracked automatically.
35$(obj)/initramfs_data.o: $(obj)/initramfs_data.cpio$(suffix_y) FORCE
36
37#####
38# Generate the initramfs cpio archive
39
40hostprogs-y := gen_init_cpio
41initramfs := $(CONFIG_SHELL) $(srctree)/scripts/gen_initramfs_list.sh
42ramfs-input := $(if $(filter-out "",$(CONFIG_INITRAMFS_SOURCE)), \
43 $(shell echo $(CONFIG_INITRAMFS_SOURCE)),-d)
44ramfs-args := \
45 $(if $(CONFIG_INITRAMFS_ROOT_UID), -u $(CONFIG_INITRAMFS_ROOT_UID)) \
46 $(if $(CONFIG_INITRAMFS_ROOT_GID), -g $(CONFIG_INITRAMFS_ROOT_GID))
47
48# .initramfs_data.cpio.d is used to identify all files included
49# in initramfs and to detect if any files are added/removed.
50# Removed files are identified by directory timestamp being updated
51# The dependency list is generated by gen_initramfs.sh -l
52ifneq ($(wildcard $(obj)/.initramfs_data.cpio.d),)
53 include $(obj)/.initramfs_data.cpio.d
54endif
55
56quiet_cmd_initfs = GEN $@
57 cmd_initfs = $(initramfs) -o $@ $(ramfs-args) $(ramfs-input)
58
59targets := initramfs_data.cpio.gz initramfs_data.cpio.bz2 \
60 initramfs_data.cpio.lzma initramfs_data.cpio.xz \
61 initramfs_data.cpio.lzo initramfs_data.cpio.lz4 \
62 initramfs_data.cpio
63# do not try to update files included in initramfs
64$(deps_initramfs): ;
65
66$(deps_initramfs): klibcdirs
67# We rebuild initramfs_data.cpio if:
68# 1) Any included file is newer then initramfs_data.cpio
69# 2) There are changes in which files are included (added or deleted)
70# 3) If gen_init_cpio are newer than initramfs_data.cpio
71# 4) arguments to gen_initramfs.sh changes
72$(obj)/initramfs_data.cpio$(suffix_y): $(obj)/gen_init_cpio $(deps_initramfs) klibcdirs
73 $(Q)$(initramfs) -l $(ramfs-input) > $(obj)/.initramfs_data.cpio.d
74 $(call if_changed,initfs)
1# SPDX-License-Identifier: GPL-2.0
2#
3# kbuild file for usr - including initramfs image
4#
5
6compress-y := copy
7compress-$(CONFIG_INITRAMFS_COMPRESSION_GZIP) := gzip
8compress-$(CONFIG_INITRAMFS_COMPRESSION_BZIP2) := bzip2
9compress-$(CONFIG_INITRAMFS_COMPRESSION_LZMA) := lzma
10compress-$(CONFIG_INITRAMFS_COMPRESSION_XZ) := xzmisc
11compress-$(CONFIG_INITRAMFS_COMPRESSION_LZO) := lzo
12compress-$(CONFIG_INITRAMFS_COMPRESSION_LZ4) := lz4
13compress-$(CONFIG_INITRAMFS_COMPRESSION_ZSTD) := zstd
14
15obj-$(CONFIG_BLK_DEV_INITRD) := initramfs_data.o
16
17$(obj)/initramfs_data.o: $(obj)/initramfs_inc_data
18
19ramfs-input := $(CONFIG_INITRAMFS_SOURCE)
20cpio-data :=
21
22# If CONFIG_INITRAMFS_SOURCE is empty, generate a small initramfs with the
23# default contents.
24ifeq ($(ramfs-input),)
25ramfs-input := $(srctree)/$(src)/default_cpio_list
26endif
27
28ifeq ($(words $(ramfs-input)),1)
29
30# If CONFIG_INITRAMFS_SOURCE specifies a single file, and it is suffixed with
31# .cpio, use it directly as an initramfs.
32ifneq ($(filter %.cpio,$(ramfs-input)),)
33cpio-data := $(ramfs-input)
34endif
35
36# If CONFIG_INITRAMFS_SOURCE specifies a single file, and it is suffixed with
37# .cpio.*, use it directly as an initramfs, and avoid double compression.
38ifeq ($(words $(subst .cpio.,$(space),$(ramfs-input))),2)
39cpio-data := $(ramfs-input)
40compress-y := copy
41endif
42
43endif
44
45# For other cases, generate the initramfs cpio archive based on the contents
46# specified by CONFIG_INITRAMFS_SOURCE.
47ifeq ($(cpio-data),)
48
49cpio-data := $(obj)/initramfs_data.cpio
50
51hostprogs := gen_init_cpio
52
53# .initramfs_data.cpio.d is used to identify all files included
54# in initramfs and to detect if any files are added/removed.
55# Removed files are identified by directory timestamp being updated
56# The dependency list is generated by gen_initramfs.sh -l
57-include $(obj)/.initramfs_data.cpio.d
58
59# do not try to update files included in initramfs
60$(deps_initramfs): ;
61
62quiet_cmd_initfs = GEN $@
63 cmd_initfs = \
64 $(CONFIG_SHELL) $< -o $@ -l $(obj)/.initramfs_data.cpio.d \
65 $(if $(CONFIG_INITRAMFS_ROOT_UID), -u $(CONFIG_INITRAMFS_ROOT_UID)) \
66 $(if $(CONFIG_INITRAMFS_ROOT_GID), -g $(CONFIG_INITRAMFS_ROOT_GID)) \
67 $(ramfs-input)
68
69# We rebuild initramfs_data.cpio if:
70# 1) Any included file is newer than initramfs_data.cpio
71# 2) There are changes in which files are included (added or deleted)
72# 3) If gen_init_cpio are newer than initramfs_data.cpio
73# 4) Arguments to gen_initramfs.sh changes
74$(obj)/initramfs_data.cpio: $(src)/gen_initramfs.sh $(obj)/gen_init_cpio $(deps_initramfs) FORCE
75 $(call if_changed,initfs)
76
77endif
78
79$(obj)/initramfs_inc_data: $(cpio-data) FORCE
80 $(call if_changed,$(compress-y))
81
82targets += initramfs_data.cpio initramfs_inc_data
83
84subdir-$(CONFIG_UAPI_HEADER_TEST) += include