| 
									
										
										
										
											2009-01-08 15:14:17 -08:00
										 |  |  | /*
 | 
					
						
							|  |  |  |  * decompress.c | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * Detect the decompression method based on magic number | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #include <linux/decompress/generic.h>
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #include <linux/decompress/bunzip2.h>
 | 
					
						
							|  |  |  | #include <linux/decompress/unlzma.h>
 | 
					
						
							| 
									
										
											  
											
												decompressors: add boot-time XZ support
This implements the API defined in <linux/decompress/generic.h> which is
used for kernel, initramfs, and initrd decompression.  This patch together
with the first patch is enough for XZ-compressed initramfs and initrd;
XZ-compressed kernel will need arch-specific changes.
The buffering requirements described in decompress_unxz.c are stricter
than with gzip, so the relevant changes should be done to the
arch-specific code when adding support for XZ-compressed kernel.
Similarly, the heap size in arch-specific pre-boot code may need to be
increased (30 KiB is enough).
The XZ decompressor needs memmove(), memeq() (memcmp() == 0), and
memzero() (memset(ptr, 0, size)), which aren't available in all
arch-specific pre-boot environments.  I'm including simple versions in
decompress_unxz.c, but a cleaner solution would naturally be nicer.
Signed-off-by: Lasse Collin <lasse.collin@tukaani.org>
Cc: "H. Peter Anvin" <hpa@zytor.com>
Cc: Alain Knaff <alain@knaff.lu>
Cc: Albin Tonnerre <albin.tonnerre@free-electrons.com>
Cc: Phillip Lougher <phillip@lougher.demon.co.uk>
Signed-off-by: Andrew Morton <akpm@linux-foundation.org>
Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
											
										 
											2011-01-12 17:01:23 -08:00
										 |  |  | #include <linux/decompress/unxz.h>
 | 
					
						
							| 
									
										
										
										
											2009-01-08 15:14:17 -08:00
										 |  |  | #include <linux/decompress/inflate.h>
 | 
					
						
							| 
									
										
										
										
											2010-01-08 14:42:46 -08:00
										 |  |  | #include <linux/decompress/unlzo.h>
 | 
					
						
							| 
									
										
										
										
											2013-07-08 16:01:46 -07:00
										 |  |  | #include <linux/decompress/unlz4.h>
 | 
					
						
							| 
									
										
										
										
											2009-01-08 15:14:17 -08:00
										 |  |  | 
 | 
					
						
							|  |  |  | #include <linux/types.h>
 | 
					
						
							|  |  |  | #include <linux/string.h>
 | 
					
						
							| 
									
										
										
										
											2012-10-04 17:16:58 -07:00
										 |  |  | #include <linux/init.h>
 | 
					
						
							| 
									
										
										
										
											2014-04-07 15:39:16 -07:00
										 |  |  | #include <linux/printk.h>
 | 
					
						
							| 
									
										
										
										
											2009-01-08 15:14:17 -08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-01-12 14:24:04 -08:00
										 |  |  | #ifndef CONFIG_DECOMPRESS_GZIP
 | 
					
						
							|  |  |  | # define gunzip NULL
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | #ifndef CONFIG_DECOMPRESS_BZIP2
 | 
					
						
							|  |  |  | # define bunzip2 NULL
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | #ifndef CONFIG_DECOMPRESS_LZMA
 | 
					
						
							|  |  |  | # define unlzma NULL
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							| 
									
										
											  
											
												decompressors: add boot-time XZ support
This implements the API defined in <linux/decompress/generic.h> which is
used for kernel, initramfs, and initrd decompression.  This patch together
with the first patch is enough for XZ-compressed initramfs and initrd;
XZ-compressed kernel will need arch-specific changes.
The buffering requirements described in decompress_unxz.c are stricter
than with gzip, so the relevant changes should be done to the
arch-specific code when adding support for XZ-compressed kernel.
Similarly, the heap size in arch-specific pre-boot code may need to be
increased (30 KiB is enough).
The XZ decompressor needs memmove(), memeq() (memcmp() == 0), and
memzero() (memset(ptr, 0, size)), which aren't available in all
arch-specific pre-boot environments.  I'm including simple versions in
decompress_unxz.c, but a cleaner solution would naturally be nicer.
Signed-off-by: Lasse Collin <lasse.collin@tukaani.org>
Cc: "H. Peter Anvin" <hpa@zytor.com>
Cc: Alain Knaff <alain@knaff.lu>
Cc: Albin Tonnerre <albin.tonnerre@free-electrons.com>
Cc: Phillip Lougher <phillip@lougher.demon.co.uk>
Signed-off-by: Andrew Morton <akpm@linux-foundation.org>
Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
											
										 
											2011-01-12 17:01:23 -08:00
										 |  |  | #ifndef CONFIG_DECOMPRESS_XZ
 | 
					
						
							|  |  |  | # define unxz NULL
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2010-01-08 14:42:46 -08:00
										 |  |  | #ifndef CONFIG_DECOMPRESS_LZO
 | 
					
						
							|  |  |  | # define unlzo NULL
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2013-07-08 16:01:46 -07:00
										 |  |  | #ifndef CONFIG_DECOMPRESS_LZ4
 | 
					
						
							|  |  |  | # define unlz4 NULL
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2009-01-12 14:24:04 -08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-10-04 17:16:58 -07:00
										 |  |  | struct compress_format { | 
					
						
							| 
									
										
										
										
											2009-01-08 15:14:17 -08:00
										 |  |  | 	unsigned char magic[2]; | 
					
						
							|  |  |  | 	const char *name; | 
					
						
							|  |  |  | 	decompress_fn decompressor; | 
					
						
							| 
									
										
										
										
											2012-10-04 17:16:58 -07:00
										 |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-04-30 15:28:50 -07:00
										 |  |  | static const struct compress_format compressed_formats[] __initconst = { | 
					
						
							| 
									
										
										
										
											2009-01-08 15:14:17 -08:00
										 |  |  | 	{ {037, 0213}, "gzip", gunzip }, | 
					
						
							|  |  |  | 	{ {037, 0236}, "gzip", gunzip }, | 
					
						
							|  |  |  | 	{ {0x42, 0x5a}, "bzip2", bunzip2 }, | 
					
						
							|  |  |  | 	{ {0x5d, 0x00}, "lzma", unlzma }, | 
					
						
							| 
									
										
											  
											
												decompressors: add boot-time XZ support
This implements the API defined in <linux/decompress/generic.h> which is
used for kernel, initramfs, and initrd decompression.  This patch together
with the first patch is enough for XZ-compressed initramfs and initrd;
XZ-compressed kernel will need arch-specific changes.
The buffering requirements described in decompress_unxz.c are stricter
than with gzip, so the relevant changes should be done to the
arch-specific code when adding support for XZ-compressed kernel.
Similarly, the heap size in arch-specific pre-boot code may need to be
increased (30 KiB is enough).
The XZ decompressor needs memmove(), memeq() (memcmp() == 0), and
memzero() (memset(ptr, 0, size)), which aren't available in all
arch-specific pre-boot environments.  I'm including simple versions in
decompress_unxz.c, but a cleaner solution would naturally be nicer.
Signed-off-by: Lasse Collin <lasse.collin@tukaani.org>
Cc: "H. Peter Anvin" <hpa@zytor.com>
Cc: Alain Knaff <alain@knaff.lu>
Cc: Albin Tonnerre <albin.tonnerre@free-electrons.com>
Cc: Phillip Lougher <phillip@lougher.demon.co.uk>
Signed-off-by: Andrew Morton <akpm@linux-foundation.org>
Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
											
										 
											2011-01-12 17:01:23 -08:00
										 |  |  | 	{ {0xfd, 0x37}, "xz", unxz }, | 
					
						
							| 
									
										
										
										
											2010-01-08 14:42:46 -08:00
										 |  |  | 	{ {0x89, 0x4c}, "lzo", unlzo }, | 
					
						
							| 
									
										
										
										
											2013-07-08 16:01:46 -07:00
										 |  |  | 	{ {0x02, 0x21}, "lz4", unlz4 }, | 
					
						
							| 
									
										
										
										
											2009-01-08 15:14:17 -08:00
										 |  |  | 	{ {0, 0}, NULL, NULL } | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-10-04 17:16:58 -07:00
										 |  |  | decompress_fn __init decompress_method(const unsigned char *inbuf, int len, | 
					
						
							| 
									
										
										
										
											2009-01-08 15:14:17 -08:00
										 |  |  | 				const char **name) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	const struct compress_format *cf; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	if (len < 2) | 
					
						
							|  |  |  | 		return NULL;	/* Need at least this much... */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-04-07 15:39:16 -07:00
										 |  |  | 	pr_debug("Compressed data magic: %#.2x %#.2x\n", inbuf[0], inbuf[1]); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-02-19 13:36:55 -08:00
										 |  |  | 	for (cf = compressed_formats; cf->name; cf++) { | 
					
						
							| 
									
										
										
										
											2009-01-08 15:14:17 -08:00
										 |  |  | 		if (!memcmp(inbuf, cf->magic, 2)) | 
					
						
							|  |  |  | 			break; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	if (name) | 
					
						
							|  |  |  | 		*name = cf->name; | 
					
						
							|  |  |  | 	return cf->decompressor; | 
					
						
							|  |  |  | } |