wok-current rev 6372

Up: squashfs to 4.1. Doesn't need lzma.u patch anymore.
author Christopher Rogers <slaxemulator@gmail.com>
date Tue Sep 21 10:52:22 2010 +0000 (2010-09-21)
parents e3a30fd8f61d
children e2914a415ebc
files squashfs/receipt squashfs/stuff/lzma.u
line diff
     1.1 --- a/squashfs/receipt	Tue Sep 21 03:46:53 2010 +0000
     1.2 +++ b/squashfs/receipt	Tue Sep 21 10:52:22 2010 +0000
     1.3 @@ -1,7 +1,7 @@
     1.4  # SliTaz package receipt.
     1.5  
     1.6  PACKAGE="squashfs"
     1.7 -VERSION="4.0"
     1.8 +VERSION="4.1"
     1.9  CATEGORY="base-system"
    1.10  SHORT_DESC="Linux squashfs userland tools."
    1.11  MAINTAINER="pascal.bellard@slitaz.org"
    1.12 @@ -9,7 +9,7 @@
    1.13  TARBALL="squashfs$VERSION.tar.gz"
    1.14  WGET_URL="$SF_MIRROR/$PACKAGE/$TARBALL"
    1.15  DEPENDS="zlib linux-squashfs"
    1.16 -BUILD_DEPENDS="zlib-dev"
    1.17 +BUILD_DEPENDS="zlib-dev attr-dev liblzma-dev"
    1.18  PROVIDE="cromfs-or-squashfs"
    1.19  
    1.20  # Rules to configure and make the package.
    1.21 @@ -18,17 +18,8 @@
    1.22  	mv ${PACKAGE}${VERSION} $src 2> /dev/null
    1.23  
    1.24  	cd $src/squashfs-tools
    1.25 +	sed -i 's|#XZ_SUPPORT = 1|XZ_SUPPORT = 1|g' Makefile
    1.26  	mkdir -p ../_pkg/usr/sbin ../_pkg/sbin
    1.27 -	if [ ! -d ../LZMA/lzma465 ]; then
    1.28 -		SF_MIRROR=http://switch.dl.sourceforge.net/sourceforge
    1.29 -		[ -s $SOURCES_REPOSITORY/lzma465.tar.bz2 ] || 
    1.30 -		wget $SF_MIRROR/sevenzip/lzma465.tar.bz2 -P $SOURCES_REPOSITORY
    1.31 -		mkdir -p ../LZMA/lzma465
    1.32 -		tar xjf $SOURCES_REPOSITORY/lzma465.tar.bz2 -C ../LZMA/lzma465
    1.33 -	fi
    1.34 -	if [ ! -f lzma_wrapper.c ]; then
    1.35 -		patch -p2 -i ../../stuff/lzma.u
    1.36 -	fi
    1.37  	make || return 1
    1.38  	cp mksquashfs ../_pkg/usr/sbin
    1.39  	cp unsquashfs ../_pkg/sbin
     2.1 --- a/squashfs/stuff/lzma.u	Tue Sep 21 03:46:53 2010 +0000
     2.2 +++ /dev/null	Thu Jan 01 00:00:00 1970 +0000
     2.3 @@ -1,2275 +0,0 @@
     2.4 ---- squashfs-4.0/squashfs-tools/Makefile
     2.5 -+++ squashfs-4.0/squashfs-tools/Makefile
     2.6 -@@ -1,40 +1,76 @@
     2.7 -+#
     2.8 -+# Building LZMA support
     2.9 -+# Download LZMA sdk (4.65 used in development, other versions may work),
    2.10 -+# set LZMA_DIR to unpacked source, and uncomment next line
    2.11 -+LZMA_SUPPORT = 1
    2.12 -+LZMA_DIR = ../LZMA/lzma465
    2.13 -+
    2.14 -+#Compression default.
    2.15 -+COMP_DEFAULT = gzip
    2.16 -+
    2.17 -+INCLUDEDIR = -I.
    2.18 - INSTALL_DIR = /usr/local/bin
    2.19 - 
    2.20 --INCLUDEDIR = .
    2.21 -+MKSQUASHFS_OBJS = mksquashfs.o read_fs.o sort.o swap.o pseudo.o compressor.o \
    2.22 -+	gzip_wrapper.o
    2.23 - 
    2.24 --CFLAGS := -I$(INCLUDEDIR) -D_FILE_OFFSET_BITS=64 -D_LARGEFILE_SOURCE -D_GNU_SOURCE -O2
    2.25 -+UNSQUASHFS_OBJS = unsquashfs.o unsquash-1.o unsquash-2.o unsquash-3.o \
    2.26 -+	unsquash-4.o swap.o compressor.o gzip_wrapper.o
    2.27 - 
    2.28 -+CFLAGS = $(INCLUDEDIR) -D_FILE_OFFSET_BITS=64 -D_LARGEFILE_SOURCE \
    2.29 -+	-D_GNU_SOURCE -DCOMP_DEFAULT=\"$(COMP_DEFAULT)\" -O2 -Wall
    2.30 -+
    2.31 -+ifdef LZMA_SUPPORT
    2.32 -+LZMA_OBJS = $(LZMA_DIR)/C/Alloc.o $(LZMA_DIR)/C/LzFind.o \
    2.33 -+	$(LZMA_DIR)/C/LzmaDec.o $(LZMA_DIR)/C/LzmaEnc.o $(LZMA_DIR)/C/LzmaLib.o
    2.34 -+INCLUDEDIR += -I$(LZMA_DIR)/C
    2.35 -+CFLAGS += -DLZMA_SUPPORT
    2.36 -+MKSQUASHFS_OBJS += lzma_wrapper.o $(LZMA_OBJS)
    2.37 -+UNSQUASHFS_OBJS += lzma_wrapper.o $(LZMA_OBJS)
    2.38 -+endif
    2.39 -+
    2.40 -+.PHONY: all
    2.41 - all: mksquashfs unsquashfs
    2.42 - 
    2.43 --mksquashfs: mksquashfs.o read_fs.o sort.o swap.o pseudo.o
    2.44 --	$(CC) mksquashfs.o read_fs.o sort.o swap.o pseudo.o -lz -lpthread -lm -o $@
    2.45 -+mksquashfs: $(MKSQUASHFS_OBJS)
    2.46 -+	$(CC) $(MKSQUASHFS_OBJS) -lz -lpthread -lm -o $@
    2.47 - 
    2.48 --mksquashfs.o: mksquashfs.c squashfs_fs.h mksquashfs.h global.h sort.h squashfs_swap.h Makefile
    2.49 -+mksquashfs.o: mksquashfs.c squashfs_fs.h mksquashfs.h global.h sort.h \
    2.50 -+	squashfs_swap.h
    2.51 - 
    2.52 --read_fs.o: read_fs.c squashfs_fs.h read_fs.h global.h squashfs_swap.h Makefile
    2.53 -+read_fs.o: read_fs.c squashfs_fs.h read_fs.h global.h squashfs_swap.h
    2.54 - 
    2.55 --sort.o: sort.c squashfs_fs.h global.h sort.h Makefile
    2.56 -+sort.o: sort.c squashfs_fs.h global.h sort.h
    2.57 - 
    2.58 --swap.o: swap.c Makefile
    2.59 -+swap.o: swap.c
    2.60 - 
    2.61 --pseudo.o: pseudo.c pseudo.h Makefile
    2.62 -+pseudo.o: pseudo.c pseudo.h
    2.63 - 
    2.64 --unsquashfs: unsquashfs.o unsquash-1.o unsquash-2.o unsquash-3.o unsquash-4.o swap.o
    2.65 --	$(CC) unsquashfs.o unsquash-1.o unsquash-2.o unsquash-3.o unsquash-4.o swap.o -lz -lpthread -lm -o $@
    2.66 -+compressor.o: compressor.c compressor.h
    2.67 - 
    2.68 --unsquashfs.o: unsquashfs.h unsquashfs.c squashfs_fs.h squashfs_swap.h squashfs_compat.h global.h Makefile
    2.69 -+unsquashfs: $(UNSQUASHFS_OBJS)
    2.70 -+	$(CC) $(UNSQUASHFS_OBJS) -lz -lpthread -lm -o $@
    2.71 - 
    2.72 --unsquash-1.o: unsquashfs.h unsquash-1.c squashfs_fs.h squashfs_compat.h global.h Makefile
    2.73 -+unsquashfs.o: unsquashfs.h unsquashfs.c squashfs_fs.h squashfs_swap.h \
    2.74 -+	squashfs_compat.h global.h
    2.75 - 
    2.76 --unsquash-2.o: unsquashfs.h unsquash-2.c unsquashfs.h squashfs_fs.h squashfs_compat.h global.h Makefile
    2.77 -+unsquash-1.o: unsquashfs.h unsquash-1.c squashfs_fs.h squashfs_compat.h \
    2.78 -+	global.h
    2.79 - 
    2.80 --unsquash-3.o: unsquashfs.h unsquash-3.c squashfs_fs.h squashfs_compat.h global.h Makefile
    2.81 -+unsquash-2.o: unsquashfs.h unsquash-2.c unsquashfs.h squashfs_fs.h \
    2.82 -+	squashfs_compat.h global.h
    2.83 - 
    2.84 --unsquash-4.o: unsquashfs.h unsquash-4.c squashfs_fs.h squashfs_swap.h global.h Makefile
    2.85 -+unsquash-3.o: unsquashfs.h unsquash-3.c squashfs_fs.h squashfs_compat.h \
    2.86 -+	global.h
    2.87 - 
    2.88 -+unsquash-4.o: unsquashfs.h unsquash-4.c squashfs_fs.h squashfs_swap.h \
    2.89 -+	global.h
    2.90 -+
    2.91 -+.PHONY: clean
    2.92 - clean:
    2.93 - 	-rm -f *.o mksquashfs unsquashfs
    2.94 - 
    2.95 -+.PHONY: install
    2.96 - install: mksquashfs unsquashfs
    2.97 - 	mkdir -p $(INSTALL_DIR)
    2.98 - 	cp mksquashfs $(INSTALL_DIR)
    2.99 -
   2.100 ---- squashfs-4.0/squashfs-tools/compressor.c	Thu Jan  1 01:00:00 1970
   2.101 -+++ squashfs-4.0/squashfs-tools/compressor.c	Sat Aug 29 03:05:34 2009
   2.102 -@@ -0,0 +1,78 @@
   2.103 -+/*
   2.104 -+ *
   2.105 -+ * Copyright (c) 2002, 2003, 2004, 2005, 2006, 2007, 2008, 2009
   2.106 -+ * Phillip Lougher <phillip@lougher.demon.co.uk>
   2.107 -+ *
   2.108 -+ * This program is free software; you can redistribute it and/or
   2.109 -+ * modify it under the terms of the GNU General Public License
   2.110 -+ * as published by the Free Software Foundation; either version 2,
   2.111 -+ * or (at your option) any later version.
   2.112 -+ *
   2.113 -+ * This program is distributed in the hope that it will be useful,
   2.114 -+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
   2.115 -+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
   2.116 -+ * GNU General Public License for more details.
   2.117 -+ *
   2.118 -+ * You should have received a copy of the GNU General Public License
   2.119 -+ * along with this program; if not, write to the Free Software
   2.120 -+ * Foundation, 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
   2.121 -+ *
   2.122 -+ * compressor.c
   2.123 -+ */
   2.124 -+
   2.125 -+#include <stdio.h>
   2.126 -+#include <string.h>
   2.127 -+#include "compressor.h"
   2.128 -+#include "squashfs_fs.h"
   2.129 -+
   2.130 -+extern int gzip_compress(void **, char *, char *, int, int, int *);
   2.131 -+extern int gzip_uncompress(char *, char *, int, int, int *);
   2.132 -+extern int lzma_compress(void **, char *, char *, int, int, int *);
   2.133 -+extern int lzma_uncompress(char *, char *, int, int, int *);
   2.134 -+
   2.135 -+struct compressor compressor[] = {
   2.136 -+	{ gzip_compress, gzip_uncompress, ZLIB_COMPRESSION, "gzip", 1 },
   2.137 -+#ifdef LZMA_SUPPORT
   2.138 -+	{ lzma_compress, lzma_uncompress, LZMA_COMPRESSION, "lzma", 1 },
   2.139 -+#else
   2.140 -+	{ NULL, NULL, LZMA_COMPRESSION, "lzma", 0 },
   2.141 -+#endif
   2.142 -+	{ NULL, NULL , 0, "unknown", 0}
   2.143 -+};
   2.144 -+
   2.145 -+
   2.146 -+struct compressor *lookup_compressor(char *name)
   2.147 -+{
   2.148 -+	int i;
   2.149 -+
   2.150 -+	for(i = 0; compressor[i].id; i++)
   2.151 -+		if(strcmp(compressor[i].name, name) == 0)
   2.152 -+			break;
   2.153 -+
   2.154 -+	return &compressor[i];
   2.155 -+}
   2.156 -+
   2.157 -+
   2.158 -+struct compressor *lookup_compressor_id(int id)
   2.159 -+{
   2.160 -+	int i;
   2.161 -+
   2.162 -+	for(i = 0; compressor[i].id; i++)
   2.163 -+		if(id == compressor[i].id)
   2.164 -+			break;
   2.165 -+
   2.166 -+	return &compressor[i];
   2.167 -+}
   2.168 -+
   2.169 -+
   2.170 -+void display_compressors(char *indent, char *def_comp)
   2.171 -+{
   2.172 -+	int i;
   2.173 -+
   2.174 -+	for(i = 0; compressor[i].id; i++)
   2.175 -+		if(compressor[i].supported)
   2.176 -+			fprintf(stderr, "%s\t%s%s\n", indent,
   2.177 -+				compressor[i].name,
   2.178 -+				strcmp(compressor[i].name, def_comp) == 0 ?
   2.179 -+				" (default)" : "");
   2.180 -+}
   2.181 -
   2.182 ---- squashfs-4.0/squashfs-tools/compressor.h	Thu Jan  1 01:00:00 1970
   2.183 -+++ squashfs-4.0/squashfs-tools/compressor.h	Mon Aug 24 20:28:04 2009
   2.184 -@@ -0,0 +1,33 @@
   2.185 -+/*
   2.186 -+ *
   2.187 -+ * Copyright (c) 2002, 2003, 2004, 2005, 2006, 2007, 2008, 2009
   2.188 -+ * Phillip Lougher <phillip@lougher.demon.co.uk>
   2.189 -+ *
   2.190 -+ * This program is free software; you can redistribute it and/or
   2.191 -+ * modify it under the terms of the GNU General Public License
   2.192 -+ * as published by the Free Software Foundation; either version 2,
   2.193 -+ * or (at your option) any later version.
   2.194 -+ *
   2.195 -+ * This program is distributed in the hope that it will be useful,
   2.196 -+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
   2.197 -+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
   2.198 -+ * GNU General Public License for more details.
   2.199 -+ *
   2.200 -+ * You should have received a copy of the GNU General Public License
   2.201 -+ * along with this program; if not, write to the Free Software
   2.202 -+ * Foundation, 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
   2.203 -+ *
   2.204 -+ * compressor.h
   2.205 -+ */
   2.206 -+
   2.207 -+struct compressor {
   2.208 -+	int (*compress)(void **, char *, char *, int, int, int *);
   2.209 -+	int (*uncompress)(char *, char *, int, int, int *);
   2.210 -+	int id;
   2.211 -+	char *name;
   2.212 -+	int supported;
   2.213 -+};
   2.214 -+
   2.215 -+extern struct compressor *lookup_compressor(char *);
   2.216 -+extern struct compressor *lookup_compressor_id(int);
   2.217 -+extern void display_compressors(char *, char *);
   2.218 -
   2.219 ---- squashfs-4.0/squashfs-tools/gzip_wrapper.c	Thu Jan  1 01:00:00 1970
   2.220 -+++ squashfs-4.0/squashfs-tools/gzip_wrapper.c	Fri Aug  7 22:12:53 2009
   2.221 -@@ -0,0 +1,80 @@
   2.222 -+/*
   2.223 -+ * Copyright (c) 2002, 2003, 2004, 2005, 2006, 2007, 2008, 2009
   2.224 -+ * Phillip Lougher <phillip@lougher.demon.co.uk>
   2.225 -+ *
   2.226 -+ * This program is free software; you can redistribute it and/or
   2.227 -+ * modify it under the terms of the GNU General Public License
   2.228 -+ * as published by the Free Software Foundation; either version 2,
   2.229 -+ * or (at your option) any later version.
   2.230 -+ *
   2.231 -+ * This program is distributed in the hope that it will be useful,
   2.232 -+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
   2.233 -+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
   2.234 -+ * GNU General Public License for more details.
   2.235 -+ *
   2.236 -+ * You should have received a copy of the GNU General Public License
   2.237 -+ * along with this program; if not, write to the Free Software
   2.238 -+ * Foundation, 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
   2.239 -+ *
   2.240 -+ * gzip_wrapper.c
   2.241 -+ */
   2.242 -+
   2.243 -+#include <stdlib.h>
   2.244 -+#include <zlib.h>
   2.245 -+
   2.246 -+int gzip_compress(void **strm, char *d, char *s, int size, int block_size,
   2.247 -+		int *error)
   2.248 -+{
   2.249 -+	int res = 0;
   2.250 -+	z_stream *stream = *strm;
   2.251 -+
   2.252 -+	if(stream == NULL) {
   2.253 -+		if((stream = *strm = malloc(sizeof(z_stream))) == NULL)
   2.254 -+			goto failed;
   2.255 -+
   2.256 -+		stream->zalloc = Z_NULL;
   2.257 -+		stream->zfree = Z_NULL;
   2.258 -+		stream->opaque = 0;
   2.259 -+
   2.260 -+		if((res = deflateInit(stream, 9)) != Z_OK)
   2.261 -+			goto failed;
   2.262 -+	} else if((res = deflateReset(stream)) != Z_OK)
   2.263 -+		goto failed;
   2.264 -+
   2.265 -+	stream->next_in = (unsigned char *) s;
   2.266 -+	stream->avail_in = size;
   2.267 -+	stream->next_out = (unsigned char *) d;
   2.268 -+	stream->avail_out = block_size;
   2.269 -+
   2.270 -+	res = deflate(stream, Z_FINISH);
   2.271 -+	if(res == Z_STREAM_END)
   2.272 -+		/*
   2.273 -+		 * Success, return the compressed size.
   2.274 -+		 */
   2.275 -+		return (int) stream->total_out;
   2.276 -+	if(res == Z_OK)
   2.277 -+		/*
   2.278 -+		 * Output buffer overflow.  Return out of buffer space
   2.279 -+		 */
   2.280 -+		return 0;
   2.281 -+failed:
   2.282 -+	/*
   2.283 -+	 * All other errors return failure, with the compressor
   2.284 -+	 * specific error code in *error
   2.285 -+	 */
   2.286 -+	*error = res;
   2.287 -+	return -1;
   2.288 -+}
   2.289 -+
   2.290 -+
   2.291 -+int gzip_uncompress(char *d, char *s, int size, int block_size, int *error)
   2.292 -+{
   2.293 -+	int res;
   2.294 -+	unsigned long bytes = block_size;
   2.295 -+
   2.296 -+	res = uncompress((unsigned char *) d, &bytes,
   2.297 -+		(const unsigned char *) s, size);
   2.298 -+
   2.299 -+	*error = res;
   2.300 -+	return res == Z_OK ? (int) bytes : -1;
   2.301 -+}
   2.302 -
   2.303 ---- squashfs-4.0/squashfs-tools/lzma_wrapper.c	Thu Jan  1 01:00:00 1970
   2.304 -+++ squashfs-4.0/squashfs-tools/lzma_wrapper.c	Wed Oct 14 05:32:57 2009
   2.305 -@@ -0,0 +1,93 @@
   2.306 -+/*
   2.307 -+ * Copyright (c) 2002, 2003, 2004, 2005, 2006, 2007, 2008, 2009
   2.308 -+ * Phillip Lougher <phillip@lougher.demon.co.uk>
   2.309 -+ *
   2.310 -+ * This program is free software; you can redistribute it and/or
   2.311 -+ * modify it under the terms of the GNU General Public License
   2.312 -+ * as published by the Free Software Foundation; either version 2,
   2.313 -+ * or (at your option) any later version.
   2.314 -+ *
   2.315 -+ * This program is distributed in the hope that it will be useful,
   2.316 -+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
   2.317 -+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
   2.318 -+ * GNU General Public License for more details.
   2.319 -+ *
   2.320 -+ * You should have received a copy of the GNU General Public License
   2.321 -+ * along with this program; if not, write to the Free Software
   2.322 -+ * Foundation, 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
   2.323 -+ *
   2.324 -+ * lzma_wrapper.c
   2.325 -+ */
   2.326 -+
   2.327 -+#include <LzmaLib.h>
   2.328 -+
   2.329 -+#define LZMA_HEADER_SIZE	(LZMA_PROPS_SIZE + 8)
   2.330 -+
   2.331 -+int lzma_compress(void **strm, char *dest, char *src,  int size,int block_size,
   2.332 -+		int *error)
   2.333 -+{
   2.334 -+	unsigned char *d = (unsigned char *) dest, *s = (unsigned char *) src;
   2.335 -+	size_t props_size = LZMA_PROPS_SIZE,
   2.336 -+		outlen = block_size - LZMA_HEADER_SIZE;
   2.337 -+	int res;
   2.338 -+
   2.339 -+	res = LzmaCompress(d + LZMA_HEADER_SIZE, &outlen, s, size, d,
   2.340 -+		&props_size, 5, block_size, 3, 0, 2, 32, 1);
   2.341 -+	
   2.342 -+	if(res == SZ_ERROR_OUTPUT_EOF) {
   2.343 -+		/*
   2.344 -+		 * Output buffer overflow.  Return out of buffer space error
   2.345 -+		 */
   2.346 -+		return 0;
   2.347 -+	}
   2.348 -+
   2.349 -+	if(res != SZ_OK) {
   2.350 -+		/*
   2.351 -+		 * All other errors return failure, with the compressor
   2.352 -+		 * specific error code in *error
   2.353 -+		 */
   2.354 -+		*error = res;
   2.355 -+		return -1;
   2.356 -+	}
   2.357 -+
   2.358 -+	/*
   2.359 -+	 * Fill in the 8 byte little endian uncompressed size field in the
   2.360 -+	 * LZMA header.  8 bytes is excessively large for squashfs but
   2.361 -+	 * this is the standard LZMA header and which is expected by the kernel
   2.362 -+	 * code
   2.363 -+	 */
   2.364 -+	d[LZMA_PROPS_SIZE] = size & 255;
   2.365 -+	d[LZMA_PROPS_SIZE + 1] = (size >> 8) & 255;
   2.366 -+	d[LZMA_PROPS_SIZE + 2] = (size >> 16) & 255;
   2.367 -+	d[LZMA_PROPS_SIZE + 3] = (size >> 24) & 255;
   2.368 -+	d[LZMA_PROPS_SIZE + 4] = 0;
   2.369 -+	d[LZMA_PROPS_SIZE + 5] = 0;
   2.370 -+	d[LZMA_PROPS_SIZE + 6] = 0;
   2.371 -+	d[LZMA_PROPS_SIZE + 7] = 0;
   2.372 -+
   2.373 -+	/*
   2.374 -+	 * Success, return the compressed size.  Outlen returned by the LZMA
   2.375 -+	 * compressor does not include the LZMA header space
   2.376 -+	 */
   2.377 -+	return outlen + LZMA_HEADER_SIZE;
   2.378 -+}
   2.379 -+
   2.380 -+
   2.381 -+int lzma_uncompress(char *dest, char *src, int size, int block_size,
   2.382 -+	int *error)
   2.383 -+{
   2.384 -+	unsigned char *d = (unsigned char *) dest, *s = (unsigned char *) src;
   2.385 -+	size_t outlen, inlen = size - LZMA_HEADER_SIZE;
   2.386 -+	int res;
   2.387 -+
   2.388 -+	outlen = s[LZMA_PROPS_SIZE] |
   2.389 -+		(s[LZMA_PROPS_SIZE + 1] << 8) |
   2.390 -+		(s[LZMA_PROPS_SIZE + 2] << 16) |
   2.391 -+		(s[LZMA_PROPS_SIZE + 3] << 24);
   2.392 -+
   2.393 -+	res = LzmaUncompress(d, &outlen, s + LZMA_HEADER_SIZE, &inlen,
   2.394 -+		s, LZMA_PROPS_SIZE);
   2.395 -+	
   2.396 -+	*error = res;
   2.397 -+	return res == SZ_OK ? outlen : -1;
   2.398 -+}
   2.399 -
   2.400 ---- squashfs-4.0/squashfs-tools/mksquashfs.c	Sun Apr  5 23:22:48 2009
   2.401 -+++ squashfs-4.0/squashfs-tools/mksquashfs.c	Tue Dec  8 19:02:54 2009
   2.402 -@@ -36,7 +36,6 @@
   2.403 - #include <errno.h>
   2.404 - #include <dirent.h>
   2.405 - #include <string.h>
   2.406 --#include <zlib.h>
   2.407 - #include <stdlib.h>
   2.408 - #include <signal.h>
   2.409 - #include <setjmp.h>
   2.410 -@@ -47,6 +46,7 @@
   2.411 - #include <math.h>
   2.412 - #include <regex.h>
   2.413 - #include <fnmatch.h>
   2.414 -+#include <sys/wait.h>
   2.415 - 
   2.416 - #ifndef linux
   2.417 - #define __BYTE_ORDER BYTE_ORDER
   2.418 -@@ -64,6 +64,7 @@
   2.419 - #include "global.h"
   2.420 - #include "sort.h"
   2.421 - #include "pseudo.h"
   2.422 -+#include "compressor.h"
   2.423 - 
   2.424 - #ifdef SQUASHFS_TRACE
   2.425 - #define TRACE(s, args...)	do { \
   2.426 -@@ -245,10 +246,8 @@
   2.427 - /* list of root directory entries read from original filesystem */
   2.428 - int old_root_entries = 0;
   2.429 - struct old_root_entry_info {
   2.430 --	char			name[SQUASHFS_NAME_LEN + 1];
   2.431 --	squashfs_inode		inode;
   2.432 --	int			type;
   2.433 --	int			inode_number;
   2.434 -+	char			*name;
   2.435 -+	struct inode_info	inode;
   2.436 - };
   2.437 - struct old_root_entry_info *old_root_entry;
   2.438 - 
   2.439 -@@ -371,10 +370,15 @@
   2.440 - int reader_buffer_size;
   2.441 - int fragment_buffer_size;
   2.442 - 
   2.443 -+/* compression operations structure */
   2.444 -+static struct compressor *comp;
   2.445 -+char *comp_name = COMP_DEFAULT;
   2.446 -+
   2.447 - char *read_from_disk(long long start, unsigned int avail_bytes);
   2.448 - void add_old_root_entry(char *name, squashfs_inode inode, int inode_number,
   2.449 - 	int type);
   2.450 --extern int read_super(int fd, squashfs_super_block *sBlk, char *source);
   2.451 -+extern struct compressor  *read_super(int fd, squashfs_super_block *sBlk,
   2.452 -+	char *source);
   2.453 - extern long long read_filesystem(char *root_name, int fd,
   2.454 - 	squashfs_super_block *sBlk, char **cinode_table, char **data_cache,
   2.455 - 	char **cdirectory_table, char **directory_data_cache,
   2.456 -@@ -831,83 +835,32 @@
   2.457 - }
   2.458 - 
   2.459 - 
   2.460 --unsigned int mangle2(z_stream **strm, char *d, char *s, int size,
   2.461 -+int mangle2(void **strm, char *d, char *s, int size,
   2.462 - 	int block_size, int uncompressed, int data_block)
   2.463 - {
   2.464 --	unsigned long c_byte;
   2.465 --	unsigned int res;
   2.466 --	z_stream *stream = *strm;
   2.467 -+	int error, c_byte = 0;
   2.468 - 
   2.469 --	if(uncompressed)
   2.470 --		goto notcompressed;
   2.471 --
   2.472 --	if(stream == NULL) {
   2.473 --		if((stream = *strm = malloc(sizeof(z_stream))) == NULL)
   2.474 --			BAD_ERROR("mangle::compress failed, not enough "
   2.475 --				"memory\n");
   2.476 --
   2.477 --		stream->zalloc = Z_NULL;
   2.478 --		stream->zfree = Z_NULL;
   2.479 --		stream->opaque = 0;
   2.480 --
   2.481 --		if((res = deflateInit(stream, 9)) != Z_OK) {
   2.482 --			if(res == Z_MEM_ERROR)
   2.483 --				BAD_ERROR("zlib::compress failed, not enough "
   2.484 --					"memory\n");
   2.485 --			else if(res == Z_STREAM_ERROR)
   2.486 --				BAD_ERROR("zlib::compress failed, not a valid "
   2.487 --					"compression level\n");
   2.488 --			else if(res == Z_VERSION_ERROR)
   2.489 --				BAD_ERROR("zlib::compress failed, incorrect "
   2.490 --					"zlib version\n");
   2.491 --			else
   2.492 --				BAD_ERROR("zlib::compress failed, unknown "
   2.493 --					"error %d\n", res);
   2.494 --		}
   2.495 --	} else if((res = deflateReset(stream)) != Z_OK) {
   2.496 --		if(res == Z_STREAM_ERROR)
   2.497 --			BAD_ERROR("zlib::compress failed, stream state "
   2.498 --				"inconsistent\n");
   2.499 --		else
   2.500 --			BAD_ERROR("zlib::compress failed, unknown error %d\n",
   2.501 --				res);
   2.502 -+	if(!uncompressed) {
   2.503 -+		c_byte = comp->compress(strm, d, s, size, block_size, &error);
   2.504 -+		if(c_byte == -1)
   2.505 -+			BAD_ERROR("mangle2:: %s compress failed with error "
   2.506 -+				"code %d\n", comp->name, error);
   2.507 - 	}
   2.508 - 
   2.509 --	stream->next_in = (unsigned char *) s;
   2.510 --	stream->avail_in = size;
   2.511 --	stream->next_out = (unsigned char *) d;
   2.512 --	stream->avail_out = block_size;
   2.513 --
   2.514 --	res = deflate(stream, Z_FINISH);
   2.515 --	if(res != Z_STREAM_END && res != Z_OK) {
   2.516 --		if(res == Z_STREAM_ERROR)
   2.517 --			BAD_ERROR("zlib::compress failed, stream state "
   2.518 --				"inconsistent\n");
   2.519 --		else if(res == Z_BUF_ERROR)
   2.520 --			BAD_ERROR("zlib::compress failed, no progress possible"
   2.521 --				"\n");
   2.522 --		else
   2.523 --			BAD_ERROR("zlib::compress failed, unknown error %d\n",
   2.524 --				res);
   2.525 --	}
   2.526 --
   2.527 --	c_byte = stream->total_out;
   2.528 --
   2.529 --	if(res != Z_STREAM_END || c_byte >= size) {
   2.530 --notcompressed:
   2.531 -+	if(c_byte == 0 || c_byte >= size) {
   2.532 - 		memcpy(d, s, size);
   2.533 - 		return size | (data_block ? SQUASHFS_COMPRESSED_BIT_BLOCK :
   2.534 - 			SQUASHFS_COMPRESSED_BIT);
   2.535 - 	}
   2.536 - 
   2.537 --	return (unsigned int) c_byte;
   2.538 -+	return c_byte;
   2.539 - }
   2.540 - 
   2.541 - 
   2.542 --unsigned int mangle(char *d, char *s, int size, int block_size,
   2.543 -+int mangle(char *d, char *s, int size, int block_size,
   2.544 - 	int uncompressed, int data_block)
   2.545 - {
   2.546 --	static z_stream *stream = NULL;
   2.547 -+	static void *stream = NULL;
   2.548 - 
   2.549 - 	return mangle2(&stream, d, s, size, block_size, uncompressed,
   2.550 - 		data_block);
   2.551 -@@ -1660,8 +1613,7 @@
   2.552 - 	pthread_mutex_unlock(&fragment_mutex);
   2.553 - 
   2.554 - 	if(SQUASHFS_COMPRESSED_BLOCK(disk_fragment->size)) {
   2.555 --		int res;
   2.556 --		unsigned long bytes = block_size;
   2.557 -+		int error, res;
   2.558 - 		char *data;
   2.559 - 
   2.560 - 		if(compressed_buffer)
   2.561 -@@ -1669,19 +1621,11 @@
   2.562 - 		else
   2.563 - 			data = read_from_disk(start_block, size);
   2.564 - 
   2.565 --		res = uncompress((unsigned char *) buffer->data, &bytes,
   2.566 --			(const unsigned char *) data, size);
   2.567 --		if(res != Z_OK) {
   2.568 --			if(res == Z_MEM_ERROR)
   2.569 --				BAD_ERROR("zlib::uncompress failed, not enough "
   2.570 --					"memory\n");
   2.571 --			else if(res == Z_BUF_ERROR)
   2.572 --				BAD_ERROR("zlib::uncompress failed, not enough "
   2.573 --					"room in output buffer\n");
   2.574 --			else
   2.575 --				BAD_ERROR("zlib::uncompress failed,"
   2.576 --					"  unknown error %d\n", res);
   2.577 --		}
   2.578 -+		res = comp->uncompress(buffer->data, data, size, block_size,
   2.579 -+			&error);
   2.580 -+		if(res == -1)
   2.581 -+			BAD_ERROR("%s uncompress failed with error code %d\n",
   2.582 -+				comp->name, error);
   2.583 - 	} else if(compressed_buffer)
   2.584 - 		memcpy(buffer->data, compressed_buffer->data, size);
   2.585 - 	else
   2.586 -@@ -1733,9 +1677,7 @@
   2.587 - 		entry->buffer->block = bytes;
   2.588 - 		bytes += compressed_size;
   2.589 - 		fragments_outstanding --;
   2.590 --		pthread_mutex_unlock(&fragment_mutex);
   2.591 - 		queue_put(to_writer, entry->buffer);
   2.592 --		pthread_mutex_lock(&fragment_mutex);
   2.593 - 		TRACE("fragment_locked writing fragment %d, compressed size %d"
   2.594 - 			"\n", entry->fragment, compressed_size);
   2.595 - 		free(entry);
   2.596 -@@ -1758,6 +1700,8 @@
   2.597 - 	pthread_mutex_lock(&fragment_mutex);
   2.598 - 	insert_fragment_list(&frag_locked_list, entry);
   2.599 - 	pthread_mutex_unlock(&fragment_mutex);
   2.600 -+
   2.601 -+	return TRUE;
   2.602 - }
   2.603 - 
   2.604 - 
   2.605 -@@ -1824,7 +1768,9 @@
   2.606 - 	unsigned short c_byte;
   2.607 - 	char cbuffer[(SQUASHFS_METADATA_SIZE << 2) + 2];
   2.608 - 	
   2.609 -+#ifdef SQUASHFS_TRACE
   2.610 - 	long long obytes = bytes;
   2.611 -+#endif
   2.612 - 
   2.613 - 	for(i = 0; i < meta_blocks; i++) {
   2.614 - 		int avail_bytes = length > SQUASHFS_METADATA_SIZE ?
   2.615 -@@ -2170,11 +2116,85 @@
   2.616 - }
   2.617 - 
   2.618 - 
   2.619 -+static int seq = 0;
   2.620 -+void reader_read_process(struct dir_ent *dir_ent)
   2.621 -+{
   2.622 -+	struct file_buffer *prev_buffer = NULL, *file_buffer;
   2.623 -+	int status, res, byte, count = 0;
   2.624 -+	int file = get_pseudo_file(dir_ent->inode->pseudo_id)->fd;
   2.625 -+	int child = get_pseudo_file(dir_ent->inode->pseudo_id)->child;
   2.626 -+	long long bytes = 0;
   2.627 -+
   2.628 -+	while(1) {
   2.629 -+		file_buffer = cache_get(reader_buffer, 0, 0);
   2.630 -+		file_buffer->sequence = seq ++;
   2.631 -+
   2.632 -+		byte = read_bytes(file, file_buffer->data, block_size);
   2.633 -+		if(byte == -1)
   2.634 -+			goto read_err;
   2.635 -+
   2.636 -+		file_buffer->size = byte;
   2.637 -+		file_buffer->file_size = -1;
   2.638 -+		file_buffer->block = count ++;
   2.639 -+		file_buffer->error = FALSE;
   2.640 -+		file_buffer->fragment = FALSE;
   2.641 -+		bytes += byte;
   2.642 -+
   2.643 -+		if(byte == 0)
   2.644 -+			break;
   2.645 -+
   2.646 -+		/*
   2.647 -+		 * Update estimated_uncompressed block count.  This is done
   2.648 -+		 * on every block rather than waiting for all blocks to be
   2.649 -+		 * read incase write_file_process() is running in parallel
   2.650 -+		 * with this.  Otherwise cur uncompressed block count may
   2.651 -+		 * get ahead of the total uncompressed block count.
   2.652 -+		 */ 
   2.653 -+		estimated_uncompressed ++;
   2.654 -+
   2.655 -+		if(prev_buffer)
   2.656 -+			queue_put(from_reader, prev_buffer);
   2.657 -+		prev_buffer = file_buffer;
   2.658 -+	}
   2.659 -+
   2.660 -+	/*
   2.661 -+ 	 * Update inode file size now that the size of the dynamic pseudo file
   2.662 -+	 * is known.  This is needed for the -info option.
   2.663 -+	 */
   2.664 -+	dir_ent->inode->buf.st_size = bytes;
   2.665 -+
   2.666 -+	res = waitpid(child, &status, 0);
   2.667 -+	if(res == -1 || !WIFEXITED(status) || WEXITSTATUS(status) != 0)
   2.668 -+		goto read_err;
   2.669 -+
   2.670 -+	if(prev_buffer == NULL)
   2.671 -+		prev_buffer = file_buffer;
   2.672 -+	else {
   2.673 -+		cache_block_put(file_buffer);
   2.674 -+		seq --;
   2.675 -+	}
   2.676 -+	prev_buffer->file_size = bytes;
   2.677 -+	prev_buffer->fragment = !no_fragments &&
   2.678 -+		(count == 2 || always_use_fragments) && (byte < block_size);
   2.679 -+	queue_put(from_reader, prev_buffer);
   2.680 -+
   2.681 -+	return;
   2.682 -+
   2.683 -+read_err:
   2.684 -+	if(prev_buffer) {
   2.685 -+		cache_block_put(file_buffer);
   2.686 -+		seq --;
   2.687 -+		file_buffer = prev_buffer;
   2.688 -+	}
   2.689 -+	file_buffer->error = TRUE;
   2.690 -+	queue_put(from_deflate, file_buffer);
   2.691 -+}
   2.692 -+
   2.693 -+
   2.694 - void reader_read_file(struct dir_ent *dir_ent)
   2.695 - {
   2.696 - 	struct stat *buf = &dir_ent->inode->buf, buf2;
   2.697 - 	struct file_buffer *file_buffer;
   2.698 --	static int index = 0;
   2.699 - 	int blocks, byte, count, expected, file, frag_block;
   2.700 - 	long long bytes, read_size;
   2.701 - 
   2.702 -@@ -2202,7 +2222,7 @@
   2.703 - 		if(file_buffer)
   2.704 - 			queue_put(from_reader, file_buffer);
   2.705 - 		file_buffer = cache_get(reader_buffer, 0, 0);
   2.706 --		file_buffer->sequence = index ++;
   2.707 -+		file_buffer->sequence = seq ++;
   2.708 - 
   2.709 - 		byte = file_buffer->size = read_bytes(file, file_buffer->data,
   2.710 - 			block_size);
   2.711 -@@ -2238,7 +2258,7 @@
   2.712 - 
   2.713 - read_err:
   2.714 - 	file_buffer = cache_get(reader_buffer, 0, 0);
   2.715 --	file_buffer->sequence = index ++;
   2.716 -+	file_buffer->sequence = seq ++;
   2.717 - read_err2:
   2.718 - 	file_buffer->error = TRUE;
   2.719 - 	queue_put(from_deflate, file_buffer);
   2.720 -@@ -2262,9 +2282,14 @@
   2.721 - 	for(i = 0; i < dir->count; i++) {
   2.722 - 		struct dir_ent *dir_ent = dir->list[i];
   2.723 - 		struct stat *buf = &dir_ent->inode->buf;
   2.724 --		if(dir_ent->data)
   2.725 -+		if(dir_ent->inode->root_entry)
   2.726 - 			continue;
   2.727 - 
   2.728 -+		if(dir_ent->inode->pseudo_file) {
   2.729 -+			reader_read_process(dir_ent);
   2.730 -+			continue;
   2.731 -+		}
   2.732 -+
   2.733 - 		switch(buf->st_mode & S_IFMT) {
   2.734 - 			case S_IFREG:
   2.735 - 				reader_read_file(dir_ent);
   2.736 -@@ -2365,7 +2390,7 @@
   2.737 - 
   2.738 - void *deflator(void *arg)
   2.739 - {
   2.740 --	z_stream *stream = NULL;
   2.741 -+	void *stream = NULL;
   2.742 - 	int oldstate;
   2.743 - 
   2.744 - 	pthread_setcancelstate(PTHREAD_CANCEL_ENABLE, &oldstate);
   2.745 -@@ -2402,7 +2427,7 @@
   2.746 - 
   2.747 - void *frag_deflator(void *arg)
   2.748 - {
   2.749 --	z_stream *stream = NULL;
   2.750 -+	void *stream = NULL;
   2.751 - 	int oldstate;
   2.752 - 
   2.753 - 	pthread_setcancelstate(PTHREAD_CANCEL_ENABLE, &oldstate);
   2.754 -@@ -2426,8 +2451,8 @@
   2.755 - 			write_buffer->block = bytes;
   2.756 - 			bytes += compressed_size;
   2.757 - 			fragments_outstanding --;
   2.758 --			pthread_mutex_unlock(&fragment_mutex);
   2.759 - 			queue_put(to_writer, write_buffer);
   2.760 -+			pthread_mutex_unlock(&fragment_mutex);
   2.761 - 			TRACE("Writing fragment %lld, uncompressed size %d, "
   2.762 - 				"compressed size %d\n", file_buffer->block,
   2.763 - 				file_buffer->size, compressed_size);
   2.764 -@@ -2674,6 +2699,98 @@
   2.765 - }
   2.766 - 
   2.767 - 
   2.768 -+int write_file_process(squashfs_inode *inode, struct dir_ent *dir_ent,
   2.769 -+	struct file_buffer *read_buffer, int *duplicate_file)
   2.770 -+{
   2.771 -+	long long read_size, file_bytes, start;
   2.772 -+	struct fragment *fragment;
   2.773 -+	unsigned int *block_list = NULL;
   2.774 -+	int block = 0, status;
   2.775 -+	long long sparse = 0;
   2.776 -+	struct file_buffer *fragment_buffer = NULL;
   2.777 -+
   2.778 -+	*duplicate_file = FALSE;
   2.779 -+
   2.780 -+	lock_fragments();
   2.781 -+
   2.782 -+	file_bytes = 0;
   2.783 -+	start = bytes;
   2.784 -+	while (1) {
   2.785 -+		read_size = read_buffer->file_size;
   2.786 -+		if(read_buffer->fragment && read_buffer->c_byte)
   2.787 -+			fragment_buffer = read_buffer;
   2.788 -+		else {
   2.789 -+			block_list = realloc(block_list, (block + 1) *
   2.790 -+				sizeof(unsigned int));
   2.791 -+			if(block_list == NULL)
   2.792 -+				BAD_ERROR("Out of memory allocating block_list"
   2.793 -+					"\n");
   2.794 -+			block_list[block ++] = read_buffer->c_byte;
   2.795 -+			if(read_buffer->c_byte) {
   2.796 -+				read_buffer->block = bytes;
   2.797 -+				bytes += read_buffer->size;
   2.798 -+				cache_rehash(read_buffer, read_buffer->block);
   2.799 -+				file_bytes += read_buffer->size;
   2.800 -+				queue_put(to_writer, read_buffer);
   2.801 -+			} else {
   2.802 -+				sparse += read_buffer->size;
   2.803 -+				cache_block_put(read_buffer);
   2.804 -+			}
   2.805 -+		}
   2.806 -+		inc_progress_bar();
   2.807 -+
   2.808 -+		if(read_size != -1)
   2.809 -+			break;
   2.810 -+
   2.811 -+		read_buffer = get_file_buffer(from_deflate);
   2.812 -+		if(read_buffer->error)
   2.813 -+			goto read_err;
   2.814 -+	}
   2.815 -+
   2.816 -+	unlock_fragments();
   2.817 -+	fragment = get_and_fill_fragment(fragment_buffer);
   2.818 -+	cache_block_put(fragment_buffer);
   2.819 -+
   2.820 -+	if(duplicate_checking)
   2.821 -+		add_non_dup(read_size, file_bytes, block_list, start, fragment,
   2.822 -+			0, 0, FALSE);
   2.823 -+	file_count ++;
   2.824 -+	total_bytes += read_size;
   2.825 -+
   2.826 -+	if(read_size < (1LL << 32) && start < (1LL << 32) && sparse == 0)
   2.827 -+		create_inode(inode, dir_ent, SQUASHFS_FILE_TYPE, read_size,
   2.828 -+			start, block, block_list, fragment, NULL, 0);
   2.829 -+	else
   2.830 -+		create_inode(inode, dir_ent, SQUASHFS_LREG_TYPE, read_size,
   2.831 -+			start, block, block_list, fragment, NULL, sparse);
   2.832 -+
   2.833 -+	if(duplicate_checking == FALSE)
   2.834 -+		free(block_list);
   2.835 -+
   2.836 -+	return 0;
   2.837 -+
   2.838 -+read_err:
   2.839 -+	cur_uncompressed -= block;
   2.840 -+	status = read_buffer->error;
   2.841 -+	bytes = start;
   2.842 -+	if(!block_device) {
   2.843 -+		int res;
   2.844 -+
   2.845 -+		queue_put(to_writer, NULL);
   2.846 -+		if(queue_get(from_writer) != 0)
   2.847 -+			EXIT_MKSQUASHFS();
   2.848 -+		res = ftruncate(fd, bytes);
   2.849 -+		if(res != 0)
   2.850 -+			BAD_ERROR("Failed to truncate dest file because %s\n",
   2.851 -+				strerror(errno));
   2.852 -+	}
   2.853 -+	unlock_fragments();
   2.854 -+	free(block_list);
   2.855 -+	cache_block_put(read_buffer);
   2.856 -+	return status;
   2.857 -+}
   2.858 -+
   2.859 -+
   2.860 - int write_file_blocks(squashfs_inode *inode, struct dir_ent *dir_ent,
   2.861 - 	long long read_size, struct file_buffer *read_buffer,
   2.862 - 	int *duplicate_file)
   2.863 -@@ -2941,7 +3058,10 @@
   2.864 - 	
   2.865 - 	read_size = read_buffer->file_size;
   2.866 - 
   2.867 --	if(read_size == 0) {
   2.868 -+	if(read_size == -1)
   2.869 -+		status = write_file_process(inode, dir_ent, read_buffer,
   2.870 -+			duplicate_file);
   2.871 -+	else if(read_size == 0) {
   2.872 - 		write_file_empty(inode, dir_ent, duplicate_file);
   2.873 - 		cache_block_put(read_buffer);
   2.874 - 	} else if(read_buffer->fragment && read_buffer->c_byte)
   2.875 -@@ -3036,6 +3156,8 @@
   2.876 - 
   2.877 - 	memcpy(&inode->buf, buf, sizeof(struct stat));
   2.878 - 	inode->read = FALSE;
   2.879 -+	inode->root_entry = FALSE;
   2.880 -+	inode->pseudo_file = FALSE;
   2.881 - 	inode->inode = SQUASHFS_INVALID_BLK;
   2.882 - 	inode->nlink = 1;
   2.883 - 
   2.884 -@@ -3056,7 +3178,7 @@
   2.885 - 
   2.886 - 
   2.887 - inline void add_dir_entry(char *name, char *pathname, struct dir_info *sub_dir,
   2.888 --	struct inode_info *inode_info, void *data, struct dir_info *dir)
   2.889 -+	struct inode_info *inode_info, struct dir_info *dir)
   2.890 - {
   2.891 - 	if((dir->count % DIR_ENTRIES) == 0) {
   2.892 - 		dir->list = realloc(dir->list, (dir->count + DIR_ENTRIES) *
   2.893 -@@ -3075,8 +3197,7 @@
   2.894 - 		NULL;
   2.895 - 	dir->list[dir->count]->inode = inode_info;
   2.896 - 	dir->list[dir->count]->dir = sub_dir;
   2.897 --	dir->list[dir->count]->our_dir = dir;
   2.898 --	dir->list[dir->count++]->data = data;
   2.899 -+	dir->list[dir->count++]->our_dir = dir;
   2.900 - 	dir->byte_count += strlen(name) + sizeof(squashfs_dir_entry);
   2.901 - }
   2.902 - 
   2.903 -@@ -3128,10 +3249,10 @@
   2.904 - 
   2.905 - 	if(dir->count < old_root_entries)
   2.906 - 		for(i = 0; i < old_root_entries; i++) {
   2.907 --			if(old_root_entry[i].type == SQUASHFS_DIR_TYPE)
   2.908 -+			if(old_root_entry[i].inode.type == SQUASHFS_DIR_TYPE)
   2.909 - 				dir->directory_count ++;
   2.910 --			add_dir_entry(old_root_entry[i].name, "", NULL, NULL,
   2.911 --				&old_root_entry[i], dir);
   2.912 -+			add_dir_entry(old_root_entry[i].name, "", NULL,
   2.913 -+				&old_root_entry[i].inode, dir);
   2.914 - 		}
   2.915 - 
   2.916 - 	while(index < source) {
   2.917 -@@ -3167,10 +3288,10 @@
   2.918 - 
   2.919 - 	if(dir->count < old_root_entries)
   2.920 - 		for(i = 0; i < old_root_entries; i++) {
   2.921 --			if(old_root_entry[i].type == SQUASHFS_DIR_TYPE)
   2.922 -+			if(old_root_entry[i].inode.type == SQUASHFS_DIR_TYPE)
   2.923 - 				dir->directory_count ++;
   2.924 --			add_dir_entry(old_root_entry[i].name, "", NULL, NULL,
   2.925 --				&old_root_entry[i], dir);
   2.926 -+			add_dir_entry(old_root_entry[i].name, "", NULL,
   2.927 -+				&old_root_entry[i].inode, dir);
   2.928 - 		}
   2.929 - 
   2.930 - 	if((d_name = readdir(dir->linuxdir)) != NULL) {
   2.931 -@@ -3215,7 +3336,7 @@
   2.932 - 	int current_count;
   2.933 - 
   2.934 - 	while((current_count = dir_info->current_count++) < dir_info->count)
   2.935 --		if(dir_info->list[current_count]->data)
   2.936 -+		if(dir_info->list[current_count]->inode->root_entry)
   2.937 - 			continue;
   2.938 - 		else 
   2.939 - 			return dir_info->list[current_count];
   2.940 -@@ -3240,11 +3361,11 @@
   2.941 - 	int current_count;
   2.942 - 
   2.943 - 	while((current_count = dir_info->current_count++) < dir_info->count)
   2.944 --		if(dir_info->list[current_count]->data)
   2.945 --			add_dir(dir_info->list[current_count]->data->inode,
   2.946 --				dir_info->list[current_count]->data->inode_number,
   2.947 -+		if(dir_info->list[current_count]->inode->root_entry)
   2.948 -+			add_dir(dir_info->list[current_count]->inode->inode,
   2.949 -+				dir_info->list[current_count]->inode->inode_number,
   2.950 - 				dir_info->list[current_count]->name,
   2.951 --				dir_info->list[current_count]->data->type, dir);
   2.952 -+				dir_info->list[current_count]->inode->type, dir);
   2.953 - 		else 
   2.954 - 			return dir_info->list[current_count];
   2.955 - 	return NULL;	
   2.956 -@@ -3313,7 +3434,6 @@
   2.957 - 	dir_ent->name = dir_ent->pathname = strdup(pathname);
   2.958 - 	dir_ent->dir = dir_info;
   2.959 - 	dir_ent->our_dir = NULL;
   2.960 --	dir_ent->data = NULL;
   2.961 - 	dir_info->dir_ent = dir_ent;
   2.962 - 
   2.963 - 	if(sorted)
   2.964 -@@ -3383,7 +3503,7 @@
   2.965 - 			sub_dir = NULL;
   2.966 - 
   2.967 - 		add_dir_entry(dir_name, filename, sub_dir, lookup_inode(&buf),
   2.968 --			NULL, dir);
   2.969 -+			dir);
   2.970 - 	}
   2.971 - 
   2.972 - 	scan1_freedir(dir);
   2.973 -@@ -3399,7 +3519,7 @@
   2.974 - 	struct dir_ent *dir_ent;
   2.975 - 	struct pseudo_entry *pseudo_ent;
   2.976 - 	struct stat buf;
   2.977 --	static pseudo_ino = 1;
   2.978 -+	static int pseudo_ino = 1;
   2.979 - 	
   2.980 - 	if(dir == NULL && (dir = scan1_opendir("")) == NULL)
   2.981 - 		return NULL;
   2.982 -@@ -3415,6 +3535,29 @@
   2.983 - 
   2.984 - 	while((pseudo_ent = pseudo_readdir(pseudo)) != NULL) {
   2.985 - 		dir_ent = scan2_lookup(dir, pseudo_ent->name);
   2.986 -+		if(pseudo_ent->dev->type == 's') {
   2.987 -+			struct stat *buf;
   2.988 -+			if(dir_ent == NULL) {
   2.989 -+				ERROR("Pseudo set file \"%s\" does not exist "
   2.990 -+					"in source filesystem.  Ignoring\n",
   2.991 -+					pseudo_ent->pathname);
   2.992 -+				continue;
   2.993 -+			}
   2.994 -+			if(dir_ent->inode->root_entry) {
   2.995 -+				ERROR("Pseudo set file \"%s\" is a pre-existing"
   2.996 -+					" file in the filesystem being appended"
   2.997 -+					"  to.  It cannot be modified. "
   2.998 -+					"Ignoring!\n", pseudo_ent->pathname);
   2.999 -+				continue;
  2.1000 -+			}
  2.1001 -+			buf = &dir_ent->inode->buf;
  2.1002 -+			buf->st_mode = (buf->st_mode & S_IFMT) |
  2.1003 -+				pseudo_ent->dev->mode;
  2.1004 -+			buf->st_uid = pseudo_ent->dev->uid;
  2.1005 -+			buf->st_gid = pseudo_ent->dev->gid;
  2.1006 -+			continue;
  2.1007 -+		}
  2.1008 -+
  2.1009 - 		if(dir_ent) {
  2.1010 - 			ERROR("Pseudo file \"%s\" exists in source filesystem "
  2.1011 - 				"\"%s\"\n", pseudo_ent->pathname,
  2.1012 -@@ -3444,8 +3587,29 @@
  2.1013 - 		buf.st_mtime = time(NULL);
  2.1014 - 		buf.st_ino = pseudo_ino ++;
  2.1015 - 
  2.1016 --		add_dir_entry(pseudo_ent->name, pseudo_ent->pathname, sub_dir,
  2.1017 --			lookup_inode(&buf), NULL, dir);
  2.1018 -+		if(pseudo_ent->dev->type == 'f') {
  2.1019 -+#ifdef USE_TMP_FILE
  2.1020 -+			struct stat buf2;
  2.1021 -+			int res = stat(pseudo_ent->dev->filename, &buf2);
  2.1022 -+			if(res == -1) {
  2.1023 -+				ERROR("Stat on pseudo file \"%s\" failed, "
  2.1024 -+					"skipping...", pseudo_ent->pathname);
  2.1025 -+				continue;
  2.1026 -+			}
  2.1027 -+			buf.st_size = buf2.st_size;
  2.1028 -+			add_dir_entry(pseudo_ent->name,
  2.1029 -+				pseudo_ent->dev->filename, sub_dir,
  2.1030 -+				lookup_inode(&buf), dir);
  2.1031 -+#else
  2.1032 -+			struct inode_info *inode = lookup_inode(&buf);
  2.1033 -+			inode->pseudo_id = pseudo_ent->dev->pseudo_id;
  2.1034 -+			inode->pseudo_file = TRUE;		
  2.1035 -+			add_dir_entry(pseudo_ent->name, pseudo_ent->pathname,
  2.1036 -+				sub_dir, inode, dir);
  2.1037 -+#endif
  2.1038 -+		} else
  2.1039 -+			add_dir_entry(pseudo_ent->name, pseudo_ent->pathname,
  2.1040 -+				sub_dir, lookup_inode(&buf), dir);
  2.1041 - 	}
  2.1042 - 
  2.1043 - 	scan2_freedir(dir);
  2.1044 -@@ -3482,8 +3646,9 @@
  2.1045 - 						&duplicate_file);
  2.1046 - 					INFO("file %s, uncompressed size %lld "
  2.1047 - 						"bytes %s\n", filename,
  2.1048 --						buf->st_size, duplicate_file ?
  2.1049 --						"DUPLICATE" : "");
  2.1050 -+						(long long) buf->st_size,
  2.1051 -+						duplicate_file ?  "DUPLICATE" :
  2.1052 -+						 "");
  2.1053 - 					break;
  2.1054 - 
  2.1055 - 				case S_IFDIR:
  2.1056 -@@ -3557,6 +3722,7 @@
  2.1057 - 						INFO("file %s, uncompressed "
  2.1058 - 							"size %lld bytes LINK"
  2.1059 - 							"\n", filename,
  2.1060 -+							(long long)
  2.1061 - 							buf->st_size);
  2.1062 - 					break;
  2.1063 - 				case SQUASHFS_SYMLINK_TYPE:
  2.1064 -@@ -3667,10 +3833,11 @@
  2.1065 - 		BAD_ERROR("Out of memory in old root directory entries "
  2.1066 - 			"reallocation\n");
  2.1067 - 
  2.1068 --	strcpy(old_root_entry[old_root_entries].name, name);
  2.1069 --	old_root_entry[old_root_entries].inode = inode;
  2.1070 --	old_root_entry[old_root_entries].inode_number = inode_number;
  2.1071 --	old_root_entry[old_root_entries++].type = type;
  2.1072 -+	old_root_entry[old_root_entries].name = strdup(name);
  2.1073 -+	old_root_entry[old_root_entries].inode.inode = inode;
  2.1074 -+	old_root_entry[old_root_entries].inode.inode_number = inode_number;
  2.1075 -+	old_root_entry[old_root_entries].inode.type = type;
  2.1076 -+	old_root_entry[old_root_entries++].inode.root_entry = TRUE;
  2.1077 - }
  2.1078 - 
  2.1079 - 
  2.1080 -@@ -4137,7 +4304,7 @@
  2.1081 - 
  2.1082 - 
  2.1083 - #define VERSION() \
  2.1084 --	printf("mksquashfs version 4.0 (2009/04/05)\n");\
  2.1085 -+	printf("mksquashfs version 4.1-CVS (2009/12/08)\n");\
  2.1086 - 	printf("copyright (C) 2009 Phillip Lougher <phillip@lougher.demon.co.uk>\n\n"); \
  2.1087 - 	printf("This program is free software; you can redistribute it and/or\n");\
  2.1088 - 	printf("modify it under the terms of the GNU General Public License\n");\
  2.1089 -@@ -4172,26 +4339,28 @@
  2.1090 - 	source_path = argv + 1;
  2.1091 - 	source = i - 2;
  2.1092 - 	for(; i < argc; i++) {
  2.1093 --		if(strcmp(argv[i], "-pf") == 0) {
  2.1094 -+		if(strcmp(argv[i], "-comp") == 0) {
  2.1095 - 			if(++i == argc) {
  2.1096 --				ERROR("%s: -pf missing filename\n", argv[0]);
  2.1097 -+				ERROR("%s: -comp missing compression type\n",
  2.1098 -+					argv[0]);
  2.1099 - 				exit(1);
  2.1100 - 			}
  2.1101 --			if(read_pseudo_file(&pseudo, argv[i]) == FALSE) {
  2.1102 --				ERROR("Failed to parse pseudo file \"%s\"\n",
  2.1103 --					argv[i]);
  2.1104 -+			comp_name = argv[i];
  2.1105 -+		} else if(strcmp(argv[i], "-pf") == 0) {
  2.1106 -+			if(++i == argc) {
  2.1107 -+				ERROR("%s: -pf missing filename\n", argv[0]);
  2.1108 - 				exit(1);
  2.1109 - 			}
  2.1110 -+			if(read_pseudo_file(&pseudo, argv[i]) == FALSE)
  2.1111 -+				exit(1);
  2.1112 - 		} else if(strcmp(argv[i], "-p") == 0) {
  2.1113 - 			if(++i == argc) {
  2.1114 - 				ERROR("%s: -p missing pseudo file definition\n",
  2.1115 - 					argv[0]);
  2.1116 - 				exit(1);
  2.1117 - 			}
  2.1118 --			if(read_pseudo_def(&pseudo, argv[i]) == FALSE) {
  2.1119 --				ERROR("Failed to parse pseudo definition\n");
  2.1120 -+			if(read_pseudo_def(&pseudo, argv[i]) == FALSE)
  2.1121 - 				exit(1);
  2.1122 --			}
  2.1123 - 		} else if(strcmp(argv[i], "-recover") == 0) {
  2.1124 - 			if(++i == argc) {
  2.1125 - 				ERROR("%s: -recover missing recovery file\n",
  2.1126 -@@ -4394,34 +4563,16 @@
  2.1127 - printOptions:
  2.1128 - 			ERROR("SYNTAX:%s source1 source2 ...  dest [options] "
  2.1129 - 				"[-e list of exclude\ndirs/files]\n", argv[0]);
  2.1130 --			ERROR("\nOptions are\n");
  2.1131 --			ERROR("-version\t\tprint version, licence and "
  2.1132 --				"copyright message\n");
  2.1133 --			ERROR("-recover <name>\t\trecover filesystem data "
  2.1134 --				"using recovery file <name>\n");
  2.1135 --			ERROR("-no-recovery\t\tdon't generate a recovery "
  2.1136 --				"file\n");
  2.1137 --			ERROR("-info\t\t\tprint files written to filesystem\n");
  2.1138 --			ERROR("-no-exports\t\tdon't make the filesystem "
  2.1139 --				"exportable via NFS\n");
  2.1140 --			ERROR("-no-progress\t\tdon't display the progress "
  2.1141 --				"bar\n");
  2.1142 --			ERROR("-no-sparse\t\tdon't detect sparse files\n");
  2.1143 -+			ERROR("\nFilesystem build options:\n");
  2.1144 -+			ERROR("-comp <comp>\t\tselect <comp> compression\n");
  2.1145 -+			ERROR("\t\t\tCompressors available:\n");
  2.1146 -+			display_compressors("\t\t\t", COMP_DEFAULT);
  2.1147 - 			ERROR("-b <block_size>\t\tset data block to "
  2.1148 - 				"<block_size>.  Default %d bytes\n",
  2.1149 - 				SQUASHFS_FILE_SIZE);
  2.1150 --			ERROR("-processors <number>\tUse <number> processors."
  2.1151 --				"  By default will use number of\n");
  2.1152 --			ERROR("\t\t\tprocessors available\n");
  2.1153 --			ERROR("-read-queue <size>\tSet input queue to <size> "
  2.1154 --				"Mbytes.  Default %d Mbytes\n",
  2.1155 --				READER_BUFFER_DEFAULT);
  2.1156 --			ERROR("-write-queue <size>\tSet output queue to <size> "
  2.1157 --				"Mbytes.  Default %d Mbytes\n",
  2.1158 --				WRITER_BUFFER_DEFAULT);
  2.1159 --			ERROR("-fragment-queue <size>\tSet fagment queue to "
  2.1160 --				"<size> Mbytes.  Default %d Mbytes\n",
  2.1161 --				FRAGMENT_BUFFER_DEFAULT);
  2.1162 -+			ERROR("-no-exports\t\tdon't make the filesystem "
  2.1163 -+				"exportable via NFS\n");
  2.1164 -+			ERROR("-no-sparse\t\tdon't detect sparse files\n");
  2.1165 - 			ERROR("-noI\t\t\tdo not compress inode table\n");
  2.1166 - 			ERROR("-noD\t\t\tdo not compress data blocks\n");
  2.1167 - 			ERROR("-noF\t\t\tdo not compress fragment blocks\n");
  2.1168 -@@ -4430,13 +4581,34 @@
  2.1169 - 				"files larger than block size\n");
  2.1170 - 			ERROR("-no-duplicates\t\tdo not perform duplicate "
  2.1171 - 				"checking\n");
  2.1172 --			ERROR("-noappend\t\tdo not append to existing "
  2.1173 --				"filesystem\n");
  2.1174 -+			ERROR("-all-root\t\tmake all files owned by root\n");
  2.1175 -+			ERROR("-force-uid uid\t\tset all file uids to uid\n");
  2.1176 -+			ERROR("-force-gid gid\t\tset all file gids to gid\n");
  2.1177 -+			ERROR("-nopad\t\t\tdo not pad filesystem to a multiple "
  2.1178 -+				"of 4K\n");
  2.1179 - 			ERROR("-keep-as-directory\tif one source directory is "
  2.1180 - 				"specified, create a root\n");
  2.1181 - 			ERROR("\t\t\tdirectory containing that directory, "
  2.1182 - 				"rather than the\n");
  2.1183 - 			ERROR("\t\t\tcontents of the directory\n");
  2.1184 -+			ERROR("\nFilesystem filter options:\n");
  2.1185 -+			ERROR("-p <pseudo-definition>\tAdd pseudo file definition\n");
  2.1186 -+			ERROR("-pf <pseudo-file>\tAdd list of pseudo file definitions\n");
  2.1187 -+			ERROR("-sort <sort_file>\tsort files according to "
  2.1188 -+				"priorities in <sort_file>.  One\n");
  2.1189 -+			ERROR("\t\t\tfile or dir with priority per line.  "
  2.1190 -+				"Priority -32768 to\n");
  2.1191 -+			ERROR("\t\t\t32767, default priority 0\n");
  2.1192 -+			ERROR("-ef <exclude_file>\tlist of exclude dirs/files."
  2.1193 -+				"  One per line\n");
  2.1194 -+			ERROR("-wildcards\t\tAllow extended shell wildcards "
  2.1195 -+				"(globbing) to be used in\n\t\t\texclude "
  2.1196 -+				"dirs/files\n");
  2.1197 -+			ERROR("-regex\t\t\tAllow POSIX regular expressions to "
  2.1198 -+				"be used in exclude\n\t\t\tdirs/files\n");
  2.1199 -+			ERROR("\nFilesystem append options:\n");
  2.1200 -+			ERROR("-noappend\t\tdo not append to existing "
  2.1201 -+				"filesystem\n");
  2.1202 - 			ERROR("-root-becomes <name>\twhen appending source "
  2.1203 - 				"files/directories, make the\n");
  2.1204 - 			ERROR("\t\t\toriginal root become a subdirectory in "
  2.1205 -@@ -4444,11 +4616,29 @@
  2.1206 - 			ERROR("\t\t\tcalled <name>, rather than adding the new "
  2.1207 - 				"source items\n");
  2.1208 - 			ERROR("\t\t\tto the original root\n");
  2.1209 --			ERROR("-all-root\t\tmake all files owned by root\n");
  2.1210 --			ERROR("-force-uid uid\t\tset all file uids to uid\n");
  2.1211 --			ERROR("-force-gid gid\t\tset all file gids to gid\n");
  2.1212 --			ERROR("-nopad\t\t\tdo not pad filesystem to a multiple "
  2.1213 --				"of 4K\n");
  2.1214 -+			ERROR("\nMksquashfs runtime options:\n");
  2.1215 -+			ERROR("-version\t\tprint version, licence and "
  2.1216 -+				"copyright message\n");
  2.1217 -+			ERROR("-recover <name>\t\trecover filesystem data "
  2.1218 -+				"using recovery file <name>\n");
  2.1219 -+			ERROR("-no-recovery\t\tdon't generate a recovery "
  2.1220 -+				"file\n");
  2.1221 -+			ERROR("-info\t\t\tprint files written to filesystem\n");
  2.1222 -+			ERROR("-no-progress\t\tdon't display the progress "
  2.1223 -+				"bar\n");
  2.1224 -+			ERROR("-processors <number>\tUse <number> processors."
  2.1225 -+				"  By default will use number of\n");
  2.1226 -+			ERROR("\t\t\tprocessors available\n");
  2.1227 -+			ERROR("-read-queue <size>\tSet input queue to <size> "
  2.1228 -+				"Mbytes.  Default %d Mbytes\n",
  2.1229 -+				READER_BUFFER_DEFAULT);
  2.1230 -+			ERROR("-write-queue <size>\tSet output queue to <size> "
  2.1231 -+				"Mbytes.  Default %d Mbytes\n",
  2.1232 -+				WRITER_BUFFER_DEFAULT);
  2.1233 -+			ERROR("-fragment-queue <size>\tSet fagment queue to "
  2.1234 -+				"<size> Mbytes.  Default %d Mbytes\n",
  2.1235 -+				FRAGMENT_BUFFER_DEFAULT);
  2.1236 -+			ERROR("\nMiscellaneous options:\n");
  2.1237 - 			ERROR("-root-owned\t\talternative name for -all-root"
  2.1238 - 				"\n");
  2.1239 - 			ERROR("-noInodeCompression\talternative name for -noI"
  2.1240 -@@ -4457,20 +4647,8 @@
  2.1241 - 				"\n");
  2.1242 - 			ERROR("-noFragmentCompression\talternative name for "
  2.1243 - 				"-noF\n");
  2.1244 --			ERROR("-sort <sort_file>\tsort files according to "
  2.1245 --				"priorities in <sort_file>.  One\n");
  2.1246 --			ERROR("\t\t\tfile or dir with priority per line.  "
  2.1247 --				"Priority -32768 to\n");
  2.1248 --			ERROR("\t\t\t32767, default priority 0\n");
  2.1249 --			ERROR("-ef <exclude_file>\tlist of exclude dirs/files."
  2.1250 --				"  One per line\n");
  2.1251 --			ERROR("-wildcards\t\tAllow extended shell wildcards "
  2.1252 --				"(globbing) to be used in\n\t\t\texclude "
  2.1253 --				"dirs/files\n");
  2.1254 --			ERROR("-regex\t\t\tAllow POSIX regular expressions to "
  2.1255 --				"be used in exclude\n\t\t\tdirs/files\n");
  2.1256 --			ERROR("-p <pseudo-definition>\tAdd pseudo file definition\n");
  2.1257 --			ERROR("-pf <pseudo-file>\tAdd list of pseudo file definitions\n");
  2.1258 -+			ERROR("\nCompressors available:\n");
  2.1259 -+			display_compressors("", COMP_DEFAULT);
  2.1260 - 			exit(1);
  2.1261 - 		}
  2.1262 - 	}
  2.1263 -@@ -4548,11 +4726,10 @@
  2.1264 - 			fclose(fd);
  2.1265 - 		} else if(strcmp(argv[i], "-e") == 0)
  2.1266 - 			break;
  2.1267 --		else if(strcmp(argv[i], "-b") == 0 ||
  2.1268 --				strcmp(argv[i], "-root-becomes") == 0 ||
  2.1269 -+		else if(strcmp(argv[i], "-root-becomes") == 0 ||
  2.1270 - 				strcmp(argv[i], "-sort") == 0 ||
  2.1271 - 				strcmp(argv[i], "-pf") == 0 ||
  2.1272 --				strcmp(argv[i], "-p") == 0)
  2.1273 -+				strcmp(argv[i], "-comp") == 0)
  2.1274 - 			i++;
  2.1275 - 
  2.1276 - 	if(i != argc) {
  2.1277 -@@ -4574,11 +4751,10 @@
  2.1278 - 			sorted ++;
  2.1279 - 		} else if(strcmp(argv[i], "-e") == 0)
  2.1280 - 			break;
  2.1281 --		else if(strcmp(argv[i], "-b") == 0 ||
  2.1282 --				strcmp(argv[i], "-root-becomes") == 0 ||
  2.1283 -+		else if(strcmp(argv[i], "-root-becomes") == 0 ||
  2.1284 - 				strcmp(argv[i], "-ef") == 0 ||
  2.1285 - 				strcmp(argv[i], "-pf") == 0 ||
  2.1286 --				strcmp(argv[i], "-p") == 0)
  2.1287 -+				strcmp(argv[i], "-comp") == 0)
  2.1288 - 			i++;
  2.1289 - 
  2.1290 - #ifdef SQUASHFS_TRACE
  2.1291 -@@ -4586,7 +4762,8 @@
  2.1292 - #endif
  2.1293 - 
  2.1294 - 	if(!delete) {
  2.1295 --	        if(read_super(fd, &sBlk, argv[source + 1]) == 0) {
  2.1296 -+	        comp = read_super(fd, &sBlk, argv[source + 1]);
  2.1297 -+	        if(comp == NULL) {
  2.1298 - 			ERROR("Failed to read existing filesystem - will not "
  2.1299 - 				"overwrite - ABORTING!\n");
  2.1300 - 			ERROR("To force Mksquashfs to write to this block "
  2.1301 -@@ -4603,6 +4780,15 @@
  2.1302 - 		always_use_fragments = SQUASHFS_ALWAYS_FRAGMENTS(sBlk.flags);
  2.1303 - 		duplicate_checking = SQUASHFS_DUPLICATES(sBlk.flags);
  2.1304 - 		exportable = SQUASHFS_EXPORTABLE(sBlk.flags);
  2.1305 -+	} else {
  2.1306 -+		comp = lookup_compressor(comp_name);
  2.1307 -+		if(!comp->supported) {
  2.1308 -+			ERROR("FATAL_ERROR: Compressor \"%s\" is not "
  2.1309 -+				"supported!\n", comp_name);
  2.1310 -+			ERROR("Compressors available:\n");
  2.1311 -+			display_compressors("", COMP_DEFAULT);
  2.1312 -+			EXIT_MKSQUASHFS();
  2.1313 -+		}
  2.1314 - 	}
  2.1315 - 
  2.1316 - 	initialise_threads();
  2.1317 -@@ -4648,8 +4834,8 @@
  2.1318 - 			"size %d\n", SQUASHFS_MAJOR, s_minor, argv[source + 1],
  2.1319 - 			block_size);
  2.1320 - 		printf("All -b, -noI, -noD, -noF, no-duplicates, no-fragments, "
  2.1321 --			"-always-use-fragments and -exportable options ignored"
  2.1322 --			"\n");
  2.1323 -+			"-always-use-fragments,\n-exportable and -comp options "
  2.1324 -+			"ignored\n");
  2.1325 - 		printf("\nIf appending is not wanted, please re-run with "
  2.1326 - 			"-noappend specified!\n\n");
  2.1327 - 
  2.1328 -@@ -4803,8 +4989,7 @@
  2.1329 - 
  2.1330 - 	sBlk.bytes_used = bytes;
  2.1331 - 
  2.1332 --	/* Only compression supported */
  2.1333 --	sBlk.compression = ZLIB_COMPRESSION;
  2.1334 -+	sBlk.compression = comp->id;
  2.1335 - 
  2.1336 - 	/* Xattrs are not currently supported */
  2.1337 - 	sBlk.xattr_table_start = SQUASHFS_INVALID_BLK;
  2.1338 -@@ -4820,6 +5005,8 @@
  2.1339 - 
  2.1340 - 	close(fd);
  2.1341 - 
  2.1342 -+	delete_pseudo_files();
  2.1343 -+
  2.1344 - 	if(recovery_file[0] != '\0')
  2.1345 - 		unlink(recovery_file);
  2.1346 - 
  2.1347 -@@ -4827,9 +5014,9 @@
  2.1348 - 		* sizeof(unsigned short) + guid_count * sizeof(unsigned short) +
  2.1349 - 		sizeof(squashfs_super_block);
  2.1350 - 
  2.1351 --	printf("\n%sSquashfs %d.%d filesystem, data block size %d\n",
  2.1352 --		exportable ? "Exportable " : "", SQUASHFS_MAJOR, SQUASHFS_MINOR,
  2.1353 --		block_size);
  2.1354 -+	printf("\n%sSquashfs %d.%d filesystem, %s compressed, data block size"
  2.1355 -+		" %d\n", exportable ? "Exportable " : "", SQUASHFS_MAJOR,
  2.1356 -+		SQUASHFS_MINOR, comp->name, block_size);
  2.1357 - 	printf("\t%s data, %s metadata, %s fragments\n",
  2.1358 - 		noD ? "uncompressed" : "compressed", noI ?  "uncompressed" :
  2.1359 - 		"compressed", no_fragments ? "no" : noF ? "uncompressed" :
  2.1360 -
  2.1361 ---- squashfs-4.0/squashfs-tools/par_mksquashfs/README	Thu Jan  1 01:00:00 1970
  2.1362 -+++ squashfs-4.0/squashfs-tools/par_mksquashfs/README	Mon Nov  6 01:27:32 2006
  2.1363 -@@ -0,0 +1,2 @@
  2.1364 -+par_mksquashfs is now the standard mksquashfs, and so this directory is now empty.
  2.1365 -+
  2.1366 -
  2.1367 ---- squashfs-4.0/squashfs-tools/pseudo.c	Sun Apr  5 04:01:58 2009
  2.1368 -+++ squashfs-4.0/squashfs-tools/pseudo.c	Thu Sep 10 06:17:48 2009
  2.1369 -@@ -30,6 +30,7 @@
  2.1370 - #include <string.h>
  2.1371 - #include <stdlib.h>
  2.1372 - #include <sys/types.h>
  2.1373 -+#include <sys/wait.h>
  2.1374 - 
  2.1375 - #include "pseudo.h"
  2.1376 - 
  2.1377 -@@ -55,6 +56,9 @@
  2.1378 - #define TRUE 1
  2.1379 - #define FALSE 0
  2.1380 - 
  2.1381 -+struct pseudo_dev **pseudo_file = NULL;
  2.1382 -+int pseudo_count = 0;
  2.1383 -+
  2.1384 - static void dump_pseudo(struct pseudo *pseudo, char *string)
  2.1385 - {
  2.1386 - 	int i;
  2.1387 -@@ -99,7 +103,7 @@
  2.1388 - 	char *target, char *alltarget)
  2.1389 - {
  2.1390 - 	char targname[1024];
  2.1391 --	int i, error;
  2.1392 -+	int i;
  2.1393 - 
  2.1394 - 	target = get_component(target, targname);
  2.1395 - 
  2.1396 -@@ -128,12 +132,8 @@
  2.1397 - 		if(target[0] == '\0') {
  2.1398 - 			/* at leaf pathname component */
  2.1399 - 			pseudo->name[i].pseudo = NULL;
  2.1400 --			pseudo->name[i].dev = malloc(sizeof(struct pseudo_dev));
  2.1401 --			if(pseudo->name[i].dev == NULL)
  2.1402 --				BAD_ERROR("failed to allocate pseudo file\n");
  2.1403 - 			pseudo->name[i].pathname = strdup(alltarget);
  2.1404 --			memcpy(pseudo->name[i].dev, pseudo_dev,
  2.1405 --				sizeof(struct pseudo_dev));
  2.1406 -+			pseudo->name[i].dev = pseudo_dev;
  2.1407 - 		} else {
  2.1408 - 			/* recurse adding child components */
  2.1409 - 			pseudo->name[i].dev = NULL;
  2.1410 -@@ -169,15 +169,9 @@
  2.1411 - 			if(target[0] == '\0') {
  2.1412 - 				if(pseudo->name[i].dev == NULL &&
  2.1413 - 						pseudo_dev->type == 'd') {
  2.1414 --					pseudo->name[i].dev =
  2.1415 --						malloc(sizeof(struct pseudo_dev));
  2.1416 --					if(pseudo->name[i].dev == NULL)
  2.1417 --						BAD_ERROR("failed to allocate "
  2.1418 --							"pseudo file\n");
  2.1419 - 					pseudo->name[i].pathname =
  2.1420 - 						strdup(alltarget);
  2.1421 --					memcpy(pseudo->name[i].dev, pseudo_dev,
  2.1422 --						sizeof(struct pseudo_dev));
  2.1423 -+					pseudo->name[i].dev = pseudo_dev;
  2.1424 - 				} else
  2.1425 - 					ERROR("%s already exists as a "
  2.1426 - 						"directory.  Ignoring %s!\n",
  2.1427 -@@ -229,16 +223,113 @@
  2.1428 - }
  2.1429 - 
  2.1430 - 
  2.1431 -+int exec_file(char *command, struct pseudo_dev *dev)
  2.1432 -+{
  2.1433 -+	int child, res;
  2.1434 -+	static pid_t pid = -1;
  2.1435 -+	int pipefd[2];
  2.1436 -+#ifdef USE_TMP_FILE
  2.1437 -+	char filename[1024];
  2.1438 -+	int status;
  2.1439 -+	static int number = 0;
  2.1440 -+#endif
  2.1441 -+
  2.1442 -+	if(pid == -1)
  2.1443 -+		pid = getpid();
  2.1444 -+
  2.1445 -+#ifdef USE_TMP_FILE
  2.1446 -+	sprintf(filename, "/tmp/squashfs_pseudo_%d_%d", pid, number ++);
  2.1447 -+	pipefd[1] = open(filename, O_CREAT | O_TRUNC | O_RDWR, S_IRWXU);
  2.1448 -+	if(pipefd[1] == -1) {
  2.1449 -+		printf("open failed\n");
  2.1450 -+		return -1;
  2.1451 -+	}
  2.1452 -+#else
  2.1453 -+	res = pipe(pipefd);
  2.1454 -+	if(res == -1) {
  2.1455 -+		printf("pipe failed\n");
  2.1456 -+		return -1;
  2.1457 -+	}
  2.1458 -+#endif
  2.1459 -+
  2.1460 -+	child = fork();
  2.1461 -+	if(child == -1) {
  2.1462 -+		printf("fork failed\n");
  2.1463 -+		goto failed;
  2.1464 -+	}
  2.1465 -+
  2.1466 -+	if(child == 0) {
  2.1467 -+		close(STDOUT_FILENO);
  2.1468 -+		res = dup(pipefd[1]);
  2.1469 -+		if(res == -1) {
  2.1470 -+			printf("dup failed\n");
  2.1471 -+			exit(EXIT_FAILURE);
  2.1472 -+		}
  2.1473 -+		execl("/bin/sh", "sh", "-c", command, (char *) NULL);
  2.1474 -+		printf("execl failed\n");
  2.1475 -+		exit(EXIT_FAILURE);
  2.1476 -+	}
  2.1477 -+
  2.1478 -+#ifdef USE_TMP_FILE
  2.1479 -+	res = waitpid(child, &status, 0);
  2.1480 -+	close(pipefd[1]);
  2.1481 -+	if(res != -1 && WIFEXITED(status) && WEXITSTATUS(status) == 0) {
  2.1482 -+		dev->filename = strdup(filename);
  2.1483 -+		return 0;
  2.1484 -+	}
  2.1485 -+failed:
  2.1486 -+	unlink(filename);
  2.1487 -+	return -1;
  2.1488 -+#else
  2.1489 -+	close(pipefd[1]);
  2.1490 -+	dev->fd = pipefd[0];
  2.1491 -+	dev->child = child;
  2.1492 -+	return 0;
  2.1493 -+failed:
  2.1494 -+	return -1;
  2.1495 -+#endif
  2.1496 -+}
  2.1497 -+
  2.1498 -+
  2.1499 -+void add_pseudo_file(struct pseudo_dev *dev)
  2.1500 -+{
  2.1501 -+	pseudo_file = realloc(pseudo_file, (pseudo_count + 1) *
  2.1502 -+		sizeof(struct pseudo_dev *));
  2.1503 -+	if(pseudo_file == NULL)
  2.1504 -+		BAD_ERROR("Failed to realloc pseudo_file\n");
  2.1505 -+
  2.1506 -+	dev->pseudo_id = pseudo_count;
  2.1507 -+	pseudo_file[pseudo_count ++] = dev;
  2.1508 -+}
  2.1509 -+
  2.1510 -+
  2.1511 -+void delete_pseudo_files()
  2.1512 -+{
  2.1513 -+#ifdef USE_TMP_FILE
  2.1514 -+	int i;
  2.1515 -+
  2.1516 -+	for(i = 0; i < pseudo_count; i++)
  2.1517 -+		unlink(pseudo_file[i]->filename);
  2.1518 -+#endif
  2.1519 -+}
  2.1520 -+
  2.1521 -+
  2.1522 -+struct pseudo_dev *get_pseudo_file(int pseudo_id)
  2.1523 -+{
  2.1524 -+	return pseudo_file[pseudo_id];
  2.1525 -+}
  2.1526 -+
  2.1527 -+
  2.1528 - int read_pseudo_def(struct pseudo **pseudo, char *def)
  2.1529 - {
  2.1530 --	int n;
  2.1531 -+	int n, bytes;
  2.1532 - 	unsigned int major = 0, minor = 0, mode;
  2.1533 - 	char filename[2048], type, suid[100], sgid[100], *ptr;
  2.1534 - 	long long uid, gid;
  2.1535 --	struct pseudo_dev dev;
  2.1536 -+	struct pseudo_dev *dev;
  2.1537 - 
  2.1538 --	n = sscanf(def, "%s %c %o %s %s %u %u", filename, &type, &mode, suid, sgid,
  2.1539 --			&major, &minor);
  2.1540 -+	n = sscanf(def, "%s %c %o %s %s %n", filename, &type, &mode, suid,
  2.1541 -+			sgid, &bytes);
  2.1542 - 
  2.1543 - 	if(n < 5) {
  2.1544 - 		ERROR("Not enough or invalid arguments in pseudo file "
  2.1545 -@@ -249,7 +340,9 @@
  2.1546 - 	switch(type) {
  2.1547 - 	case 'b':
  2.1548 - 	case 'c':
  2.1549 --		if(n < 7) {
  2.1550 -+		n = sscanf(def + bytes,  "%u %u", &major, &minor);
  2.1551 -+
  2.1552 -+		if(n < 2) {
  2.1553 - 			ERROR("Not enough or invalid arguments in pseudo file "
  2.1554 - 				"definition\n");
  2.1555 - 			goto error;
  2.1556 -@@ -265,54 +358,59 @@
  2.1557 - 			goto error;
  2.1558 - 		}
  2.1559 - 
  2.1560 --		/* fall through */
  2.1561 --	case 'd':
  2.1562 --		if(mode > 0777) {
  2.1563 --			ERROR("Mode %o out of range\n", mode);
  2.1564 -+	case 'f':
  2.1565 -+		if(def[bytes] == '\0') {
  2.1566 -+			ERROR("Not enough arguments in pseudo file "
  2.1567 -+				"definition\n");
  2.1568 - 			goto error;
  2.1569 --		}
  2.1570 --
  2.1571 --		uid = strtoll(suid, &ptr, 10);
  2.1572 --		if(*ptr == '\0') {
  2.1573 --			if(uid < 0 || uid > ((1LL << 32) - 1)) {
  2.1574 --				ERROR("Uid %s out of range\n", suid);
  2.1575 --				goto error;
  2.1576 --			}
  2.1577 --		} else {
  2.1578 --			struct passwd *pwuid = getpwnam(suid);
  2.1579 --			if(pwuid)
  2.1580 --				uid = pwuid->pw_uid;
  2.1581 --			else {
  2.1582 --				ERROR("Uid %s invalid uid or unknown user\n",
  2.1583 --					suid);
  2.1584 --				goto error;
  2.1585 --			}
  2.1586 --		}
  2.1587 --		
  2.1588 --		gid = strtoll(sgid, &ptr, 10);
  2.1589 --		if(*ptr == '\0') {
  2.1590 --			if(gid < 0 || gid > ((1LL << 32) - 1)) {
  2.1591 --				ERROR("Gid %s out of range\n", sgid);
  2.1592 --				goto error;
  2.1593 --			}
  2.1594 --		} else {
  2.1595 --			struct group *grgid = getgrnam(sgid);
  2.1596 --			if(grgid)
  2.1597 --				gid = grgid->gr_gid;
  2.1598 --			else {
  2.1599 --				ERROR("Gid %s invalid uid or unknown user\n",
  2.1600 --					sgid);
  2.1601 --				goto error;
  2.1602 --			}
  2.1603 --		}
  2.1604 --
  2.1605 -+		}	
  2.1606 - 		break;
  2.1607 -+	case 'd':
  2.1608 -+	case 'm':
  2.1609 -+		break;
  2.1610 - 	default:
  2.1611 - 		ERROR("Unsupported type %c\n", type);
  2.1612 - 		goto error;
  2.1613 - 	}
  2.1614 - 
  2.1615 - 
  2.1616 -+	if(mode > 0777) {
  2.1617 -+		ERROR("Mode %o out of range\n", mode);
  2.1618 -+		goto error;
  2.1619 -+	}
  2.1620 -+
  2.1621 -+	uid = strtoll(suid, &ptr, 10);
  2.1622 -+	if(*ptr == '\0') {
  2.1623 -+		if(uid < 0 || uid > ((1LL << 32) - 1)) {
  2.1624 -+			ERROR("Uid %s out of range\n", suid);
  2.1625 -+			goto error;
  2.1626 -+		}
  2.1627 -+	} else {
  2.1628 -+		struct passwd *pwuid = getpwnam(suid);
  2.1629 -+		if(pwuid)
  2.1630 -+			uid = pwuid->pw_uid;
  2.1631 -+		else {
  2.1632 -+			ERROR("Uid %s invalid uid or unknown user\n", suid);
  2.1633 -+			goto error;
  2.1634 -+		}
  2.1635 -+	}
  2.1636 -+		
  2.1637 -+	gid = strtoll(sgid, &ptr, 10);
  2.1638 -+	if(*ptr == '\0') {
  2.1639 -+		if(gid < 0 || gid > ((1LL << 32) - 1)) {
  2.1640 -+			ERROR("Gid %s out of range\n", sgid);
  2.1641 -+			goto error;
  2.1642 -+		}
  2.1643 -+	} else {
  2.1644 -+		struct group *grgid = getgrnam(sgid);
  2.1645 -+		if(grgid)
  2.1646 -+			gid = grgid->gr_gid;
  2.1647 -+		else {
  2.1648 -+			ERROR("Gid %s invalid uid or unknown user\n", sgid);
  2.1649 -+			goto error;
  2.1650 -+		}
  2.1651 -+	}
  2.1652 -+
  2.1653 - 	switch(type) {
  2.1654 - 	case 'b':
  2.1655 - 		mode |= S_IFBLK;
  2.1656 -@@ -323,16 +421,37 @@
  2.1657 - 	case 'd':
  2.1658 - 		mode |= S_IFDIR;
  2.1659 - 		break;
  2.1660 -+	case 'f':
  2.1661 -+		mode |= S_IFREG;
  2.1662 -+		break;
  2.1663 - 	}
  2.1664 - 
  2.1665 --	dev.type = type;
  2.1666 --	dev.mode = mode;
  2.1667 --	dev.uid = uid;
  2.1668 --	dev.gid = gid;
  2.1669 --	dev.major = major;
  2.1670 --	dev.minor = minor;
  2.1671 -+	dev = malloc(sizeof(struct pseudo_dev));
  2.1672 -+	if(dev == NULL)
  2.1673 -+		BAD_ERROR("Failed to create pseudo_dev\n");
  2.1674 - 
  2.1675 --	*pseudo = add_pseudo(*pseudo, &dev, filename, filename);
  2.1676 -+	dev->type = type;
  2.1677 -+	dev->mode = mode;
  2.1678 -+	dev->uid = uid;
  2.1679 -+	dev->gid = gid;
  2.1680 -+	dev->major = major;
  2.1681 -+	dev->minor = minor;
  2.1682 -+
  2.1683 -+	if(type == 'f') {
  2.1684 -+		int res;
  2.1685 -+
  2.1686 -+		printf("Executing dynamic pseudo file\n");
  2.1687 -+		printf("\t\"%s\"\n", def);
  2.1688 -+		res = exec_file(def + bytes, dev);
  2.1689 -+		if(res == -1) {
  2.1690 -+			ERROR("Failed to execute dynamic pseudo file definition"
  2.1691 -+				" \"%s\"\n", def);
  2.1692 -+			return FALSE;
  2.1693 -+		}
  2.1694 -+		add_pseudo_file(dev);
  2.1695 -+	}
  2.1696 -+
  2.1697 -+	*pseudo = add_pseudo(*pseudo, dev, filename, filename);
  2.1698 - 
  2.1699 - 	return TRUE;
  2.1700 - 
  2.1701 -
  2.1702 ---- squashfs-4.0/squashfs-tools/pseudo.h	Sat Apr  4 03:44:24 2009
  2.1703 -+++ squashfs-4.0/squashfs-tools/pseudo.h	Fri Sep 11 14:10:58 2009
  2.1704 -@@ -27,6 +27,12 @@
  2.1705 - 	unsigned int	gid;
  2.1706 - 	unsigned int	major;
  2.1707 - 	unsigned int	minor;
  2.1708 -+	int		pseudo_id;
  2.1709 -+	int		fd;
  2.1710 -+	int		child;
  2.1711 -+#ifdef USE_TMP_FILE
  2.1712 -+	char		*filename;
  2.1713 -+#endif
  2.1714 - };
  2.1715 - 
  2.1716 - struct pseudo_entry {
  2.1717 -@@ -46,3 +52,5 @@
  2.1718 - extern int read_pseudo_file(struct pseudo **, char *);
  2.1719 - extern struct pseudo *pseudo_subdir(char *, struct pseudo *);
  2.1720 - extern struct pseudo_entry *pseudo_readdir(struct pseudo *);
  2.1721 -+extern struct pseudo_dev *get_pseudo_file(int);
  2.1722 -+extern void delete_pseudo_files();
  2.1723 -
  2.1724 ---- squashfs-4.0/squashfs-tools/read_fs.c	Tue Mar 31 06:23:14 2009
  2.1725 -+++ squashfs-4.0/squashfs-tools/read_fs.c	Mon Aug 24 20:28:04 2009
  2.1726 -@@ -36,7 +36,6 @@
  2.1727 - #include <fcntl.h>
  2.1728 - #include <errno.h>
  2.1729 - #include <string.h>
  2.1730 --#include <zlib.h>
  2.1731 - #include <sys/mman.h>
  2.1732 - 
  2.1733 - #ifndef linux
  2.1734 -@@ -51,6 +50,7 @@
  2.1735 - #include "squashfs_swap.h"
  2.1736 - #include "read_fs.h"
  2.1737 - #include "global.h"
  2.1738 -+#include "compressor.h"
  2.1739 - 
  2.1740 - #include <stdlib.h>
  2.1741 - 
  2.1742 -@@ -66,7 +66,9 @@
  2.1743 - 						fprintf(stderr, s, ## args); \
  2.1744 - 					} while(0)
  2.1745 - 
  2.1746 --int read_block(int fd, long long start, long long *next, unsigned char *block,
  2.1747 -+static struct compressor *comp;
  2.1748 -+
  2.1749 -+int read_block(int fd, long long start, long long *next, void *block,
  2.1750 - 	squashfs_super_block *sBlk)
  2.1751 - {
  2.1752 - 	unsigned short c_byte;
  2.1753 -@@ -77,32 +79,24 @@
  2.1754 - 
  2.1755 - 	if(SQUASHFS_COMPRESSED(c_byte)) {
  2.1756 - 		char buffer[SQUASHFS_METADATA_SIZE];
  2.1757 --		int res;
  2.1758 --		unsigned long bytes = SQUASHFS_METADATA_SIZE;
  2.1759 -+		int error, res;
  2.1760 - 
  2.1761 - 		c_byte = SQUASHFS_COMPRESSED_SIZE(c_byte);
  2.1762 - 		read_destination(fd, start + offset, c_byte, buffer);
  2.1763 - 
  2.1764 --		res = uncompress(block, &bytes, (const unsigned char *) buffer,
  2.1765 --			c_byte);
  2.1766 --		if(res != Z_OK) {
  2.1767 --			if(res == Z_MEM_ERROR)
  2.1768 --				ERROR("zlib::uncompress failed, not enough "
  2.1769 --					"memory\n");
  2.1770 --			else if(res == Z_BUF_ERROR)
  2.1771 --				ERROR("zlib::uncompress failed, not enough "
  2.1772 --					"room in output buffer\n");
  2.1773 --			else
  2.1774 --				ERROR("zlib::uncompress failed, unknown error "
  2.1775 --					"%d\n", res);
  2.1776 -+		res = comp->uncompress(block, buffer, c_byte,
  2.1777 -+			SQUASHFS_METADATA_SIZE, &error);
  2.1778 -+		if(res == -1) {
  2.1779 -+			ERROR("%s uncompress failed with error code %d\n",
  2.1780 -+				comp->name, error);
  2.1781 - 			return 0;
  2.1782 - 		}
  2.1783 - 		if(next)
  2.1784 - 			*next = start + offset + c_byte;
  2.1785 --		return bytes;
  2.1786 -+		return res;
  2.1787 - 	} else {
  2.1788 - 		c_byte = SQUASHFS_COMPRESSED_SIZE(c_byte);
  2.1789 --		read_destination(fd, start + offset, c_byte, (char *) block);
  2.1790 -+		read_destination(fd, start + offset, c_byte, block);
  2.1791 - 		if(next)
  2.1792 - 			*next = start + offset + c_byte;
  2.1793 - 		return c_byte;
  2.1794 -@@ -356,7 +350,7 @@
  2.1795 - }
  2.1796 - 
  2.1797 - 
  2.1798 --int read_super(int fd, squashfs_super_block *sBlk, char *source)
  2.1799 -+struct compressor *read_super(int fd, squashfs_super_block *sBlk, char *source)
  2.1800 - {
  2.1801 - 	read_destination(fd, SQUASHFS_START, sizeof(squashfs_super_block),
  2.1802 - 		(char *) sBlk);
  2.1803 -@@ -388,8 +382,18 @@
  2.1804 - 		goto failed_mount;
  2.1805 - 	}
  2.1806 - 
  2.1807 -+	/* Check the compression type */
  2.1808 -+	comp = lookup_compressor_id(sBlk->compression);
  2.1809 -+	if(!comp->supported) {
  2.1810 -+		ERROR("Filesystem on %s uses %s compression, this is"
  2.1811 -+			"unsupported by this version\n", source, comp->name);
  2.1812 -+		display_compressors("", "");
  2.1813 -+		goto failed_mount;
  2.1814 -+	}
  2.1815 -+
  2.1816 - 	printf("Found a valid %sSQUASHFS superblock on %s.\n",
  2.1817 - 		SQUASHFS_EXPORTABLE(sBlk->flags) ? "exportable " : "", source);
  2.1818 -+	printf("\tCompression used %s\n", comp->name);
  2.1819 - 	printf("\tInodes are %scompressed\n",
  2.1820 - 		SQUASHFS_UNCOMPRESSED_INODES(sBlk->flags) ? "un" : "");
  2.1821 - 	printf("\tData is %scompressed\n",
  2.1822 -@@ -417,10 +421,10 @@
  2.1823 - 	TRACE("sBlk->lookup_table_start %llx\n", sBlk->lookup_table_start);
  2.1824 - 	printf("\n");
  2.1825 - 
  2.1826 --	return TRUE;
  2.1827 -+	return comp;
  2.1828 - 
  2.1829 - failed_mount:
  2.1830 --	return FALSE;
  2.1831 -+	return NULL;
  2.1832 - }
  2.1833 - 
  2.1834 - 
  2.1835 -@@ -514,12 +518,17 @@
  2.1836 - 	SQUASHFS_INSWAP_ID_BLOCKS(index, indexes);
  2.1837 - 
  2.1838 - 	for(i = 0; i < indexes; i++) {
  2.1839 --		int length;
  2.1840 --		length = read_block(fd, index[i], NULL,
  2.1841 -+		int length = read_block(fd, index[i], NULL,
  2.1842 - 			((unsigned char *) id_table) +
  2.1843 - 			(i * SQUASHFS_METADATA_SIZE), sBlk);
  2.1844 - 		TRACE("Read id table block %d, from 0x%llx, length %d\n", i,
  2.1845 - 			index[i], length);
  2.1846 -+		if(length == 0) {
  2.1847 -+			ERROR("Failed to read id table block %d, from 0x%llx, "
  2.1848 -+				"length %d\n", i, index[i], length);
  2.1849 -+			free(id_table);
  2.1850 -+			return NULL;
  2.1851 -+		}
  2.1852 - 	}
  2.1853 - 
  2.1854 - 	SQUASHFS_INSWAP_INTS(id_table, sBlk->no_ids);
  2.1855 -@@ -563,6 +572,13 @@
  2.1856 - 			(i * SQUASHFS_METADATA_SIZE), sBlk);
  2.1857 - 		TRACE("Read fragment table block %d, from 0x%llx, length %d\n",
  2.1858 - 			i, fragment_table_index[i], length);
  2.1859 -+		if(length == 0) {
  2.1860 -+			ERROR("Failed to read fragment table block %d, from "
  2.1861 -+				"0x%llx, length %d\n", i,
  2.1862 -+				fragment_table_index[i], length);
  2.1863 -+			free(*fragment_table);
  2.1864 -+			return 0;
  2.1865 -+		}
  2.1866 - 	}
  2.1867 - 
  2.1868 - 	for(i = 0; i < sBlk->fragments; i++)
  2.1869 -@@ -599,6 +615,13 @@
  2.1870 - 			(i * SQUASHFS_METADATA_SIZE), sBlk);
  2.1871 - 		TRACE("Read inode lookup table block %d, from 0x%llx, length "
  2.1872 - 			"%d\n", i, index[i], length);
  2.1873 -+		if(length == 0) {
  2.1874 -+			ERROR("Failed to read inode lookup table block %d, "
  2.1875 -+				"from 0x%llx, length %d\n", i, index[i],
  2.1876 -+				length);
  2.1877 -+			free(*inode_lookup_table);
  2.1878 -+			return 0;
  2.1879 -+		}
  2.1880 - 	}
  2.1881 - 
  2.1882 - 	SQUASHFS_INSWAP_LONG_LONGS(*inode_lookup_table, sBlk->inodes);
  2.1883 -
  2.1884 ---- squashfs-4.0/squashfs-tools/sort.c	Tue Mar 31 06:25:53 2009
  2.1885 -+++ squashfs-4.0/squashfs-tools/sort.c	Sat Aug 29 07:41:45 2009
  2.1886 -@@ -198,7 +198,7 @@
  2.1887 - 	while(dir->current_count < dir->count) {
  2.1888 - 		struct dir_ent *dir_ent = dir->list[dir->current_count++];
  2.1889 - 		struct stat *buf = &dir_ent->inode->buf;
  2.1890 --		if(dir_ent->data)
  2.1891 -+		if(dir_ent->inode->root_entry)
  2.1892 - 			continue;
  2.1893 - 
  2.1894 - 		switch(buf->st_mode & S_IFMT) {
  2.1895 -@@ -254,6 +254,7 @@
  2.1896 - 				write_file(&inode, entry->dir, &duplicate_file);
  2.1897 - 				INFO("file %s, uncompressed size %lld bytes %s"
  2.1898 - 					"\n", entry->dir->pathname,
  2.1899 -+					(long long)
  2.1900 - 					entry->dir->inode->buf.st_size,
  2.1901 - 					duplicate_file ? "DUPLICATE" : "");
  2.1902 - 				entry->dir->inode->inode = inode;
  2.1903 -@@ -261,6 +262,7 @@
  2.1904 - 			} else
  2.1905 - 				INFO("file %s, uncompressed size %lld bytes "
  2.1906 - 					"LINK\n", entry->dir->pathname,
  2.1907 -+					(long long)
  2.1908 - 					entry->dir->inode->buf.st_size);
  2.1909 - 		}
  2.1910 - }
  2.1911 -
  2.1912 ---- squashfs-4.0/squashfs-tools/sort.h	Sun Feb  8 13:02:53 2009
  2.1913 -+++ squashfs-4.0/squashfs-tools/sort.h	Thu Sep 10 05:50:01 2009
  2.1914 -@@ -42,17 +42,19 @@
  2.1915 - 	struct inode_info	*inode;
  2.1916 - 	struct dir_info		*dir;
  2.1917 - 	struct dir_info		*our_dir;
  2.1918 --	struct old_root_entry_info *data;
  2.1919 - };
  2.1920 - 
  2.1921 - struct inode_info {
  2.1922 --	unsigned int		nlink;
  2.1923 - 	struct stat		buf;
  2.1924 -+	struct inode_info	*next;
  2.1925 - 	squashfs_inode		inode;
  2.1926 --	unsigned int		type;
  2.1927 - 	unsigned int		inode_number;
  2.1928 -+	unsigned int		nlink;
  2.1929 -+	int			pseudo_id;
  2.1930 -+	char			type;
  2.1931 - 	char			read;
  2.1932 --	struct inode_info	*next;
  2.1933 -+	char			root_entry;
  2.1934 -+	char			pseudo_file;
  2.1935 - };
  2.1936 - 
  2.1937 - struct priority_entry {
  2.1938 -
  2.1939 ---- squashfs-4.0/squashfs-tools/squashfs_compat.h	Mon Mar 16 05:27:27 2009
  2.1940 -+++ squashfs-4.0/squashfs-tools/squashfs_compat.h	Tue Apr 21 02:52:24 2009
  2.1941 -@@ -777,11 +777,10 @@
  2.1942 - #endif
  2.1943 - 
  2.1944 - #define _SQUASHFS_SWAP(value, p, pos, tbits, SHIFT) {\
  2.1945 --	int bits;\
  2.1946 --	int b_pos = pos % 8;\
  2.1947 --	unsigned long long val = 0;\
  2.1948 --	unsigned char *s = (unsigned char *)p + (pos / 8);\
  2.1949 --	unsigned char *d = ((unsigned char *) &val) + 7;\
  2.1950 -+	b_pos = pos % 8;\
  2.1951 -+	val = 0;\
  2.1952 -+	s = (unsigned char *)p + (pos / 8);\
  2.1953 -+	d = ((unsigned char *) &val) + 7;\
  2.1954 - 	for(bits = 0; bits < (tbits + b_pos); bits += 8) \
  2.1955 - 		*d-- = *s++;\
  2.1956 - 	value = (val >> (SHIFT))/* & ((1 << tbits) - 1)*/;\
  2.1957 -
  2.1958 ---- squashfs-4.0/squashfs-tools/squashfs_fs.h	Wed Mar 18 03:50:20 2009
  2.1959 -+++ squashfs-4.0/squashfs-tools/squashfs_fs.h	Thu Jul 30 06:45:38 2009
  2.1960 -@@ -229,6 +229,7 @@
  2.1961 - typedef long long		squashfs_inode_t;
  2.1962 - 
  2.1963 - #define ZLIB_COMPRESSION	1
  2.1964 -+#define LZMA_COMPRESSION	2
  2.1965 - 
  2.1966 - struct squashfs_super_block {
  2.1967 - 	unsigned int		s_magic;
  2.1968 -
  2.1969 ---- squashfs-4.0/squashfs-tools/unsquash-3.c	Tue Mar 31 06:35:10 2009
  2.1970 -+++ squashfs-4.0/squashfs-tools/unsquash-3.c	Tue Apr 21 02:58:22 2009
  2.1971 -@@ -36,7 +36,7 @@
  2.1972 - 		sBlk.fragment_table_start);
  2.1973 - 
  2.1974 - 	if(sBlk.fragments == 0)
  2.1975 --		return;
  2.1976 -+		return TRUE;
  2.1977 - 
  2.1978 - 	if((fragment_table = malloc(sBlk.fragments *
  2.1979 - 			sizeof(squashfs_fragment_entry_3))) == NULL)
  2.1980 -
  2.1981 ---- squashfs-4.0/squashfs-tools/unsquash-4.c	Tue Mar 31 06:38:31 2009
  2.1982 -+++ squashfs-4.0/squashfs-tools/unsquash-4.c	Tue Apr 21 02:59:16 2009
  2.1983 -@@ -38,7 +38,7 @@
  2.1984 - 		sBlk.fragment_table_start);
  2.1985 - 
  2.1986 - 	if(sBlk.fragments == 0)
  2.1987 --		return;
  2.1988 -+		return TRUE;
  2.1989 - 
  2.1990 - 	if((fragment_table = malloc(sBlk.fragments *
  2.1991 - 			sizeof(squashfs_fragment_entry))) == NULL)
  2.1992 -
  2.1993 ---- squashfs-4.0/squashfs-tools/unsquashfs.c	Sun Apr  5 23:23:06 2009
  2.1994 -+++ squashfs-4.0/squashfs-tools/unsquashfs.c	Sun Aug 30 16:10:31 2009
  2.1995 -@@ -25,7 +25,10 @@
  2.1996 - #include "squashfs_swap.h"
  2.1997 - #include "squashfs_compat.h"
  2.1998 - #include "read_fs.h"
  2.1999 -+#include "compressor.h"
  2.2000 - 
  2.2001 -+#include <sys/sysinfo.h>
  2.2002 -+
  2.2003 - struct cache *fragment_cache, *data_cache;
  2.2004 - struct queue *to_reader, *to_deflate, *to_writer, *from_writer;
  2.2005 - pthread_t *thread, *deflator_thread;
  2.2006 -@@ -36,6 +39,7 @@
  2.2007 - 
  2.2008 - struct super_block sBlk;
  2.2009 - squashfs_operations s_ops;
  2.2010 -+struct compressor *comp;
  2.2011 - 
  2.2012 - int bytes = 0, swap, file_count = 0, dir_count = 0, sym_count = 0,
  2.2013 - 	dev_count = 0, fifo_count = 0;
  2.2014 -@@ -590,31 +594,23 @@
  2.2015 - 		offset = 3;
  2.2016 - 	if(SQUASHFS_COMPRESSED(c_byte)) {
  2.2017 - 		char buffer[SQUASHFS_METADATA_SIZE];
  2.2018 --		int res;
  2.2019 --		unsigned long bytes = SQUASHFS_METADATA_SIZE;
  2.2020 -+		int error, res;
  2.2021 - 
  2.2022 - 		c_byte = SQUASHFS_COMPRESSED_SIZE(c_byte);
  2.2023 - 		if(read_bytes(start + offset, c_byte, buffer) == FALSE)
  2.2024 - 			goto failed;
  2.2025 - 
  2.2026 --		res = uncompress((unsigned char *) block, &bytes,
  2.2027 --			(const unsigned char *) buffer, c_byte);
  2.2028 -+		res = comp->uncompress(block, buffer, c_byte,
  2.2029 -+			SQUASHFS_METADATA_SIZE, &error);
  2.2030 - 
  2.2031 --		if(res != Z_OK) {
  2.2032 --			if(res == Z_MEM_ERROR)
  2.2033 --				ERROR("zlib::uncompress failed, not enough "
  2.2034 --					"memory\n");
  2.2035 --			else if(res == Z_BUF_ERROR)
  2.2036 --				ERROR("zlib::uncompress failed, not enough "
  2.2037 --					"room in output buffer\n");
  2.2038 --			else
  2.2039 --				ERROR("zlib::uncompress failed, unknown error "
  2.2040 --					"%d\n", res);
  2.2041 -+		if(res == -1) {
  2.2042 -+			ERROR("%s uncompress failed with error code %d\n",
  2.2043 -+				comp->name, error);
  2.2044 - 			goto failed;
  2.2045 - 		}
  2.2046 - 		if(next)
  2.2047 - 			*next = start + offset + c_byte;
  2.2048 --		return bytes;
  2.2049 -+		return res;
  2.2050 - 	} else {
  2.2051 - 		c_byte = SQUASHFS_COMPRESSED_SIZE(c_byte);
  2.2052 - 		if(read_bytes(start + offset, c_byte, block) == FALSE)
  2.2053 -@@ -632,36 +628,26 @@
  2.2054 - 
  2.2055 - int read_data_block(long long start, unsigned int size, char *block)
  2.2056 - {
  2.2057 --	int res;
  2.2058 --	unsigned long bytes = block_size;
  2.2059 -+	int error, res;
  2.2060 - 	int c_byte = SQUASHFS_COMPRESSED_SIZE_BLOCK(size);
  2.2061 - 
  2.2062 - 	TRACE("read_data_block: block @0x%llx, %d %s bytes\n", start,
  2.2063 --		SQUASHFS_COMPRESSED_SIZE_BLOCK(c_byte),
  2.2064 --		SQUASHFS_COMPRESSED_BLOCK(c_byte) ? "compressed" :
  2.2065 -+		c_byte, SQUASHFS_COMPRESSED_BLOCK(size) ? "compressed" :
  2.2066 - 		"uncompressed");
  2.2067 - 
  2.2068 - 	if(SQUASHFS_COMPRESSED_BLOCK(size)) {
  2.2069 - 		if(read_bytes(start, c_byte, data) == FALSE)
  2.2070 - 			goto failed;
  2.2071 - 
  2.2072 --		res = uncompress((unsigned char *) block, &bytes,
  2.2073 --			(const unsigned char *) data, c_byte);
  2.2074 -+		res = comp->uncompress(block, data, c_byte, block_size, &error);
  2.2075 - 
  2.2076 --		if(res != Z_OK) {
  2.2077 --			if(res == Z_MEM_ERROR)
  2.2078 --				ERROR("zlib::uncompress failed, not enough "
  2.2079 --					"memory\n");
  2.2080 --			else if(res == Z_BUF_ERROR)
  2.2081 --				ERROR("zlib::uncompress failed, not enough "
  2.2082 --					"room in output buffer\n");
  2.2083 --			else
  2.2084 --				ERROR("zlib::uncompress failed, unknown error "
  2.2085 --					"%d\n", res);
  2.2086 -+		if(res == -1) {
  2.2087 -+			ERROR("%s uncompress failed with error code %d\n",
  2.2088 -+				comp->name, error);
  2.2089 - 			goto failed;
  2.2090 - 		}
  2.2091 - 
  2.2092 --		return bytes;
  2.2093 -+		return res;
  2.2094 - 	} else {
  2.2095 - 		if(read_bytes(start, c_byte, block) == FALSE)
  2.2096 - 			goto failed;
  2.2097 -@@ -671,7 +657,7 @@
  2.2098 - 
  2.2099 - failed:
  2.2100 - 	ERROR("read_data_block: failed to read block @0x%llx, size %d\n", start,
  2.2101 --		size);
  2.2102 -+		c_byte);
  2.2103 - 	return FALSE;
  2.2104 - }
  2.2105 - 
  2.2106 -@@ -1383,6 +1369,11 @@
  2.2107 - #endif
  2.2108 - 	printf("Creation or last append time %s", mkfs_str ? mkfs_str :
  2.2109 - 		"failed to get time\n");
  2.2110 -+	printf("Filesystem size %.2f Kbytes (%.2f Mbytes)\n",
  2.2111 -+		sBlk.bytes_used / 1024.0, sBlk.bytes_used / (1024.0 * 1024.0));
  2.2112 -+	if(sBlk.s_major == 4)
  2.2113 -+		printf("Compression %s\n", comp->name);
  2.2114 -+	printf("Block size %d\n", sBlk.block_size);
  2.2115 - 	printf("Filesystem is %sexportable via NFS\n",
  2.2116 - 		SQUASHFS_EXPORTABLE(sBlk.flags) ? "" : "not ");
  2.2117 - 
  2.2118 -@@ -1409,9 +1400,6 @@
  2.2119 - 			SQUASHFS_DUPLICATES(sBlk.flags) ? "" : "not ");
  2.2120 - 	else
  2.2121 - 		printf("Duplicates are removed\n");
  2.2122 --	printf("Filesystem size %.2f Kbytes (%.2f Mbytes)\n",
  2.2123 --		sBlk.bytes_used / 1024.0, sBlk.bytes_used / (1024.0 * 1024.0));
  2.2124 --	printf("Block size %d\n", sBlk.block_size);
  2.2125 - 	if(sBlk.s_major > 1)
  2.2126 - 		printf("Number of fragments %d\n", sBlk.fragments);
  2.2127 - 	printf("Number of inodes %d\n", sBlk.inodes);
  2.2128 -@@ -1459,6 +1447,18 @@
  2.2129 - 		s_ops.read_inode = read_inode_4;
  2.2130 - 		s_ops.read_uids_guids = read_uids_guids_4;
  2.2131 - 		memcpy(&sBlk, &sBlk_4, sizeof(sBlk_4));
  2.2132 -+
  2.2133 -+		/*
  2.2134 -+		 * Check the compression type
  2.2135 -+		 */
  2.2136 -+		comp = lookup_compressor_id(sBlk.compression);
  2.2137 -+		if(!comp->supported) {
  2.2138 -+			ERROR("Filesystem uses %s compression, this is "
  2.2139 -+				"unsupported by this version\n", comp->name);
  2.2140 -+			ERROR("Decompressors available:\n");
  2.2141 -+			display_compressors("", "");
  2.2142 -+			goto failed_mount;
  2.2143 -+		}
  2.2144 - 		return TRUE;
  2.2145 - 	}
  2.2146 - 
  2.2147 -@@ -1548,6 +1548,11 @@
  2.2148 - 		goto failed_mount;
  2.2149 - 	}
  2.2150 - 
  2.2151 -+	/*
  2.2152 -+	 * 1.x, 2.x and 3.x filesystems use gzip compression.  Gzip is always
  2.2153 -+	 * suppported.
  2.2154 -+	 */
  2.2155 -+	comp = lookup_compressor("gzip");
  2.2156 - 	return TRUE;
  2.2157 - 
  2.2158 - failed_mount:
  2.2159 -@@ -1707,32 +1712,24 @@
  2.2160 - 
  2.2161 - 	while(1) {
  2.2162 - 		struct cache_entry *entry = queue_get(to_deflate);
  2.2163 --		int res;
  2.2164 --		unsigned long bytes = block_size;
  2.2165 -+		int error, res;
  2.2166 - 
  2.2167 --		res = uncompress((unsigned char *) tmp, &bytes,
  2.2168 --			(const unsigned char *) entry->data,
  2.2169 --			SQUASHFS_COMPRESSED_SIZE_BLOCK(entry->size));
  2.2170 -+		res = comp->uncompress(tmp, entry->data,
  2.2171 -+			SQUASHFS_COMPRESSED_SIZE_BLOCK(entry->size), block_size,
  2.2172 -+			&error);
  2.2173 - 
  2.2174 --		if(res != Z_OK) {
  2.2175 --			if(res == Z_MEM_ERROR)
  2.2176 --				ERROR("zlib::uncompress failed, not enough"
  2.2177 --					"memory\n");
  2.2178 --			else if(res == Z_BUF_ERROR)
  2.2179 --				ERROR("zlib::uncompress failed, not enough "
  2.2180 --					"room in output buffer\n");
  2.2181 --			else
  2.2182 --				ERROR("zlib::uncompress failed, unknown error "
  2.2183 --					"%d\n", res);
  2.2184 --		} else
  2.2185 --			memcpy(entry->data, tmp, bytes);
  2.2186 -+		if(res == -1)
  2.2187 -+			ERROR("%s uncompress failed with error code %d\n",
  2.2188 -+				comp->name, error);
  2.2189 -+		else
  2.2190 -+			memcpy(entry->data, tmp, res);
  2.2191 - 
  2.2192 - 		/*
  2.2193 - 		 * block has been either successfully decompressed, or an error
  2.2194 -  		 * occurred, clear pending flag, set error appropriately and
  2.2195 -  		 * wake up any threads waiting on this block
  2.2196 -  		 */ 
  2.2197 --		cache_block_ready(entry, res != Z_OK);
  2.2198 -+		cache_block_ready(entry, res == -1);
  2.2199 - 	}
  2.2200 - }
  2.2201 - 
  2.2202 -@@ -1913,7 +1910,7 @@
  2.2203 - 
  2.2204 - 
  2.2205 - #define VERSION() \
  2.2206 --	printf("unsquashfs version 4.0 (2009/04/05)\n");\
  2.2207 -+	printf("unsquashfs version 4.0 (CVS 2009/08/30)\n");\
  2.2208 - 	printf("copyright (C) 2009 Phillip Lougher <phillip@lougher.demon.co.uk>"\
  2.2209 - 		"\n\n");\
  2.2210 -     	printf("This program is free software; you can redistribute it and/or\n");\
  2.2211 -@@ -1938,7 +1935,6 @@
  2.2212 - 	int fragment_buffer_size = FRAGMENT_BUFFER_DEFAULT;
  2.2213 - 	int data_buffer_size = DATA_BUFFER_DEFAULT;
  2.2214 - 	char *b;
  2.2215 --	struct winsize winsize;
  2.2216 - 
  2.2217 - 	pthread_mutex_init(&screen_mutex, NULL);
  2.2218 - 	root_process = geteuid() == 0;
  2.2219 -@@ -2087,6 +2083,8 @@
  2.2220 - 				"regular expressions\n");
  2.2221 - 			ERROR("\t\t\t\trather than use the default shell "
  2.2222 - 				"wildcard\n\t\t\t\texpansion (globbing)\n");
  2.2223 -+			ERROR("\nDecompressors available:\n");
  2.2224 -+			display_compressors("", "");
  2.2225 - 		}
  2.2226 - 		exit(1);
  2.2227 - 	}
  2.2228 -
  2.2229 ---- squashfs-4.0/squashfs-tools/unsquashfs.h	Sun Mar 29 04:29:02 2009
  2.2230 -+++ squashfs-4.0/squashfs-tools/unsquashfs.h	Fri Jul 31 19:24:38 2009
  2.2231 -@@ -31,7 +31,6 @@
  2.2232 - #include <fcntl.h>
  2.2233 - #include <errno.h>
  2.2234 - #include <string.h>
  2.2235 --#include <zlib.h>
  2.2236 - #include <sys/mman.h>
  2.2237 - #include <utime.h>
  2.2238 - #include <pwd.h>
  2.2239 -
  2.2240 ---- squashfs-4.0/squashfs-tools/squashfs_fs.h
  2.2241 -+++ squashfs-4.0/squashfs-tools/squashfs_fs.h
  2.2242 -@@ -28,6 +28,8 @@
  2.2243 - #define SQUASHFS_MINOR			0
  2.2244 - #define SQUASHFS_MAGIC			0x73717368
  2.2245 - #define SQUASHFS_MAGIC_SWAP		0x68737173
  2.2246 -+#define SQUASHFS_MAGIC_OLD_LZMA		0x71736873
  2.2247 -+#define SQUASHFS_MAGIC_OLD_LZMA_SWAP	0x73687371
  2.2248 - #define SQUASHFS_START			0
  2.2249 - 
  2.2250 - /* size of metadata (inode and directory) blocks */
  2.2251 -
  2.2252 ---- squashfs-4.0/squashfs-tools/unsquashfs.c
  2.2253 -+++ squashfs-4.0/squashfs-tools/unsquashfs.c
  2.2254 -@@ -1473,8 +1473,10 @@
  2.2255 - 	 * Check it is a SQUASHFS superblock
  2.2256 - 	 */
  2.2257 - 	swap = 0;
  2.2258 --	if(sBlk_3.s_magic != SQUASHFS_MAGIC) {
  2.2259 --		if(sBlk_3.s_magic == SQUASHFS_MAGIC_SWAP) {
  2.2260 -+	if(sBlk_3.s_magic != SQUASHFS_MAGIC  &&
  2.2261 -+	   sBlk_3.s_magic != SQUASHFS_MAGIC_OLD_LZMA) {
  2.2262 -+		if(sBlk_3.s_magic == SQUASHFS_MAGIC_SWAP ||
  2.2263 -+		   sBlk_3.s_magic == SQUASHFS_MAGIC_OLD_LZMA_SWAP) {
  2.2264 - 			squashfs_super_block_3 sblk;
  2.2265 - 			ERROR("Reading a different endian SQUASHFS filesystem "
  2.2266 - 				"on %s\n", source);
  2.2267 -@@ -1552,7 +1554,10 @@
  2.2268 - 	 * 1.x, 2.x and 3.x filesystems use gzip compression.  Gzip is always
  2.2269 - 	 * suppported.
  2.2270 - 	 */
  2.2271 --	comp = lookup_compressor("gzip");
  2.2272 -+	if (sBlk_3.s_magic == SQUASHFS_MAGIC_OLD_LZMA ||
  2.2273 -+	    sBlk_3.s_magic == SQUASHFS_MAGIC_OLD_LZMA_SWAP)
  2.2274 -+		comp = lookup_compressor("lzma");
  2.2275 -+	else	comp = lookup_compressor("gzip");
  2.2276 - 	return TRUE;
  2.2277 - 
  2.2278 - failed_mount: