forked from Minki/linux
initramfs: read CONFIG_RD_ variables for initramfs compression
When expert configuration option(CONFIG_EXPERT) is enabled, menuconfig offers a choice of compression algorithm to compress initial ramfs image; This choice is stored into CONFIG_RD_* variables. But usr/Makefile uses earlier INITRAMFS_COMPRESSION_* macros to build initial ramfs file. Since none of them is defined, resulting 'initramfs_data.cpio' file remains un-compressed. This patch updates the Makefile to use CONFIG_RD_* variables and adds support for LZ4 compression algorithm. Also updates the 'gen_initramfs_list.sh' script to check whether a selected compression command is accessible or not. And fall-back to default gzip(1) compression when it is not. Signed-off-by: P J P <prasad@redhat.com> Signed-off-by: Andrew Morton <akpm@linux-foundation.org> Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
This commit is contained in:
parent
ba24762bd5
commit
9ba4bcb645
@ -240,12 +240,24 @@ case "$arg" in
|
||||
output_file="$1"
|
||||
cpio_list="$(mktemp ${TMPDIR:-/tmp}/cpiolist.XXXXXX)"
|
||||
output=${cpio_list}
|
||||
echo "$output_file" | grep -q "\.gz$" && compr="gzip -n -9 -f"
|
||||
echo "$output_file" | grep -q "\.bz2$" && compr="bzip2 -9 -f"
|
||||
echo "$output_file" | grep -q "\.lzma$" && compr="lzma -9 -f"
|
||||
echo "$output_file" | grep -q "\.xz$" && \
|
||||
compr="xz --check=crc32 --lzma2=dict=1MiB"
|
||||
echo "$output_file" | grep -q "\.lzo$" && compr="lzop -9 -f"
|
||||
echo "$output_file" | grep -q "\.gz$" \
|
||||
&& [ -x "`which gzip 2> /dev/null`" ] \
|
||||
&& compr="gzip -n -9 -f"
|
||||
echo "$output_file" | grep -q "\.bz2$" \
|
||||
&& [ -x "`which bzip2 2> /dev/null`" ] \
|
||||
&& compr="bzip2 -9 -f"
|
||||
echo "$output_file" | grep -q "\.lzma$" \
|
||||
&& [ -x "`which lzma 2> /dev/null`" ] \
|
||||
&& compr="lzma -9 -f"
|
||||
echo "$output_file" | grep -q "\.xz$" \
|
||||
&& [ -x "`which xz 2> /dev/null`" ] \
|
||||
&& compr="xz --check=crc32 --lzma2=dict=1MiB"
|
||||
echo "$output_file" | grep -q "\.lzo$" \
|
||||
&& [ -x "`which lzop 2> /dev/null`" ] \
|
||||
&& compr="lzop -9 -f"
|
||||
echo "$output_file" | grep -q "\.lz4$" \
|
||||
&& [ -x "`which lz4 2> /dev/null`" ] \
|
||||
&& compr="lz4 -9 -f"
|
||||
echo "$output_file" | grep -q "\.cpio$" && compr="cat"
|
||||
shift
|
||||
;;
|
||||
|
23
usr/Makefile
23
usr/Makefile
@ -6,20 +6,23 @@ klibcdirs:;
|
||||
PHONY += klibcdirs
|
||||
|
||||
|
||||
# Gzip
|
||||
suffix_$(CONFIG_INITRAMFS_COMPRESSION_GZIP) = .gz
|
||||
|
||||
# Bzip2
|
||||
suffix_$(CONFIG_INITRAMFS_COMPRESSION_BZIP2) = .bz2
|
||||
suffix_$(CONFIG_RD_BZIP2) = .bz2
|
||||
|
||||
# Lzma
|
||||
suffix_$(CONFIG_INITRAMFS_COMPRESSION_LZMA) = .lzma
|
||||
suffix_$(CONFIG_RD_LZMA) = .lzma
|
||||
|
||||
# XZ
|
||||
suffix_$(CONFIG_INITRAMFS_COMPRESSION_XZ) = .xz
|
||||
suffix_$(CONFIG_RD_XZ) = .xz
|
||||
|
||||
# Lzo
|
||||
suffix_$(CONFIG_INITRAMFS_COMPRESSION_LZO) = .lzo
|
||||
suffix_$(CONFIG_RD_LZO) = .lzo
|
||||
|
||||
# Lz4
|
||||
suffix_$(CONFIG_RD_LZ4) = .lz4
|
||||
|
||||
# Gzip
|
||||
suffix_$(CONFIG_RD_GZIP) = .gz
|
||||
|
||||
AFLAGS_initramfs_data.o += -DINITRAMFS_IMAGE="usr/initramfs_data.cpio$(suffix_y)"
|
||||
|
||||
@ -53,7 +56,10 @@ endif
|
||||
quiet_cmd_initfs = GEN $@
|
||||
cmd_initfs = $(initramfs) -o $@ $(ramfs-args) $(ramfs-input)
|
||||
|
||||
targets := initramfs_data.cpio.gz initramfs_data.cpio.bz2 initramfs_data.cpio.lzma initramfs_data.cpio.xz initramfs_data.cpio.lzo initramfs_data.cpio
|
||||
targets := initramfs_data.cpio.gz initramfs_data.cpio.bz2 \
|
||||
initramfs_data.cpio.lzma initramfs_data.cpio.xz \
|
||||
initramfs_data.cpio.lzo initramfs_data.cpio.lz4 \
|
||||
initramfs_data.cpio
|
||||
# do not try to update files included in initramfs
|
||||
$(deps_initramfs): ;
|
||||
|
||||
@ -66,4 +72,3 @@ $(deps_initramfs): klibcdirs
|
||||
$(obj)/initramfs_data.cpio$(suffix_y): $(obj)/gen_init_cpio $(deps_initramfs) klibcdirs
|
||||
$(Q)$(initramfs) -l $(ramfs-input) > $(obj)/.initramfs_data.cpio.d
|
||||
$(call if_changed,initfs)
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user