2 # kbuild file for usr/ - including initramfs image
8 suffix_y
= $(subst $\",,$(CONFIG_INITRAMFS_COMPRESSION
))
9 datafile_y
= initramfs_data.cpio
$(suffix_y
)
10 AFLAGS_initramfs_data.o
+= -DINITRAMFS_IMAGE
="usr/$(datafile_y)"
13 # Generate builtin.o based on initramfs_data.o
14 obj-
$(CONFIG_BLK_DEV_INITRD
) := initramfs_data.o
16 # initramfs_data.o contains the compressed initramfs_data.cpio image.
17 # The image is included using .incbin, a dependency which is not
18 # tracked automatically.
19 $(obj
)/initramfs_data.o
: $(obj
)/$(datafile_y
) FORCE
22 # Generate the initramfs cpio archive
24 hostprogs-y
:= gen_init_cpio
25 initramfs
:= $(CONFIG_SHELL
) $(srctree
)/scripts
/gen_initramfs_list.sh
26 ramfs-input
:= $(if
$(filter-out "",$(CONFIG_INITRAMFS_SOURCE
)), \
27 $(shell echo
$(CONFIG_INITRAMFS_SOURCE
)),-d
)
29 $(if
$(CONFIG_INITRAMFS_ROOT_UID
), -u
$(CONFIG_INITRAMFS_ROOT_UID
)) \
30 $(if
$(CONFIG_INITRAMFS_ROOT_GID
), -g
$(CONFIG_INITRAMFS_ROOT_GID
))
32 # .initramfs_data.cpio.d is used to identify all files included
33 # in initramfs and to detect if any files are added/removed.
34 # Removed files are identified by directory timestamp being updated
35 # The dependency list is generated by gen_initramfs.sh -l
36 ifneq ($(wildcard $(obj
)/.initramfs_data.cpio.d
),)
37 include $(obj
)/.initramfs_data.cpio.d
40 quiet_cmd_initfs
= GEN
$@
41 cmd_initfs
= $(initramfs
) -o
$@
$(ramfs-args
) $(ramfs-input
)
43 targets
:= $(datafile_y
)
45 # do not try to update files included in initramfs
48 $(deps_initramfs
): klibcdirs
49 # We rebuild initramfs_data.cpio if:
50 # 1) Any included file is newer then initramfs_data.cpio
51 # 2) There are changes in which files are included (added or deleted)
52 # 3) If gen_init_cpio are newer than initramfs_data.cpio
53 # 4) arguments to gen_initramfs.sh changes
54 $(obj
)/$(datafile_y
): $(obj
)/gen_init_cpio
$(deps_initramfs
) klibcdirs
55 $(Q
)$(initramfs
) -l
$(ramfs-input
) > $(obj
)/.initramfs_data.cpio.d
56 $(call if_changed
,initfs
)