diff options
author | Alain Knaff <alain@knaff.lu> | 2009-01-07 03:10:27 -0500 |
---|---|---|
committer | H. Peter Anvin <hpa@zytor.com> | 2009-01-07 03:10:27 -0500 |
commit | a26ee60f90daffe1de6be0d093af86e7279b3dfd (patch) | |
tree | 01239fb6b173ff46711480b9601c69b92e1715a5 /init | |
parent | fb9a4ca9820fd4d7c4906bd393004662451e273e (diff) |
bzip2/lzma: fix built-in initramfs vs CONFIG_RD_GZIP
Impact: Resolves build failures in some configurations
Makes it possible to disable CONFIG_RD_GZIP . In that case, the
built-in initramfs will be compressed by whatever compressor is
available (bzip2 or lzma) or left uncompressed if none is available.
It also removes a couple of warnings which occur when no ramdisk
compression at all is chosen.
It also restores the select ZLIB_INFLATE in drivers/block/Kconfig
which somehow came missing. This is needed to activate compilation of
the stuff in zlib_deflate.
Signed-off-by: Alain Knaff <alain@knaff.lu>
Signed-off-by: H. Peter Anvin <hpa@zytor.com>
Diffstat (limited to 'init')
-rw-r--r-- | init/initramfs.c | 7 |
1 files changed, 6 insertions, 1 deletions
diff --git a/init/initramfs.c b/init/initramfs.c index 40bd4fb95788..a3ba91cdab89 100644 --- a/init/initramfs.c +++ b/init/initramfs.c | |||
@@ -389,7 +389,7 @@ static int __init write_buffer(char *buf, unsigned len) | |||
389 | return len - count; | 389 | return len - count; |
390 | } | 390 | } |
391 | 391 | ||
392 | 392 | #if defined CONFIG_RD_GZIP || defined CONFIG_RD_BZIP2 || defined CONFIG_RD_LZMA | |
393 | static int __init flush_buffer(void *bufv, unsigned len) | 393 | static int __init flush_buffer(void *bufv, unsigned len) |
394 | { | 394 | { |
395 | char *buf = (char *) bufv; | 395 | char *buf = (char *) bufv; |
@@ -412,6 +412,7 @@ static int __init flush_buffer(void *bufv, unsigned len) | |||
412 | } | 412 | } |
413 | return origLen; | 413 | return origLen; |
414 | } | 414 | } |
415 | #endif | ||
415 | 416 | ||
416 | static unsigned my_inptr; /* index of next byte to be processed in inbuf */ | 417 | static unsigned my_inptr; /* index of next byte to be processed in inbuf */ |
417 | 418 | ||
@@ -449,10 +450,12 @@ static char * __init unpack_to_rootfs(char *buf, unsigned len, int check_only) | |||
449 | continue; | 450 | continue; |
450 | } | 451 | } |
451 | this_header = 0; | 452 | this_header = 0; |
453 | #ifdef CONFIG_RD_GZIP | ||
452 | if (!gunzip(buf, len, NULL, flush_buffer, NULL, | 454 | if (!gunzip(buf, len, NULL, flush_buffer, NULL, |
453 | &my_inptr, error) && | 455 | &my_inptr, error) && |
454 | message == NULL) | 456 | message == NULL) |
455 | goto ok; | 457 | goto ok; |
458 | #endif | ||
456 | 459 | ||
457 | #ifdef CONFIG_RD_BZIP2 | 460 | #ifdef CONFIG_RD_BZIP2 |
458 | message = NULL; /* Zero out message, or else cpio will | 461 | message = NULL; /* Zero out message, or else cpio will |
@@ -473,7 +476,9 @@ static char * __init unpack_to_rootfs(char *buf, unsigned len, int check_only) | |||
473 | goto ok; | 476 | goto ok; |
474 | } | 477 | } |
475 | #endif | 478 | #endif |
479 | #if defined CONFIG_RD_GZIP || defined CONFIG_RD_BZIP2 || defined CONFIG_RD_LZMA | ||
476 | ok: | 480 | ok: |
481 | #endif | ||
477 | if (state != Reset) | 482 | if (state != Reset) |
478 | error("junk in compressed archive"); | 483 | error("junk in compressed archive"); |
479 | this_header = saved_offset + my_inptr; | 484 | this_header = saved_offset + my_inptr; |