wok-current rev 8994

Up: squashfs to 4.2.
author Christopher Rogers <slaxemulator@gmail.com>
date Thu Mar 03 06:36:12 2011 +0000 (2011-03-03)
parents e8b87b9efb7d
children 45fab90b3a6a
files squashfs/receipt squashfs/stuff/xz.patch
line diff
     1.1 --- a/squashfs/receipt	Thu Mar 03 06:01:52 2011 +0000
     1.2 +++ b/squashfs/receipt	Thu Mar 03 06:36:12 2011 +0000
     1.3 @@ -1,7 +1,7 @@
     1.4  # SliTaz package receipt.
     1.5  
     1.6  PACKAGE="squashfs"
     1.7 -VERSION="4.1"
     1.8 +VERSION="4.2"
     1.9  CATEGORY="base-system"
    1.10  SHORT_DESC="Linux squashfs userland tools."
    1.11  MAINTAINER="pascal.bellard@slitaz.org"
    1.12 @@ -15,15 +15,13 @@
    1.13  # Rules to configure and make the package.
    1.14  compile_rules()
    1.15  {
    1.16 -	mv ${PACKAGE}${VERSION} $src 2> /dev/null
    1.17  	cd $src
    1.18 -	patch -Np1 -i $stuff/xz.patch
    1.19  	cd $src/squashfs-tools
    1.20 -	#sed -i 's|#XZ_SUPPORT = 1|XZ_SUPPORT = 1|g' Makefile
    1.21 -	mkdir -p ../_pkg/usr/sbin ../_pkg/sbin
    1.22 +	sed -i 's|#XZ_SUPPORT = 1|XZ_SUPPORT = 1|g' Makefile
    1.23 +	mkdir -p $DESTDIR/usr/sbin $DESTDIR/sbin
    1.24  	make || return 1
    1.25 -	cp mksquashfs ../_pkg/usr/sbin
    1.26 -	cp unsquashfs ../_pkg/sbin
    1.27 +	cp -a mksquashfs  $DESTDIR/usr/sbin
    1.28 +	cp -a unsquashfs $DESTDIR/sbin
    1.29  }
    1.30  
    1.31  # Rules to gen a SliTaz package suitable for Tazpkg.
     2.1 --- a/squashfs/stuff/xz.patch	Thu Mar 03 06:01:52 2011 +0000
     2.2 +++ /dev/null	Thu Jan 01 00:00:00 1970 +0000
     2.3 @@ -1,1432 +0,0 @@
     2.4 -diff -r 2ab2996036dd squashfs-tools/Makefile
     2.5 ---- a/squashfs-tools/Makefile	Tue Dec 14 12:19:33 2010 +0000
     2.6 -+++ b/squashfs-tools/Makefile	Tue Dec 14 14:18:11 2010 +0000
     2.7 -@@ -20,20 +20,33 @@
     2.8 - 
     2.9 - ########### Building LZMA support #############
    2.10 - #
    2.11 --# Both XZ Utils liblzma  (http://tukaani.org/xz/) and LZMA SDK
    2.12 -+# LZMA1 compression.
    2.13 -+#
    2.14 -+# Both XZ Utils liblzma (http://tukaani.org/xz/) and LZMA SDK
    2.15 - # (http://www.7-zip.org/sdk.html) are supported
    2.16 - #
    2.17 - # To build using XZ Utils liblzma - install the library and uncomment
    2.18 --# the XZ_SUPPORT line below.
    2.19 -+# the LZMA_XZ_SUPPORT line below.
    2.20 - #
    2.21 - # To build using the LZMA SDK (4.65 used in development, other versions may
    2.22 - # work) - download and unpack it, uncomment and set LZMA_DIR to unpacked source,
    2.23 - # and uncomment the LZMA_SUPPORT line below.
    2.24 - #
    2.25 --#XZ_SUPPORT = 1
    2.26 -+LZMA_XZ_SUPPORT = 1
    2.27 - #LZMA_SUPPORT = 1
    2.28 - #LZMA_DIR = ../../../LZMA/lzma465
    2.29 - 
    2.30 -+########### Building XZ support #############
    2.31 -+#
    2.32 -+# LZMA2 compression.
    2.33 -+#
    2.34 -+# XZ Utils liblzma (http://tukaani.org/xz/) is supported
    2.35 -+#
    2.36 -+# To build using XZ Utils liblzma - install the library and uncomment
    2.37 -+# the XZ_SUPPORT line below.
    2.38 -+#
    2.39 -+XZ_SUPPORT = 1
    2.40 -+
    2.41 - 
    2.42 - ############ Building LZO support ##############
    2.43 - #
    2.44 -@@ -109,12 +122,20 @@
    2.45 - COMPRESSORS += lzma
    2.46 - endif
    2.47 - 
    2.48 -+ifdef LZMA_XZ_SUPPORT
    2.49 -+CFLAGS += -DLZMA_SUPPORT
    2.50 -+MKSQUASHFS_OBJS += lzma_xz_wrapper.o
    2.51 -+UNSQUASHFS_OBJS += lzma_xz_wrapper.o
    2.52 -+LIBS += -llzma
    2.53 -+COMPRESSORS += lzma
    2.54 -+endif
    2.55 -+
    2.56 - ifdef XZ_SUPPORT
    2.57 --CFLAGS += -DLZMA_SUPPORT
    2.58 -+CFLAGS += -DXZ_SUPPORT
    2.59 - MKSQUASHFS_OBJS += xz_wrapper.o
    2.60 - UNSQUASHFS_OBJS += xz_wrapper.o
    2.61 - LIBS += -llzma
    2.62 --COMPRESSORS += lzma
    2.63 -+COMPRESSORS += xz
    2.64 - endif
    2.65 - 
    2.66 - ifdef LZO_SUPPORT
    2.67 -@@ -149,11 +170,11 @@
    2.68 - endif
    2.69 - 
    2.70 - #
    2.71 --# Both XZ_SUPPORT and LZMA_SUPPORT cannot be specified
    2.72 -+# Both LZMA_XZ_SUPPORT and LZMA_SUPPORT cannot be specified
    2.73 - #
    2.74 --ifdef XZ_SUPPORT
    2.75 -+ifdef LZMA_XZ_SUPPORT
    2.76 - ifdef LZMA_SUPPORT
    2.77 --$(error "Both XZ_SUPPORT and LZMA_SUPPORT cannot be specified")
    2.78 -+$(error "Both LZMA_XZ_SUPPORT and LZMA_SUPPORT cannot be specified")
    2.79 - endif
    2.80 - endif
    2.81 - 
    2.82 -@@ -161,7 +182,7 @@
    2.83 - # At least one compressor must have been selected
    2.84 - #
    2.85 - ifndef COMPRESSORS
    2.86 --$(error "No compressor selected! Select one or more of GZIP, LZMA, or LZO!")
    2.87 -+$(error "No compressor selected! Select one or more of GZIP, LZMA, XZ or LZO!")
    2.88 - endif
    2.89 - 
    2.90 - #
    2.91 -diff -r 2ab2996036dd squashfs-tools/compressor.c
    2.92 ---- a/squashfs-tools/compressor.c	Tue Dec 14 12:19:33 2010 +0000
    2.93 -+++ b/squashfs-tools/compressor.c	Tue Dec 14 14:18:11 2010 +0000
    2.94 -@@ -25,31 +25,50 @@
    2.95 - #include "compressor.h"
    2.96 - #include "squashfs_fs.h"
    2.97 - 
    2.98 --extern int gzip_compress(void **, char *, char *, int, int, int *);
    2.99 --extern int gzip_uncompress(char *, char *, int, int, int *);
   2.100 --extern int lzma_compress(void **, char *, char *, int, int, int *);
   2.101 --extern int lzma_uncompress(char *, char *, int, int, int *);
   2.102 --extern int lzo_compress(void **, char *, char *, int, int, int *);
   2.103 --extern int lzo_uncompress(char *, char *, int, int, int *);
   2.104 --
   2.105 --struct compressor compressor[] = {
   2.106 --#ifdef GZIP_SUPPORT
   2.107 --	{ gzip_compress, gzip_uncompress, ZLIB_COMPRESSION, "gzip", 1 },
   2.108 -+#ifndef GZIP_SUPPORT
   2.109 -+static struct compressor gzip_comp_ops =  {
   2.110 -+	NULL, NULL, NULL, NULL, NULL, ZLIB_COMPRESSION, "gzip", 0
   2.111 -+};
   2.112 - #else
   2.113 --	{ NULL, NULL, ZLIB_COMPRESSION, "gzip", 0 },
   2.114 --#endif
   2.115 --#ifdef LZMA_SUPPORT
   2.116 --	{ lzma_compress, lzma_uncompress, LZMA_COMPRESSION, "lzma", 1 },
   2.117 --#else
   2.118 --	{ NULL, NULL, LZMA_COMPRESSION, "lzma", 0 },
   2.119 --#endif
   2.120 --#ifdef LZO_SUPPORT
   2.121 --	{ lzo_compress, lzo_uncompress, LZO_COMPRESSION, "lzo", 1 },
   2.122 --#else
   2.123 --	{ NULL, NULL, LZO_COMPRESSION, "lzo", 0 },
   2.124 -+extern struct compressor gzip_comp_ops;
   2.125 - #endif
   2.126 - 
   2.127 --	{ NULL, NULL , 0, "unknown", 0}
   2.128 -+#ifndef LZMA_SUPPORT
   2.129 -+static struct compressor lzma_comp_ops = {
   2.130 -+	NULL, NULL, NULL, NULL, NULL, LZMA_COMPRESSION, "lzma", 0
   2.131 -+};
   2.132 -+#else
   2.133 -+extern struct compressor lzma_comp_ops;
   2.134 -+#endif
   2.135 -+
   2.136 -+#ifndef LZO_SUPPORT
   2.137 -+static struct compressor lzo_comp_ops = {
   2.138 -+	NULL, NULL, NULL, NULL, NULL, LZO_COMPRESSION, "lzo", 0
   2.139 -+};
   2.140 -+#else
   2.141 -+extern struct compressor lzo_comp_ops;
   2.142 -+#endif
   2.143 -+
   2.144 -+#ifndef XZ_SUPPORT
   2.145 -+static struct compressor xz_comp_ops = {
   2.146 -+	NULL, NULL, NULL, NULL, NULL, XZ_COMPRESSION, "xz", 0
   2.147 -+};
   2.148 -+#else
   2.149 -+extern struct compressor xz_comp_ops;
   2.150 -+#endif
   2.151 -+
   2.152 -+
   2.153 -+static struct compressor unknown_comp_ops = {
   2.154 -+	NULL, NULL, NULL , NULL, NULL, 0, "unknown", 0
   2.155 -+};
   2.156 -+
   2.157 -+
   2.158 -+struct compressor *compressor[] = {
   2.159 -+	&gzip_comp_ops,
   2.160 -+	&lzma_comp_ops,
   2.161 -+	&lzo_comp_ops,
   2.162 -+	&xz_comp_ops,
   2.163 -+	&unknown_comp_ops
   2.164 - };
   2.165 - 
   2.166 - 
   2.167 -@@ -57,11 +76,11 @@
   2.168 - {
   2.169 - 	int i;
   2.170 - 
   2.171 --	for(i = 0; compressor[i].id; i++)
   2.172 --		if(strcmp(compressor[i].name, name) == 0)
   2.173 -+	for(i = 0; compressor[i]->id; i++)
   2.174 -+		if(strcmp(compressor[i]->name, name) == 0)
   2.175 - 			break;
   2.176 - 
   2.177 --	return &compressor[i];
   2.178 -+	return compressor[i];
   2.179 - }
   2.180 - 
   2.181 - 
   2.182 -@@ -69,11 +88,11 @@
   2.183 - {
   2.184 - 	int i;
   2.185 - 
   2.186 --	for(i = 0; compressor[i].id; i++)
   2.187 --		if(id == compressor[i].id)
   2.188 -+	for(i = 0; compressor[i]->id; i++)
   2.189 -+		if(id == compressor[i]->id)
   2.190 - 			break;
   2.191 - 
   2.192 --	return &compressor[i];
   2.193 -+	return compressor[i];
   2.194 - }
   2.195 - 
   2.196 - 
   2.197 -@@ -81,10 +100,29 @@
   2.198 - {
   2.199 - 	int i;
   2.200 - 
   2.201 --	for(i = 0; compressor[i].id; i++)
   2.202 --		if(compressor[i].supported)
   2.203 -+	for(i = 0; compressor[i]->id; i++)
   2.204 -+		if(compressor[i]->supported)
   2.205 - 			fprintf(stderr, "%s\t%s%s\n", indent,
   2.206 --				compressor[i].name,
   2.207 --				strcmp(compressor[i].name, def_comp) == 0 ?
   2.208 -+				compressor[i]->name,
   2.209 -+				strcmp(compressor[i]->name, def_comp) == 0 ?
   2.210 - 				" (default)" : "");
   2.211 - }
   2.212 -+
   2.213 -+
   2.214 -+void display_compressor_usage(char *def_comp)
   2.215 -+{
   2.216 -+	int i;
   2.217 -+
   2.218 -+	for(i = 0; compressor[i]->id; i++)
   2.219 -+		if(compressor[i]->supported) {
   2.220 -+			char *str = strcmp(compressor[i]->name, def_comp) == 0 ?
   2.221 -+				" (default)" : "";
   2.222 -+			if(compressor[i]->usage) {
   2.223 -+				fprintf(stderr, "\t%s%s\n",
   2.224 -+					compressor[i]->name, str);
   2.225 -+				compressor[i]->usage();
   2.226 -+			} else
   2.227 -+				fprintf(stderr, "\t%s (no options)%s\n",
   2.228 -+					compressor[i]->name, str);
   2.229 -+		}
   2.230 -+}
   2.231 -diff -r 2ab2996036dd squashfs-tools/compressor.h
   2.232 ---- a/squashfs-tools/compressor.h	Tue Dec 14 12:19:33 2010 +0000
   2.233 -+++ b/squashfs-tools/compressor.h	Tue Dec 14 14:18:11 2010 +0000
   2.234 -@@ -21,8 +21,11 @@
   2.235 -  */
   2.236 - 
   2.237 - struct compressor {
   2.238 --	int (*compress)(void **, char *, char *, int, int, int *);
   2.239 --	int (*uncompress)(char *, char *, int, int, int *);
   2.240 -+	int (*init)(void **, int, int);
   2.241 -+	int (*compress)(void *, void *, void *, int, int, int *);
   2.242 -+	int (*uncompress)(void *, void *, int, int, int *);
   2.243 -+	int (*options)(char **, int);
   2.244 -+	void (*usage)();
   2.245 - 	int id;
   2.246 - 	char *name;
   2.247 - 	int supported;
   2.248 -@@ -31,3 +34,25 @@
   2.249 - extern struct compressor *lookup_compressor(char *);
   2.250 - extern struct compressor *lookup_compressor_id(int);
   2.251 - extern void display_compressors(char *, char *);
   2.252 -+extern void display_compressor_usage(char *);
   2.253 -+
   2.254 -+static inline int compressor_options(struct compressor *comp, char *argv[],
   2.255 -+	int argc)
   2.256 -+{
   2.257 -+	if(comp->options == NULL)
   2.258 -+		return -1;
   2.259 -+
   2.260 -+	return comp->options(argv, argc);
   2.261 -+}
   2.262 -+
   2.263 -+
   2.264 -+static inline int compressor_init(struct compressor *comp, void **stream,
   2.265 -+	int block_size, int flags)
   2.266 -+{
   2.267 -+	if(comp->init == NULL)
   2.268 -+		return 0;
   2.269 -+	return comp->init(stream, block_size, flags);
   2.270 -+}
   2.271 -+
   2.272 -+
   2.273 -+
   2.274 -diff -r 2ab2996036dd squashfs-tools/gzip_wrapper.c
   2.275 ---- a/squashfs-tools/gzip_wrapper.c	Tue Dec 14 12:19:33 2010 +0000
   2.276 -+++ b/squashfs-tools/gzip_wrapper.c	Tue Dec 14 14:18:11 2010 +0000
   2.277 -@@ -22,28 +22,48 @@
   2.278 - #include <stdlib.h>
   2.279 - #include <zlib.h>
   2.280 - 
   2.281 --int gzip_compress(void **strm, char *d, char *s, int size, int block_size,
   2.282 -+#include "squashfs_fs.h"
   2.283 -+#include "compressor.h"
   2.284 -+
   2.285 -+static int gzip_init(void **strm, int block_size, int flags)
   2.286 -+{
   2.287 -+	int res;
   2.288 -+	z_stream *stream;
   2.289 -+
   2.290 -+	stream = *strm = malloc(sizeof(z_stream));
   2.291 -+	if(stream == NULL)
   2.292 -+		goto failed;
   2.293 -+
   2.294 -+	stream->zalloc = Z_NULL;
   2.295 -+	stream->zfree = Z_NULL;
   2.296 -+	stream->opaque = 0;
   2.297 -+
   2.298 -+	res = deflateInit(stream, 9);
   2.299 -+	if(res != Z_OK)
   2.300 -+		goto failed2;
   2.301 -+
   2.302 -+	return 0;
   2.303 -+
   2.304 -+failed2:
   2.305 -+	free(stream);
   2.306 -+failed:
   2.307 -+	return -1;
   2.308 -+}
   2.309 -+
   2.310 -+
   2.311 -+static int gzip_compress(void *strm, void *d, void *s, int size, int block_size,
   2.312 - 		int *error)
   2.313 - {
   2.314 --	int res = 0;
   2.315 --	z_stream *stream = *strm;
   2.316 -+	int res;
   2.317 -+	z_stream *stream = strm;
   2.318 - 
   2.319 --	if(stream == NULL) {
   2.320 --		if((stream = *strm = malloc(sizeof(z_stream))) == NULL)
   2.321 --			goto failed;
   2.322 --
   2.323 --		stream->zalloc = Z_NULL;
   2.324 --		stream->zfree = Z_NULL;
   2.325 --		stream->opaque = 0;
   2.326 --
   2.327 --		if((res = deflateInit(stream, 9)) != Z_OK)
   2.328 --			goto failed;
   2.329 --	} else if((res = deflateReset(stream)) != Z_OK)
   2.330 -+	res = deflateReset(stream);
   2.331 -+	if(res != Z_OK)
   2.332 - 		goto failed;
   2.333 - 
   2.334 --	stream->next_in = (unsigned char *) s;
   2.335 -+	stream->next_in = s;
   2.336 - 	stream->avail_in = size;
   2.337 --	stream->next_out = (unsigned char *) d;
   2.338 -+	stream->next_out = d;
   2.339 - 	stream->avail_out = block_size;
   2.340 - 
   2.341 - 	res = deflate(stream, Z_FINISH);
   2.342 -@@ -67,14 +87,26 @@
   2.343 - }
   2.344 - 
   2.345 - 
   2.346 --int gzip_uncompress(char *d, char *s, int size, int block_size, int *error)
   2.347 -+static int gzip_uncompress(void *d, void *s, int size, int block_size, int *error)
   2.348 - {
   2.349 - 	int res;
   2.350 - 	unsigned long bytes = block_size;
   2.351 - 
   2.352 --	res = uncompress((unsigned char *) d, &bytes,
   2.353 --		(const unsigned char *) s, size);
   2.354 -+	res = uncompress(d, &bytes, s, size);
   2.355 - 
   2.356 - 	*error = res;
   2.357 - 	return res == Z_OK ? (int) bytes : -1;
   2.358 - }
   2.359 -+
   2.360 -+
   2.361 -+struct compressor gzip_comp_ops = {
   2.362 -+	.init = gzip_init,
   2.363 -+	.compress = gzip_compress,
   2.364 -+	.uncompress = gzip_uncompress,
   2.365 -+	.options = NULL,
   2.366 -+	.usage = NULL,
   2.367 -+	.id = ZLIB_COMPRESSION,
   2.368 -+	.name = "gzip",
   2.369 -+	.supported = 1
   2.370 -+};
   2.371 -+
   2.372 -diff -r 2ab2996036dd squashfs-tools/lzma_wrapper.c
   2.373 ---- a/squashfs-tools/lzma_wrapper.c	Tue Dec 14 12:19:33 2010 +0000
   2.374 -+++ b/squashfs-tools/lzma_wrapper.c	Tue Dec 14 14:18:11 2010 +0000
   2.375 -@@ -17,21 +17,27 @@
   2.376 -  * Foundation, 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
   2.377 -  *
   2.378 -  * lzma_wrapper.c
   2.379 -+ *
   2.380 -+ * Support for LZMA1 compression using LZMA SDK (4.65 used in
   2.381 -+ * development, other versions may work) http://www.7-zip.org/sdk.html
   2.382 -  */
   2.383 - 
   2.384 - #include <LzmaLib.h>
   2.385 - 
   2.386 -+#include "squashfs_fs.h"
   2.387 -+#include "compressor.h"
   2.388 -+
   2.389 - #define LZMA_HEADER_SIZE	(LZMA_PROPS_SIZE + 8)
   2.390 - 
   2.391 --int lzma_compress(void **strm, char *dest, char *src, int size, int block_size,
   2.392 -+static int lzma_compress(void *strm, void *dest, void *src, int size, int block_size,
   2.393 - 		int *error)
   2.394 - {
   2.395 --	unsigned char *d = (unsigned char *) dest, *s = (unsigned char *) src;
   2.396 -+	unsigned char *d = dest;
   2.397 - 	size_t props_size = LZMA_PROPS_SIZE,
   2.398 - 		outlen = block_size - LZMA_HEADER_SIZE;
   2.399 - 	int res;
   2.400 - 
   2.401 --	res = LzmaCompress(d + LZMA_HEADER_SIZE, &outlen, s, size, d,
   2.402 -+	res = LzmaCompress(dest + LZMA_HEADER_SIZE, &outlen, src, size, dest,
   2.403 - 		&props_size, 5, block_size, 3, 0, 2, 32, 1);
   2.404 - 	
   2.405 - 	if(res == SZ_ERROR_OUTPUT_EOF) {
   2.406 -@@ -73,10 +79,10 @@
   2.407 - }
   2.408 - 
   2.409 - 
   2.410 --int lzma_uncompress(char *dest, char *src, int size, int block_size,
   2.411 -+static int lzma_uncompress(void *dest, void *src, int size, int block_size,
   2.412 - 	int *error)
   2.413 - {
   2.414 --	unsigned char *d = (unsigned char *) dest, *s = (unsigned char *) src;
   2.415 -+	unsigned char *s = src;
   2.416 - 	size_t outlen, inlen = size - LZMA_HEADER_SIZE;
   2.417 - 	int res;
   2.418 - 
   2.419 -@@ -85,9 +91,22 @@
   2.420 - 		(s[LZMA_PROPS_SIZE + 2] << 16) |
   2.421 - 		(s[LZMA_PROPS_SIZE + 3] << 24);
   2.422 - 
   2.423 --	res = LzmaUncompress(d, &outlen, s + LZMA_HEADER_SIZE, &inlen,
   2.424 --		s, LZMA_PROPS_SIZE);
   2.425 -+	res = LzmaUncompress(dest, &outlen, src + LZMA_HEADER_SIZE, &inlen, src,
   2.426 -+		LZMA_PROPS_SIZE);
   2.427 - 	
   2.428 - 	*error = res;
   2.429 - 	return res == SZ_OK ? outlen : -1;
   2.430 - }
   2.431 -+
   2.432 -+
   2.433 -+struct compressor lzma_comp_ops = {
   2.434 -+	.init = NULL,
   2.435 -+	.compress = lzma_compress,
   2.436 -+	.uncompress = lzma_uncompress,
   2.437 -+	.options = NULL,
   2.438 -+	.usage = NULL,
   2.439 -+	.id = LZMA_COMPRESSION,
   2.440 -+	.name = "lzma",
   2.441 -+	.supported = 1
   2.442 -+};
   2.443 -+
   2.444 -diff -r 2ab2996036dd squashfs-tools/lzma_xz_wrapper.c
   2.445 ---- /dev/null	Thu Jan 01 00:00:00 1970 +0000
   2.446 -+++ b/squashfs-tools/lzma_xz_wrapper.c	Tue Dec 14 14:18:11 2010 +0000
   2.447 -@@ -0,0 +1,156 @@
   2.448 -+/*
   2.449 -+ * Copyright (c) 2010
   2.450 -+ * Phillip Lougher <phillip@lougher.demon.co.uk>
   2.451 -+ *
   2.452 -+ * This program is free software; you can redistribute it and/or
   2.453 -+ * modify it under the terms of the GNU General Public License
   2.454 -+ * as published by the Free Software Foundation; either version 2,
   2.455 -+ * or (at your option) any later version.
   2.456 -+ *
   2.457 -+ * This program is distributed in the hope that it will be useful,
   2.458 -+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
   2.459 -+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
   2.460 -+ * GNU General Public License for more details.
   2.461 -+ *
   2.462 -+ * You should have received a copy of the GNU General Public License
   2.463 -+ * along with this program; if not, write to the Free Software
   2.464 -+ * Foundation, 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
   2.465 -+ *
   2.466 -+ * lzma_xz_wrapper.c
   2.467 -+ *
   2.468 -+ * Support for LZMA1 compression using XZ Utils liblzma http://tukaani.org/xz/
   2.469 -+ */
   2.470 -+
   2.471 -+#include <stdio.h>
   2.472 -+#include <string.h>
   2.473 -+#include <lzma.h>
   2.474 -+
   2.475 -+#include "squashfs_fs.h"
   2.476 -+#include "compressor.h"
   2.477 -+
   2.478 -+#define LZMA_PROPS_SIZE 5
   2.479 -+#define LZMA_UNCOMP_SIZE 8
   2.480 -+#define LZMA_HEADER_SIZE (LZMA_PROPS_SIZE + LZMA_UNCOMP_SIZE)
   2.481 -+
   2.482 -+#define LZMA_OPTIONS 5
   2.483 -+#define MEMLIMIT (32 * 1024 * 1024)
   2.484 -+
   2.485 -+static int lzma_compress(void *dummy, void *dest, void *src,  int size,
   2.486 -+	int block_size, int *error)
   2.487 -+{
   2.488 -+	unsigned char *d = (unsigned char *) dest;
   2.489 -+	lzma_options_lzma opt;
   2.490 -+	lzma_stream strm = LZMA_STREAM_INIT;
   2.491 -+	int res;
   2.492 -+
   2.493 -+	lzma_lzma_preset(&opt, LZMA_OPTIONS);
   2.494 -+	opt.dict_size = block_size;
   2.495 -+	res = lzma_alone_encoder(&strm, &opt);
   2.496 -+	if(res != LZMA_OK) {
   2.497 -+		lzma_end(&strm);
   2.498 -+		goto failed;
   2.499 -+	}
   2.500 -+
   2.501 -+	strm.next_out = dest;
   2.502 -+	strm.avail_out = block_size;
   2.503 -+	strm.next_in = src;
   2.504 -+	strm.avail_in = size;
   2.505 -+
   2.506 -+	res = lzma_code(&strm, LZMA_FINISH);
   2.507 -+	lzma_end(&strm);
   2.508 -+
   2.509 -+	if(res == LZMA_STREAM_END) {
   2.510 -+		/*
   2.511 -+	 	 * Fill in the 8 byte little endian uncompressed size field in
   2.512 -+		 * the LZMA header.  8 bytes is excessively large for squashfs
   2.513 -+		 * but this is the standard LZMA header and which is expected by
   2.514 -+		 * the kernel code
   2.515 -+	 	 */
   2.516 -+
   2.517 -+		d[LZMA_PROPS_SIZE] = size & 255;
   2.518 -+		d[LZMA_PROPS_SIZE + 1] = (size >> 8) & 255;
   2.519 -+		d[LZMA_PROPS_SIZE + 2] = (size >> 16) & 255;
   2.520 -+		d[LZMA_PROPS_SIZE + 3] = (size >> 24) & 255;
   2.521 -+		d[LZMA_PROPS_SIZE + 4] = 0;
   2.522 -+		d[LZMA_PROPS_SIZE + 5] = 0;
   2.523 -+		d[LZMA_PROPS_SIZE + 6] = 0;
   2.524 -+		d[LZMA_PROPS_SIZE + 7] = 0;
   2.525 -+
   2.526 -+		return (int) strm.total_out;
   2.527 -+	}
   2.528 -+
   2.529 -+	if(res == LZMA_OK)
   2.530 -+		/*
   2.531 -+	 	 * Output buffer overflow.  Return out of buffer space
   2.532 -+	 	 */
   2.533 -+		return 0;
   2.534 -+
   2.535 -+failed:
   2.536 -+	/*
   2.537 -+	 * All other errors return failure, with the compressor
   2.538 -+	 * specific error code in *error
   2.539 -+	 */
   2.540 -+	*error = res;
   2.541 -+	return -1;
   2.542 -+}
   2.543 -+
   2.544 -+
   2.545 -+static int lzma_uncompress(void *dest, void *src, int size, int block_size,
   2.546 -+	int *error)
   2.547 -+{
   2.548 -+	lzma_stream strm = LZMA_STREAM_INIT;
   2.549 -+	int uncompressed_size = 0, res;
   2.550 -+	unsigned char lzma_header[LZMA_HEADER_SIZE];
   2.551 -+
   2.552 -+	res = lzma_alone_decoder(&strm, MEMLIMIT);
   2.553 -+	if(res != LZMA_OK) {
   2.554 -+		lzma_end(&strm);
   2.555 -+		goto failed;
   2.556 -+	}
   2.557 -+
   2.558 -+	memcpy(lzma_header, src, LZMA_HEADER_SIZE);
   2.559 -+	uncompressed_size = lzma_header[LZMA_PROPS_SIZE] |
   2.560 -+		(lzma_header[LZMA_PROPS_SIZE + 1] << 8) |
   2.561 -+		(lzma_header[LZMA_PROPS_SIZE + 2] << 16) |
   2.562 -+		(lzma_header[LZMA_PROPS_SIZE + 3] << 24);
   2.563 -+	memset(lzma_header + LZMA_PROPS_SIZE, 255, LZMA_UNCOMP_SIZE);
   2.564 -+
   2.565 -+	strm.next_out = dest;
   2.566 -+	strm.avail_out = block_size;
   2.567 -+	strm.next_in = lzma_header;
   2.568 -+	strm.avail_in = LZMA_HEADER_SIZE;
   2.569 -+
   2.570 -+	res = lzma_code(&strm, LZMA_RUN);
   2.571 -+
   2.572 -+	if(res != LZMA_OK || strm.avail_in != 0) {
   2.573 -+		lzma_end(&strm);
   2.574 -+		goto failed;
   2.575 -+	}
   2.576 -+
   2.577 -+	strm.next_in = src + LZMA_HEADER_SIZE;
   2.578 -+	strm.avail_in = size - LZMA_HEADER_SIZE;
   2.579 -+
   2.580 -+	res = lzma_code(&strm, LZMA_FINISH);
   2.581 -+	lzma_end(&strm);
   2.582 -+
   2.583 -+	if(res == LZMA_STREAM_END || (res == LZMA_OK &&
   2.584 -+		strm.total_out >= uncompressed_size && strm.avail_in == 0))
   2.585 -+		return uncompressed_size;
   2.586 -+
   2.587 -+failed:
   2.588 -+	*error = res;
   2.589 -+	return -1;
   2.590 -+}
   2.591 -+
   2.592 -+
   2.593 -+struct compressor lzma_comp_ops = {
   2.594 -+	.init = NULL,
   2.595 -+	.compress = lzma_compress,
   2.596 -+	.uncompress = lzma_uncompress,
   2.597 -+	.options = NULL,
   2.598 -+	.usage = NULL,
   2.599 -+	.id = LZMA_COMPRESSION,
   2.600 -+	.name = "lzma",
   2.601 -+	.supported = 1
   2.602 -+};
   2.603 -+
   2.604 -diff -r 2ab2996036dd squashfs-tools/lzo_wrapper.c
   2.605 ---- a/squashfs-tools/lzo_wrapper.c	Tue Dec 14 12:19:33 2010 +0000
   2.606 -+++ b/squashfs-tools/lzo_wrapper.c	Tue Dec 14 14:18:11 2010 +0000
   2.607 -@@ -2,6 +2,9 @@
   2.608 -  * Copyright (c) 2010 LG Electronics
   2.609 -  * Chan Jeong <chan.jeong@lge.com>
   2.610 -  *
   2.611 -+ * All modifications Copyright (c) 2010
   2.612 -+ * Phillip Lougher <phillip@lougher.demon.co.uk>
   2.613 -+ *
   2.614 -  * This program is free software; you can redistribute it and/or
   2.615 -  * modify it under the terms of the GNU General Public License
   2.616 -  * as published by the Free Software Foundation; either version 2,
   2.617 -@@ -25,6 +28,9 @@
   2.618 - #include <lzo/lzoconf.h>
   2.619 - #include <lzo/lzo1x.h>
   2.620 - 
   2.621 -+#include "squashfs_fs.h"
   2.622 -+#include "compressor.h"
   2.623 -+
   2.624 - /* worst-case expansion calculation during compression,
   2.625 -    see LZO FAQ for more information */
   2.626 - #define LZO_OUTPUT_BUFFER_SIZE(size)	(size + (size/16) + 64 + 3)
   2.627 -@@ -34,25 +40,39 @@
   2.628 - 	lzo_bytep out;
   2.629 - };
   2.630 - 
   2.631 --int lzo_compress(void **strm, char *d, char *s, int size, int block_size,
   2.632 -+
   2.633 -+static int squashfs_lzo_init(void **strm, int block_size, int flags)
   2.634 -+{
   2.635 -+	struct lzo_stream *stream;
   2.636 -+
   2.637 -+	if((stream = *strm = malloc(sizeof(struct lzo_stream))) == NULL)
   2.638 -+		goto failed;
   2.639 -+	/* work memory for compression */
   2.640 -+	if((stream->wrkmem = malloc(LZO1X_999_MEM_COMPRESS)) == NULL)
   2.641 -+		goto failed2;
   2.642 -+	/* temporal output buffer */
   2.643 -+	if((stream->out = malloc(LZO_OUTPUT_BUFFER_SIZE(block_size))) == NULL)
   2.644 -+		goto failed3;
   2.645 -+
   2.646 -+	return 0;
   2.647 -+
   2.648 -+failed3:
   2.649 -+	free(stream->wrkmem);
   2.650 -+failed2:
   2.651 -+	free(stream);
   2.652 -+failed:
   2.653 -+	return -1;
   2.654 -+}
   2.655 -+
   2.656 -+
   2.657 -+static int lzo_compress(void *strm, void *d, void *s, int size, int block_size,
   2.658 - 		int *error)
   2.659 - {
   2.660 --	int res = 0;
   2.661 -+	int res;
   2.662 - 	lzo_uint outlen;
   2.663 --	struct lzo_stream *stream = *strm;
   2.664 -+	struct lzo_stream *stream = strm;
   2.665 - 
   2.666 --	if(stream == NULL) {
   2.667 --		if((stream = *strm = malloc(sizeof(struct lzo_stream))) == NULL)
   2.668 --			goto failed;
   2.669 --		/* work memory for compression */
   2.670 --		if((stream->wrkmem = malloc(LZO1X_999_MEM_COMPRESS)) == NULL)
   2.671 --			goto failed;
   2.672 --		/* temporal output buffer */
   2.673 --		if((stream->out = malloc(LZO_OUTPUT_BUFFER_SIZE(block_size))) == NULL)
   2.674 --			goto failed;
   2.675 --	}
   2.676 --
   2.677 --	res = lzo1x_999_compress((lzo_bytep)s, size, stream->out, &outlen, stream->wrkmem);
   2.678 -+	res = lzo1x_999_compress(s, size, stream->out, &outlen, stream->wrkmem);
   2.679 - 	if(res != LZO_E_OK)
   2.680 - 		goto failed;
   2.681 - 	if(outlen >= size)
   2.682 -@@ -77,13 +97,26 @@
   2.683 - }
   2.684 - 
   2.685 - 
   2.686 --int lzo_uncompress(char *d, char *s, int size, int block_size, int *error)
   2.687 -+static int lzo_uncompress(void *d, void *s, int size, int block_size, int *error)
   2.688 - {
   2.689 - 	int res;
   2.690 - 	lzo_uint bytes = block_size;
   2.691 - 
   2.692 --	res = lzo1x_decompress_safe((lzo_bytep)s, size, (lzo_bytep)d, &bytes, NULL);
   2.693 -+	res = lzo1x_decompress_safe(s, size, d, &bytes, NULL);
   2.694 - 
   2.695 - 	*error = res;
   2.696 - 	return res == LZO_E_OK ? bytes : -1;
   2.697 - }
   2.698 -+
   2.699 -+
   2.700 -+struct compressor lzo_comp_ops = {
   2.701 -+	.init = squashfs_lzo_init,
   2.702 -+	.compress = lzo_compress,
   2.703 -+	.uncompress = lzo_uncompress,
   2.704 -+	.options = NULL,
   2.705 -+	.usage = NULL,
   2.706 -+	.id = LZO_COMPRESSION,
   2.707 -+	.name = "lzo",
   2.708 -+	.supported = 1
   2.709 -+};
   2.710 -+
   2.711 -diff -r 2ab2996036dd squashfs-tools/mksquashfs.c
   2.712 ---- a/squashfs-tools/mksquashfs.c	Tue Dec 14 12:19:33 2010 +0000
   2.713 -+++ b/squashfs-tools/mksquashfs.c	Tue Dec 14 14:18:11 2010 +0000
   2.714 -@@ -384,9 +384,10 @@
   2.715 - #define FRAGMENT_BUFFER_DEFAULT 64
   2.716 - int writer_buffer_size;
   2.717 - 
   2.718 --/* compression operations structure */
   2.719 -+/* compression operations */
   2.720 - static struct compressor *comp;
   2.721 --char *comp_name = COMP_DEFAULT;
   2.722 -+int compressor_opts_parsed = 0;
   2.723 -+void *stream = NULL;
   2.724 - 
   2.725 - /* xattr stats */
   2.726 - unsigned int xattr_bytes = 0, total_xattr_bytes = 0;
   2.727 -@@ -859,7 +860,7 @@
   2.728 - }
   2.729 - 
   2.730 - 
   2.731 --int mangle2(void **strm, char *d, char *s, int size,
   2.732 -+int mangle2(void *strm, char *d, char *s, int size,
   2.733 - 	int block_size, int uncompressed, int data_block)
   2.734 - {
   2.735 - 	int error, c_byte = 0;
   2.736 -@@ -884,9 +885,7 @@
   2.737 - int mangle(char *d, char *s, int size, int block_size,
   2.738 - 	int uncompressed, int data_block)
   2.739 - {
   2.740 --	static void *stream = NULL;
   2.741 --
   2.742 --	return mangle2(&stream, d, s, size, block_size, uncompressed,
   2.743 -+	return mangle2(stream, d, s, size, block_size, uncompressed,
   2.744 - 		data_block);
   2.745 - }
   2.746 - 
   2.747 -@@ -2556,11 +2555,15 @@
   2.748 - void *deflator(void *arg)
   2.749 - {
   2.750 - 	void *stream = NULL;
   2.751 --	int oldstate;
   2.752 -+	int res, oldstate;
   2.753 - 
   2.754 - 	pthread_setcancelstate(PTHREAD_CANCEL_ENABLE, &oldstate);
   2.755 - 	pthread_setcanceltype(PTHREAD_CANCEL_ASYNCHRONOUS, &oldstate);
   2.756 - 
   2.757 -+	res = compressor_init(comp, &stream, block_size, 1);
   2.758 -+	if(res)
   2.759 -+		BAD_ERROR("deflator:: compressor_init failed\n");
   2.760 -+
   2.761 - 	while(1) {
   2.762 - 		struct file_buffer *file_buffer = queue_get(from_reader);
   2.763 - 		struct file_buffer *write_buffer;
   2.764 -@@ -2573,7 +2576,7 @@
   2.765 - 			queue_put(from_deflate, file_buffer);
   2.766 - 		} else {
   2.767 - 			write_buffer = cache_get(writer_buffer, 0, 0);
   2.768 --			write_buffer->c_byte = mangle2(&stream,
   2.769 -+			write_buffer->c_byte = mangle2(stream,
   2.770 - 				write_buffer->data, file_buffer->data,
   2.771 - 				file_buffer->size, block_size, noD, 1);
   2.772 - 			write_buffer->sequence = file_buffer->sequence;
   2.773 -@@ -2593,11 +2596,15 @@
   2.774 - void *frag_deflator(void *arg)
   2.775 - {
   2.776 - 	void *stream = NULL;
   2.777 --	int oldstate;
   2.778 -+	int res, oldstate;
   2.779 - 
   2.780 - 	pthread_setcancelstate(PTHREAD_CANCEL_ENABLE, &oldstate);
   2.781 - 	pthread_setcanceltype(PTHREAD_CANCEL_ASYNCHRONOUS, &oldstate);
   2.782 - 
   2.783 -+	res = compressor_init(comp, &stream, block_size, 1);
   2.784 -+	if(res)
   2.785 -+		BAD_ERROR("frag_deflator:: compressor_init failed\n");
   2.786 -+
   2.787 - 	while(1) {
   2.788 - 		int c_byte, compressed_size;
   2.789 - 		struct file_buffer *file_buffer = queue_get(to_frag);
   2.790 -@@ -2605,7 +2612,7 @@
   2.791 - 			cache_get(writer_buffer, file_buffer->block +
   2.792 - 			FRAG_INDEX, 1);
   2.793 - 
   2.794 --		c_byte = mangle2(&stream, write_buffer->data, file_buffer->data,
   2.795 -+		c_byte = mangle2(stream, write_buffer->data, file_buffer->data,
   2.796 - 			file_buffer->size, block_size, noF, 1);
   2.797 - 		compressed_size = SQUASHFS_COMPRESSED_SIZE_BLOCK(c_byte);
   2.798 - 		write_buffer->size = compressed_size;
   2.799 -@@ -4501,7 +4508,7 @@
   2.800 - 
   2.801 - 
   2.802 - #define VERSION() \
   2.803 --	printf("mksquashfs version 4.1 (2010/09/19)\n");\
   2.804 -+	printf("mksquashfs version 4.1-CVS (2010/12/07)\n");\
   2.805 - 	printf("copyright (C) 2010 Phillip Lougher "\
   2.806 - 		"<phillip@lougher.demon.co.uk>\n\n"); \
   2.807 - 	printf("This program is free software; you can redistribute it and/or"\
   2.808 -@@ -4521,7 +4528,7 @@
   2.809 - int main(int argc, char *argv[])
   2.810 - {
   2.811 - 	struct stat buf, source_buf;
   2.812 --	int i;
   2.813 -+	int res, i;
   2.814 - 	squashfs_super_block sBlk;
   2.815 - 	char *b, *root_name = NULL;
   2.816 - 	int nopad = FALSE, keep_as_directory = FALSE;
   2.817 -@@ -4542,14 +4549,50 @@
   2.818 - 		goto printOptions;
   2.819 - 	source_path = argv + 1;
   2.820 - 	source = i - 2;
   2.821 -+	/*
   2.822 -+	 * lookup default compressor.  Note the Makefile ensures the default
   2.823 -+	 * compressor has been built, and so we don't need to to check
   2.824 -+	 * for failure here
   2.825 -+	 */
   2.826 -+	comp = lookup_compressor(COMP_DEFAULT);
   2.827 - 	for(; i < argc; i++) {
   2.828 - 		if(strcmp(argv[i], "-comp") == 0) {
   2.829 -+			if(compressor_opts_parsed) {
   2.830 -+				ERROR("%s: -comp must appear before -X options"
   2.831 -+					"\n", argv[0]);
   2.832 -+				exit(1);
   2.833 -+			}
   2.834 - 			if(++i == argc) {
   2.835 - 				ERROR("%s: -comp missing compression type\n",
   2.836 - 					argv[0]);
   2.837 - 				exit(1);
   2.838 - 			}
   2.839 --			comp_name = argv[i];
   2.840 -+			comp = lookup_compressor(argv[i]);
   2.841 -+			if(!comp->supported) {
   2.842 -+				ERROR("%s: Compressor \"%s\" is not supported!"
   2.843 -+					"\n", argv[0], argv[i]);
   2.844 -+				ERROR("%s: Compressors available:\n", argv[0]);
   2.845 -+				display_compressors("", COMP_DEFAULT);
   2.846 -+				exit(1);
   2.847 -+			}
   2.848 -+
   2.849 -+		} else if(strncmp(argv[i], "-X", 2) == 0) {
   2.850 -+			int args = compressor_options(comp, argv + i, argc - i);
   2.851 -+			if(args < 0) {
   2.852 -+				if(args == -1) {
   2.853 -+					ERROR("%s: Unrecognised compressor"
   2.854 -+						" option %s\n", argv[0],
   2.855 -+						argv[i]);
   2.856 -+					ERROR("%s: Did you forget to specify"
   2.857 -+						" -comp, or specify it after"
   2.858 -+						" the compressor specific"
   2.859 -+						" option?\n", argv[0]);
   2.860 -+					}
   2.861 -+				exit(1);
   2.862 -+			}
   2.863 -+			i += args;
   2.864 -+			compressor_opts_parsed = 1;
   2.865 -+
   2.866 - 		} else if(strcmp(argv[i], "-pf") == 0) {
   2.867 - 			if(++i == argc) {
   2.868 - 				ERROR("%s: -pf missing filename\n", argv[0]);
   2.869 -@@ -4857,7 +4900,7 @@
   2.870 - 			ERROR("-write-queue <size>\tSet output queue to <size> "
   2.871 - 				"Mbytes.  Default %d Mbytes\n",
   2.872 - 				WRITER_BUFFER_DEFAULT);
   2.873 --			ERROR("-fragment-queue <size>\tSet fagment queue to "
   2.874 -+			ERROR("-fragment-queue <size>\tSet fragment queue to "
   2.875 - 				"<size> Mbytes.  Default %d Mbytes\n",
   2.876 - 				FRAGMENT_BUFFER_DEFAULT);
   2.877 - 			ERROR("\nMiscellaneous options:\n");
   2.878 -@@ -4871,8 +4914,9 @@
   2.879 - 				"-noF\n");
   2.880 - 			ERROR("-noXattrCompression\talternative name for "
   2.881 - 				"-noX\n");
   2.882 --			ERROR("\nCompressors available:\n");
   2.883 --			display_compressors("", COMP_DEFAULT);
   2.884 -+			ERROR("\nCompressors available and compressor specific "
   2.885 -+				"options:\n");
   2.886 -+			display_compressor_usage(COMP_DEFAULT);
   2.887 - 			exit(1);
   2.888 - 		}
   2.889 - 	}
   2.890 -@@ -5005,19 +5049,14 @@
   2.891 - 		always_use_fragments = SQUASHFS_ALWAYS_FRAGMENTS(sBlk.flags);
   2.892 - 		duplicate_checking = SQUASHFS_DUPLICATES(sBlk.flags);
   2.893 - 		exportable = SQUASHFS_EXPORTABLE(sBlk.flags);
   2.894 --	} else {
   2.895 --		comp = lookup_compressor(comp_name);
   2.896 --		if(!comp->supported) {
   2.897 --			ERROR("FATAL_ERROR: Compressor \"%s\" is not "
   2.898 --				"supported!\n", comp_name);
   2.899 --			ERROR("Compressors available:\n");
   2.900 --			display_compressors("", COMP_DEFAULT);
   2.901 --			EXIT_MKSQUASHFS();
   2.902 --		}
   2.903 - 	}
   2.904 - 
   2.905 - 	initialise_threads(readb_mbytes, writeb_mbytes, fragmentb_mbytes);
   2.906 - 
   2.907 -+	res = compressor_init(comp, &stream, SQUASHFS_METADATA_SIZE, 0);
   2.908 -+	if(res)
   2.909 -+		BAD_ERROR("compressor_init failed\n");
   2.910 -+
   2.911 - 	if(delete) {
   2.912 - 		printf("Creating %d.%d filesystem on %s, block size %d.\n",
   2.913 - 			SQUASHFS_MAJOR, s_minor, argv[source + 1], block_size);
   2.914 -diff -r 2ab2996036dd squashfs-tools/read_fs.c
   2.915 ---- a/squashfs-tools/read_fs.c	Tue Dec 14 12:19:33 2010 +0000
   2.916 -+++ b/squashfs-tools/read_fs.c	Tue Dec 14 14:18:11 2010 +0000
   2.917 -@@ -363,7 +363,8 @@
   2.918 - 		}
   2.919 - 	}
   2.920 - 	
   2.921 --	return files;
   2.922 -+	printf("Read existing filesystem, %d inodes scanned\n", files);
   2.923 -+	return TRUE;
   2.924 - 
   2.925 - 
   2.926 - failed:
   2.927 -@@ -414,6 +415,7 @@
   2.928 - 	if(!comp->supported) {
   2.929 - 		ERROR("Filesystem on %s uses %s compression, this is"
   2.930 - 			"unsupported by this version\n", source, comp->name);
   2.931 -+		ERROR("Compressors available:\n");
   2.932 - 		display_compressors("", "");
   2.933 - 		goto failed_mount;
   2.934 - 	}
   2.935 -@@ -691,7 +693,7 @@
   2.936 - 		SQUASHFS_INODE_BLK(sBlk->root_inode);
   2.937 - 	unsigned int root_inode_offset =
   2.938 - 		SQUASHFS_INODE_OFFSET(sBlk->root_inode);
   2.939 --	unsigned int root_inode_block, files;
   2.940 -+	unsigned int root_inode_block;
   2.941 - 	squashfs_inode_header inode;
   2.942 - 	unsigned int *id_table;
   2.943 - 	int res;
   2.944 -@@ -711,20 +713,18 @@
   2.945 - 	if(id_table == NULL)
   2.946 - 		goto error;
   2.947 - 
   2.948 --	if((files = scan_inode_table(fd, start, end, root_inode_start,
   2.949 --			root_inode_offset, sBlk, &inode, &inode_table,
   2.950 --			&root_inode_block, root_inode_size, uncompressed_file,
   2.951 --			uncompressed_directory, file_count, sym_count,
   2.952 --			dev_count, dir_count, fifo_count, sock_count, id_table))
   2.953 --			== 0) {
   2.954 -+	res = scan_inode_table(fd, start, end, root_inode_start,
   2.955 -+		root_inode_offset, sBlk, &inode, &inode_table,
   2.956 -+		&root_inode_block, root_inode_size, uncompressed_file,
   2.957 -+		uncompressed_directory, file_count, sym_count, dev_count,
   2.958 -+		dir_count, fifo_count, sock_count, id_table);
   2.959 -+	if(res == 0) {
   2.960 - 		ERROR("read_filesystem: inode table read failed\n");
   2.961 - 		goto error;
   2.962 - 	}
   2.963 - 
   2.964 - 	*uncompressed_inode = root_inode_block;
   2.965 - 
   2.966 --	printf("Read existing filesystem, %d inodes scanned\n", files);
   2.967 --
   2.968 - 	if(inode.base.inode_type == SQUASHFS_DIR_TYPE ||
   2.969 - 			inode.base.inode_type == SQUASHFS_LDIR_TYPE) {
   2.970 - 		if(inode.base.inode_type == SQUASHFS_DIR_TYPE) {
   2.971 -diff -r 2ab2996036dd squashfs-tools/squashfs_fs.h
   2.972 ---- a/squashfs-tools/squashfs_fs.h	Tue Dec 14 12:19:33 2010 +0000
   2.973 -+++ b/squashfs-tools/squashfs_fs.h	Tue Dec 14 14:18:11 2010 +0000
   2.974 -@@ -259,6 +259,7 @@
   2.975 - #define ZLIB_COMPRESSION	1
   2.976 - #define LZMA_COMPRESSION	2
   2.977 - #define LZO_COMPRESSION		3
   2.978 -+#define XZ_COMPRESSION		4
   2.979 - 
   2.980 - struct squashfs_super_block {
   2.981 - 	unsigned int		s_magic;
   2.982 -diff -r 2ab2996036dd squashfs-tools/unsquash-1.c
   2.983 ---- a/squashfs-tools/unsquash-1.c	Tue Dec 14 12:19:33 2010 +0000
   2.984 -+++ b/squashfs-tools/unsquash-1.c	Tue Dec 14 14:18:11 2010 +0000
   2.985 -@@ -138,7 +138,7 @@
   2.986 - 
   2.987 - 			i.data = inode->file_size;
   2.988 - 			i.time = inode->mtime;
   2.989 --			i.blocks = (inode->file_size + sBlk.s.block_size - 1) >>
   2.990 -+			i.blocks = (i.data + sBlk.s.block_size - 1) >>
   2.991 - 				sBlk.s.block_log;
   2.992 - 			i.start = inode->start_block;
   2.993 - 			i.block_ptr = block_ptr + sizeof(*inode);
   2.994 -diff -r 2ab2996036dd squashfs-tools/unsquash-2.c
   2.995 ---- a/squashfs-tools/unsquash-2.c	Tue Dec 14 12:19:33 2010 +0000
   2.996 -+++ b/squashfs-tools/unsquash-2.c	Tue Dec 14 14:18:11 2010 +0000
   2.997 -@@ -205,8 +205,8 @@
   2.998 - 			i.fragment = inode->fragment;
   2.999 - 			i.offset = inode->offset;
  2.1000 - 			i.blocks = inode->fragment == SQUASHFS_INVALID_FRAG ?
  2.1001 --				(inode->file_size + sBlk.s.block_size - 1) >>
  2.1002 --				sBlk.s.block_log : inode->file_size >>
  2.1003 -+				(i.data + sBlk.s.block_size - 1) >>
  2.1004 -+				sBlk.s.block_log : i.data >>
  2.1005 - 				sBlk.s.block_log;
  2.1006 - 			i.start = inode->start_block;
  2.1007 - 			i.sparse = 0;
  2.1008 -diff -r 2ab2996036dd squashfs-tools/unsquash-3.c
  2.1009 ---- a/squashfs-tools/unsquash-3.c	Tue Dec 14 12:19:33 2010 +0000
  2.1010 -+++ b/squashfs-tools/unsquash-3.c	Tue Dec 14 14:18:11 2010 +0000
  2.1011 -@@ -188,9 +188,9 @@
  2.1012 - 			i.fragment = inode->fragment;
  2.1013 - 			i.offset = inode->offset;
  2.1014 - 			i.blocks = inode->fragment == SQUASHFS_INVALID_FRAG ?
  2.1015 --				(inode->file_size + sBlk.s.block_size - 1) >>
  2.1016 -+				(i.data + sBlk.s.block_size - 1) >>
  2.1017 - 				sBlk.s.block_log :
  2.1018 --				inode->file_size >> sBlk.s.block_log;
  2.1019 -+				i.data >> sBlk.s.block_log;
  2.1020 - 			i.start = inode->start_block;
  2.1021 - 			i.sparse = 1;
  2.1022 - 			i.block_ptr = block_ptr + sizeof(*inode);
  2.1023 -diff -r 2ab2996036dd squashfs-tools/unsquash-4.c
  2.1024 ---- a/squashfs-tools/unsquash-4.c	Tue Dec 14 12:19:33 2010 +0000
  2.1025 -+++ b/squashfs-tools/unsquash-4.c	Tue Dec 14 14:18:11 2010 +0000
  2.1026 -@@ -143,9 +143,9 @@
  2.1027 - 			i.fragment = inode->fragment;
  2.1028 - 			i.offset = inode->offset;
  2.1029 - 			i.blocks = inode->fragment == SQUASHFS_INVALID_FRAG ?
  2.1030 --				(inode->file_size + sBlk.s.block_size - 1) >>
  2.1031 -+				(i.data + sBlk.s.block_size - 1) >>
  2.1032 - 				sBlk.s.block_log :
  2.1033 --				inode->file_size >> sBlk.s.block_log;
  2.1034 -+				i.data >> sBlk.s.block_log;
  2.1035 - 			i.start = inode->start_block;
  2.1036 - 			i.sparse = 0;
  2.1037 - 			i.block_ptr = block_ptr + sizeof(*inode);
  2.1038 -diff -r 2ab2996036dd squashfs-tools/unsquashfs.c
  2.1039 ---- a/squashfs-tools/unsquashfs.c	Tue Dec 14 12:19:33 2010 +0000
  2.1040 -+++ b/squashfs-tools/unsquashfs.c	Tue Dec 14 14:18:11 2010 +0000
  2.1041 -@@ -737,7 +737,7 @@
  2.1042 - int lseek_broken = FALSE;
  2.1043 - char *zero_data = NULL;
  2.1044 - 
  2.1045 --int write_block(int file_fd, char *buffer, int size, int hole, int sparse)
  2.1046 -+int write_block(int file_fd, char *buffer, int size, long long hole, int sparse)
  2.1047 - {
  2.1048 - 	off_t off = hole;
  2.1049 - 
  2.1050 -@@ -1299,9 +1299,12 @@
  2.1051 - 		print_filename(parent_name, i);
  2.1052 - 
  2.1053 - 	if(!lsonly && mkdir(parent_name, (mode_t) dir->mode) == -1 &&
  2.1054 --			(!force || errno != EEXIST))
  2.1055 --		ERROR("dir_scan: failed to open directory %s, because %s\n",
  2.1056 -+			(!force || errno != EEXIST)) {
  2.1057 -+		ERROR("dir_scan: failed to make directory %s, because %s\n",
  2.1058 - 			parent_name, strerror(errno));
  2.1059 -+		squashfs_closedir(dir);
  2.1060 -+		return;
  2.1061 -+	}
  2.1062 - 
  2.1063 - 	while(squashfs_readdir(dir, &name, &start_block, &offset, &type)) {
  2.1064 - 		TRACE("dir_scan: name %s, start_block %d, offset %d, type %d\n",
  2.1065 -@@ -1604,7 +1607,7 @@
  2.1066 - 	while(1) {
  2.1067 - 		struct squashfs_file *file = queue_get(to_writer);
  2.1068 - 		int file_fd;
  2.1069 --		int hole = 0;
  2.1070 -+		long long hole = 0;
  2.1071 - 		int failed = FALSE;
  2.1072 - 		int error;
  2.1073 - 
  2.1074 -@@ -1903,7 +1906,7 @@
  2.1075 - 
  2.1076 - 
  2.1077 - #define VERSION() \
  2.1078 --	printf("unsquashfs version 4.1 (2010/09/19)\n");\
  2.1079 -+	printf("unsquashfs version 4.1-CVS (2010/10/23)\n");\
  2.1080 - 	printf("copyright (C) 2010 Phillip Lougher "\
  2.1081 - 		"<phillip@lougher.demon.co.uk>\n\n");\
  2.1082 -     	printf("This program is free software; you can redistribute it and/or"\
  2.1083 -@@ -2081,7 +2084,7 @@
  2.1084 - 			ERROR("\t-da[ta-queue] <size>\tSet data queue to "
  2.1085 - 				"<size> Mbytes.  Default %d\n\t\t\t\tMbytes\n",
  2.1086 - 				DATA_BUFFER_DEFAULT);
  2.1087 --			ERROR("\t-fr[ag-queue] <size>\tSet fagment queue to "
  2.1088 -+			ERROR("\t-fr[ag-queue] <size>\tSet fragment queue to "
  2.1089 - 				"<size> Mbytes.  Default %d\n\t\t\t\t Mbytes\n",
  2.1090 - 				FRAGMENT_BUFFER_DEFAULT);
  2.1091 - 			ERROR("\t-r[egex]\t\ttreat extract names as POSIX "
  2.1092 -diff -r 2ab2996036dd squashfs-tools/unsquashfs_xattr.c
  2.1093 ---- a/squashfs-tools/unsquashfs_xattr.c	Tue Dec 14 12:19:33 2010 +0000
  2.1094 -+++ b/squashfs-tools/unsquashfs_xattr.c	Tue Dec 14 14:18:11 2010 +0000
  2.1095 -@@ -25,7 +25,7 @@
  2.1096 - #include "unsquashfs.h"
  2.1097 - #include "xattr.h"
  2.1098 - 
  2.1099 --#include <attr/xattr.h>
  2.1100 -+#include <sys/xattr.h>
  2.1101 - 
  2.1102 - extern int root_process;
  2.1103 - 
  2.1104 -diff -r 2ab2996036dd squashfs-tools/xattr.c
  2.1105 ---- a/squashfs-tools/xattr.c	Tue Dec 14 12:19:33 2010 +0000
  2.1106 -+++ b/squashfs-tools/xattr.c	Tue Dec 14 14:18:11 2010 +0000
  2.1107 -@@ -34,7 +34,7 @@
  2.1108 - #include <dirent.h>
  2.1109 - #include <string.h>
  2.1110 - #include <stdlib.h>
  2.1111 --#include <attr/xattr.h>
  2.1112 -+#include <sys/xattr.h>
  2.1113 - 
  2.1114 - #include "squashfs_fs.h"
  2.1115 - #include "global.h"
  2.1116 -@@ -219,6 +219,10 @@
  2.1117 - 			break;
  2.1118 - 		}
  2.1119 - 		xattr_list[i].vsize = vsize;
  2.1120 -+
  2.1121 -+		TRACE("read_xattrs_from_system: filename %s, xattr name %s,"
  2.1122 -+			" vsize %d\n", filename, xattr_list[i].full_name,
  2.1123 -+			xattr_list[i].vsize);
  2.1124 - 	}
  2.1125 - 	free(xattr_names);
  2.1126 - 	*xattrs = xattr_list;
  2.1127 -diff -r 2ab2996036dd squashfs-tools/xz_wrapper.c
  2.1128 ---- a/squashfs-tools/xz_wrapper.c	Tue Dec 14 12:19:33 2010 +0000
  2.1129 -+++ b/squashfs-tools/xz_wrapper.c	Tue Dec 14 14:18:11 2010 +0000
  2.1130 -@@ -17,69 +17,192 @@
  2.1131 -  * Foundation, 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
  2.1132 -  *
  2.1133 -  * xz_wrapper.c
  2.1134 -+ *
  2.1135 -+ * Support for XZ (LZMA2) compression using XZ Utils liblzma http://tukaani.org/xz/
  2.1136 -  */
  2.1137 - 
  2.1138 - #include <stdio.h>
  2.1139 - #include <string.h>
  2.1140 -+#include <stdlib.h>
  2.1141 - #include <lzma.h>
  2.1142 - 
  2.1143 --#define LZMA_PROPS_SIZE 5
  2.1144 --#define LZMA_UNCOMP_SIZE 8
  2.1145 --#define LZMA_HEADER_SIZE (LZMA_PROPS_SIZE + LZMA_UNCOMP_SIZE)
  2.1146 -+#include "squashfs_fs.h"
  2.1147 -+#include "compressor.h"
  2.1148 - 
  2.1149 --#define LZMA_OPTIONS 5
  2.1150 - #define MEMLIMIT (32 * 1024 * 1024)
  2.1151 - 
  2.1152 --int lzma_compress(void **dummy, void *dest, void *src,  int size,
  2.1153 -+static struct bcj {
  2.1154 -+	char	 	*name;
  2.1155 -+	lzma_vli	id;
  2.1156 -+	int		selected;
  2.1157 -+} bcj[] = {
  2.1158 -+	{ "x86", LZMA_FILTER_X86, 0 },
  2.1159 -+	{ "powerpc", LZMA_FILTER_POWERPC, 0 },
  2.1160 -+	{ "ia64", LZMA_FILTER_IA64, 0 },
  2.1161 -+	{ "arm", LZMA_FILTER_ARM, 0 },
  2.1162 -+	{ "armthumb", LZMA_FILTER_ARMTHUMB, 0 },
  2.1163 -+	{ "sparc", LZMA_FILTER_SPARC, 0 },
  2.1164 -+	{ NULL, LZMA_VLI_UNKNOWN, 0 }
  2.1165 -+};
  2.1166 -+
  2.1167 -+struct filter {
  2.1168 -+	void		*buffer;
  2.1169 -+	lzma_filter	filter[3];
  2.1170 -+	size_t		length;
  2.1171 -+};
  2.1172 -+
  2.1173 -+struct xz_stream {
  2.1174 -+	struct filter	*filter;
  2.1175 -+	int		filters;
  2.1176 -+	lzma_options_lzma opt;
  2.1177 -+};
  2.1178 -+
  2.1179 -+static int filter_count = 1;
  2.1180 -+
  2.1181 -+
  2.1182 -+static int xz_options(char *argv[], int argc)
  2.1183 -+{
  2.1184 -+	int i;
  2.1185 -+	char *name;
  2.1186 -+
  2.1187 -+	if(strcmp(argv[0], "-Xbcj") == 0) {
  2.1188 -+		if(argc < 2) {
  2.1189 -+			fprintf(stderr, "xz: -Xbcj missing filter\n");
  2.1190 -+			goto failed;
  2.1191 -+		}
  2.1192 -+
  2.1193 -+		name = argv[1];
  2.1194 -+		while(name[0] != '\0') {
  2.1195 -+			for(i = 0; bcj[i].name; i++) {
  2.1196 -+				int n = strlen(bcj[i].name);
  2.1197 -+				if((strncmp(name, bcj[i].name, n) == 0) &&
  2.1198 -+						(name[n] == '\0' ||
  2.1199 -+						 name[n] == ',')) {
  2.1200 -+					if(bcj[i].selected == 0) {
  2.1201 -+				 		bcj[i].selected = 1;
  2.1202 -+						filter_count++;
  2.1203 -+					}
  2.1204 -+					name += name[n] == ',' ? n + 1 : n;
  2.1205 -+					break;
  2.1206 -+				}
  2.1207 -+			}
  2.1208 -+			if(bcj[i].name == NULL) {
  2.1209 -+				fprintf(stderr, "xz: -Xbcj unrecognised filter\n");
  2.1210 -+				goto failed;
  2.1211 -+			}
  2.1212 -+		}
  2.1213 -+	
  2.1214 -+		return 1;
  2.1215 -+	}
  2.1216 -+
  2.1217 -+	return -1;
  2.1218 -+	
  2.1219 -+failed:
  2.1220 -+	return -2;
  2.1221 -+}
  2.1222 -+		
  2.1223 -+
  2.1224 -+void xz_usage()
  2.1225 -+{
  2.1226 -+	fprintf(stderr, "\t  -Xbcj filter1,filter2,...,filterN\n");
  2.1227 -+	fprintf(stderr, "\t\tCompress using filter1,filter2,...,filterN in");
  2.1228 -+	fprintf(stderr, " turn\n\t\t(in addition to no filter), and choose");
  2.1229 -+	fprintf(stderr, " the best compression.\n");
  2.1230 -+	fprintf(stderr, "\t\tAvailable filters: x86, arm, armthumb,");
  2.1231 -+	fprintf(stderr, " powerpc, sparc, ia64\n");
  2.1232 -+}
  2.1233 -+
  2.1234 -+
  2.1235 -+static int xz_init(void **strm, int block_size, int flags)
  2.1236 -+{
  2.1237 -+	int i, j, filters = flags ? filter_count : 1;
  2.1238 -+	struct filter *filter = malloc(filters * sizeof(struct filter));
  2.1239 -+	struct xz_stream *stream;
  2.1240 -+
  2.1241 -+	if(filter == NULL)
  2.1242 -+		goto failed;
  2.1243 -+
  2.1244 -+	stream = *strm = malloc(sizeof(struct xz_stream));
  2.1245 -+	if(stream == NULL)
  2.1246 -+		goto failed2;
  2.1247 -+
  2.1248 -+	stream->filter = filter;
  2.1249 -+	stream->filters = filters;
  2.1250 -+
  2.1251 -+	memset(filter, 0, filters * sizeof(struct filter));
  2.1252 -+
  2.1253 -+	filter[0].filter[0].id = LZMA_FILTER_LZMA2;
  2.1254 -+	filter[0].filter[0].options = &stream->opt;
  2.1255 -+	filter[0].filter[1].id = LZMA_VLI_UNKNOWN;
  2.1256 -+
  2.1257 -+	for(i = 0, j = 1; flags && bcj[i].name; i++) {
  2.1258 -+		if(bcj[i].selected) {
  2.1259 -+			filter[j].buffer = malloc(block_size);
  2.1260 -+			if(filter[j].buffer == NULL)
  2.1261 -+				goto failed3;
  2.1262 -+			filter[j].filter[0].id = bcj[i].id;
  2.1263 -+			filter[j].filter[1].id = LZMA_FILTER_LZMA2;
  2.1264 -+			filter[j].filter[1].options = &stream->opt;
  2.1265 -+			filter[j].filter[2].id = LZMA_VLI_UNKNOWN;
  2.1266 -+			j++;
  2.1267 -+		}
  2.1268 -+	}
  2.1269 -+
  2.1270 -+	return 0;
  2.1271 -+
  2.1272 -+failed3:
  2.1273 -+	for(i = 1; i < filters; i++)
  2.1274 -+		free(filter[i].buffer);
  2.1275 -+	free(stream);
  2.1276 -+
  2.1277 -+failed2:
  2.1278 -+	free(filter);
  2.1279 -+
  2.1280 -+failed:
  2.1281 -+	return -1;
  2.1282 -+}
  2.1283 -+
  2.1284 -+
  2.1285 -+static int xz_compress(void *strm, void *dest, void *src,  int size,
  2.1286 - 	int block_size, int *error)
  2.1287 - {
  2.1288 --	unsigned char *d = (unsigned char *) dest;
  2.1289 --	lzma_options_lzma opt;
  2.1290 --	lzma_stream strm = LZMA_STREAM_INIT;
  2.1291 --	int res;
  2.1292 -+	int i;
  2.1293 -+        lzma_ret res = 0;
  2.1294 -+	struct xz_stream *stream = strm;
  2.1295 -+	struct filter *selected = NULL;
  2.1296 - 
  2.1297 --	lzma_lzma_preset(&opt, LZMA_OPTIONS);
  2.1298 --	opt.dict_size = block_size;
  2.1299 --	res = lzma_alone_encoder(&strm, &opt);
  2.1300 --	if(res != LZMA_OK) {
  2.1301 --		lzma_end(&strm);
  2.1302 --		goto failed;
  2.1303 -+	stream->filter[0].buffer = dest;
  2.1304 -+
  2.1305 -+	for(i = 0; i < stream->filters; i++) {
  2.1306 -+		struct filter *filter = &stream->filter[i];
  2.1307 -+
  2.1308 -+        	if(lzma_lzma_preset(&stream->opt, LZMA_PRESET_DEFAULT))
  2.1309 -+                	goto failed;
  2.1310 -+
  2.1311 -+		stream->opt.dict_size = block_size;
  2.1312 -+		filter->length = 0;
  2.1313 -+		res = lzma_stream_buffer_encode(filter->filter,
  2.1314 -+			LZMA_CHECK_CRC32, NULL, src, size, filter->buffer,
  2.1315 -+			&filter->length, block_size);
  2.1316 -+	
  2.1317 -+		if(res == LZMA_OK) {
  2.1318 -+			if(!selected || selected->length > filter->length)
  2.1319 -+				selected = filter;
  2.1320 -+		} else if(res != LZMA_BUF_ERROR)
  2.1321 -+			goto failed;
  2.1322 - 	}
  2.1323 - 
  2.1324 --	strm.next_out = dest;
  2.1325 --	strm.avail_out = block_size;
  2.1326 --	strm.next_in = src;
  2.1327 --	strm.avail_in = size;
  2.1328 --
  2.1329 --	res = lzma_code(&strm, LZMA_FINISH);
  2.1330 --	lzma_end(&strm);
  2.1331 --
  2.1332 --	if(res == LZMA_STREAM_END) {
  2.1333 --		/*
  2.1334 --	 	 * Fill in the 8 byte little endian uncompressed size field in
  2.1335 --		 * the LZMA header.  8 bytes is excessively large for squashfs
  2.1336 --		 * but this is the standard LZMA header and which is expected by
  2.1337 --		 * the kernel code
  2.1338 --	 	 */
  2.1339 --
  2.1340 --		d[LZMA_PROPS_SIZE] = size & 255;
  2.1341 --		d[LZMA_PROPS_SIZE + 1] = (size >> 8) & 255;
  2.1342 --		d[LZMA_PROPS_SIZE + 2] = (size >> 16) & 255;
  2.1343 --		d[LZMA_PROPS_SIZE + 3] = (size >> 24) & 255;
  2.1344 --		d[LZMA_PROPS_SIZE + 4] = 0;
  2.1345 --		d[LZMA_PROPS_SIZE + 5] = 0;
  2.1346 --		d[LZMA_PROPS_SIZE + 6] = 0;
  2.1347 --		d[LZMA_PROPS_SIZE + 7] = 0;
  2.1348 --
  2.1349 --		return (int) strm.total_out;
  2.1350 --	}
  2.1351 --
  2.1352 --	if(res == LZMA_OK)
  2.1353 -+	if(!selected)
  2.1354 - 		/*
  2.1355 - 	 	 * Output buffer overflow.  Return out of buffer space
  2.1356 - 	 	 */
  2.1357 - 		return 0;
  2.1358 - 
  2.1359 -+	if(selected->buffer != dest)
  2.1360 -+		memcpy(dest, selected->buffer, selected->length);
  2.1361 -+
  2.1362 -+	return (int) selected->length;
  2.1363 -+
  2.1364 - failed:
  2.1365 - 	/*
  2.1366 - 	 * All other errors return failure, with the compressor
  2.1367 -@@ -90,49 +213,29 @@
  2.1368 - }
  2.1369 - 
  2.1370 - 
  2.1371 --int lzma_uncompress(void *dest, void *src, int size, int block_size,
  2.1372 -+static int xz_uncompress(void *dest, void *src, int size, int block_size,
  2.1373 - 	int *error)
  2.1374 - {
  2.1375 --	lzma_stream strm = LZMA_STREAM_INIT;
  2.1376 --	int uncompressed_size = 0, res;
  2.1377 --	unsigned char lzma_header[LZMA_HEADER_SIZE];
  2.1378 -+	size_t src_pos = 0;
  2.1379 -+	size_t dest_pos = 0;
  2.1380 -+	uint64_t memlimit = MEMLIMIT;
  2.1381 - 
  2.1382 --	res = lzma_alone_decoder(&strm, MEMLIMIT);
  2.1383 --	if(res != LZMA_OK) {
  2.1384 --		lzma_end(&strm);
  2.1385 --		goto failed;
  2.1386 --	}
  2.1387 -+	lzma_ret res = lzma_stream_buffer_decode(&memlimit, 0, NULL,
  2.1388 -+			src, &src_pos, size, dest, &dest_pos, block_size);
  2.1389 - 
  2.1390 --	memcpy(lzma_header, src, LZMA_HEADER_SIZE);
  2.1391 --	uncompressed_size = lzma_header[LZMA_PROPS_SIZE] |
  2.1392 --		(lzma_header[LZMA_PROPS_SIZE + 1] << 8) |
  2.1393 --		(lzma_header[LZMA_PROPS_SIZE + 2] << 16) |
  2.1394 --		(lzma_header[LZMA_PROPS_SIZE + 3] << 24);
  2.1395 --	memset(lzma_header + LZMA_PROPS_SIZE, 255, LZMA_UNCOMP_SIZE);
  2.1396 -+	*error = res;
  2.1397 -+	return res == LZMA_OK && size == (int) src_pos ? (int) dest_pos : -1;
  2.1398 -+}
  2.1399 - 
  2.1400 --	strm.next_out = dest;
  2.1401 --	strm.avail_out = block_size;
  2.1402 --	strm.next_in = lzma_header;
  2.1403 --	strm.avail_in = LZMA_HEADER_SIZE;
  2.1404 - 
  2.1405 --	res = lzma_code(&strm, LZMA_RUN);
  2.1406 -+struct compressor xz_comp_ops = {
  2.1407 -+	.init = xz_init,
  2.1408 -+	.compress = xz_compress,
  2.1409 -+	.uncompress = xz_uncompress,
  2.1410 -+	.options = xz_options,
  2.1411 -+	.usage = xz_usage,
  2.1412 -+	.id = XZ_COMPRESSION,
  2.1413 -+	.name = "xz",
  2.1414 -+	.supported = 1
  2.1415 -+};
  2.1416 - 
  2.1417 --	if(res != LZMA_OK || strm.avail_in != 0) {
  2.1418 --		lzma_end(&strm);
  2.1419 --		goto failed;
  2.1420 --	}
  2.1421 --
  2.1422 --	strm.next_in = src + LZMA_HEADER_SIZE;
  2.1423 --	strm.avail_in = size - LZMA_HEADER_SIZE;
  2.1424 --
  2.1425 --	res = lzma_code(&strm, LZMA_FINISH);
  2.1426 --	lzma_end(&strm);
  2.1427 --
  2.1428 --	if(res == LZMA_STREAM_END || (res == LZMA_OK &&
  2.1429 --		strm.total_out >= uncompressed_size && strm.avail_in == 0))
  2.1430 --		return uncompressed_size;
  2.1431 --
  2.1432 --failed:
  2.1433 --	*error = res;
  2.1434 --	return -1;
  2.1435 --}