wok-current diff fusecloop/stuff/fusecloop.u @ rev 13405

Up frogatto (1.1.1)
author Pascal Bellard <pascal.bellard@slitaz.org>
date Fri Sep 28 18:22:39 2012 +0200 (2012-09-28)
parents 071c9a026a01
children 1e434243dc31
line diff
     1.1 --- a/fusecloop/stuff/fusecloop.u	Tue Oct 25 08:48:31 2011 +0200
     1.2 +++ b/fusecloop/stuff/fusecloop.u	Fri Sep 28 18:22:39 2012 +0200
     1.3 @@ -1,11 +1,12 @@
     1.4  --- compressed_loop.h
     1.5  +++ compressed_loop.h
     1.6 -@@ -41,6 +41,73 @@
     1.7 +@@ -41,6 +41,74 @@
     1.8   /* data_index (num_blocks 64bit pointers, network order)...      */
     1.9   /* compressed data (gzip block compressed format)...             */
    1.10   
    1.11  +struct cloop_tail
    1.12  +{
    1.13 ++	u_int32_t table_size;
    1.14  +	u_int32_t index_size;
    1.15  +	u_int32_t num_blocks;
    1.16  +};
    1.17 @@ -28,7 +29,7 @@
    1.18  +				offsets[n].offset = __be64_to_cpu(offsets[n].offset);
    1.19  +				offsets[n].size = ntohl(offsets[n].size);
    1.20  +			}
    1.21 -+			return "128BE accelerated knoppix 1.0";
    1.22 ++			return (char *) "128BE accelerated knoppix 1.0";
    1.23  +		}
    1.24  +		else { /* V2.0 */
    1.25  +			loff_t last = __be64_to_cpu(ofs64[n]);
    1.26 @@ -37,7 +38,7 @@
    1.27  +					(offsets[n].offset = __be64_to_cpu(ofs64[n])); 
    1.28  +				last = offsets[n].offset;
    1.29  +			}
    1.30 -+			return "64BE v2.0";
    1.31 ++			return (char *) "64BE v2.0";
    1.32  +		}
    1.33  +	}
    1.34  +	else if (ofs32[1] == 0) { /* V1.0 */
    1.35 @@ -47,7 +48,7 @@
    1.36  +				(offsets[n].offset = __le64_to_cpu(ofs64[n])); 
    1.37  +			last = offsets[n].offset;
    1.38  +		}
    1.39 -+		return "64LE v1.0";
    1.40 ++		return (char *) "64LE v1.0";
    1.41  +	}
    1.42  +	else if (ntohl(ofs32[0]) == (4*n) + 0x8C) { /* V0.68 */
    1.43  +		loff_t last = ntohl(ofs32[n]);
    1.44 @@ -56,7 +57,7 @@
    1.45  +				(offsets[n].offset = ntohl(ofs32[n])); 
    1.46  +			last = offsets[n].offset;
    1.47  +		}
    1.48 -+		return "32BE v0.68";
    1.49 ++		return (char *) "32BE v0.68";
    1.50  +	}
    1.51  +	else { /* V3.0 */
    1.52  +		int i, j;
    1.53 @@ -67,7 +68,7 @@
    1.54  +			offsets[i].offset = j;
    1.55  +			j += offsets[i].size;
    1.56  +		}
    1.57 -+		return "32BE v3.0";
    1.58 ++		return (char *) "32BE v3.0";
    1.59  +	}
    1.60  +}
    1.61  +
    1.62 @@ -89,30 +90,43 @@
    1.63  
    1.64  --- cloopreader.c
    1.65  +++ cloopreader.c
    1.66 -@@ -59,10 +59,21 @@
    1.67 +@@ -59,10 +59,32 @@
    1.68   
    1.69       ALLOC(c->pblock,c->blocksize);
    1.70   
    1.71  -    c->tocsize=sizeof *c->toc * (c->numblocks+1); /* One extra address is position of EOF */
    1.72 -+    c->tocsize=sizeof(*c->toc) * c->numblocks;
    1.73 -+    if (c->numblocks == -1) {
    1.74 +-    ALLOC(c->toc,c->tocsize);
    1.75 ++    if (c->numblocks + 1 == 0) {
    1.76  +	struct cloop_tail tail;
    1.77  +	loff_t end = lseek(c->fh,0,SEEK_END); /* lseek(,-n,SEEK_END) buggy ? */
    1.78 -+
    1.79 ++	void *p;
    1.80 ++	ulong toclen, len; 
    1.81 + 
    1.82 +-    OP(read_all(c->fh,c->toc,c->tocsize));  /* read Data Index */
    1.83  +	OP(lseek(c->fh, end - sizeof(tail), SEEK_SET)); 
    1.84  +	OP(read_all(c->fh, &tail, sizeof(tail)));
    1.85  +	c->numblocks = ntohl(tail.num_blocks);
    1.86 -+	c->tocsize = ntohl(tail.index_size) * c->numblocks;
    1.87 -+	OP(lseek(c->fh, end - sizeof(tail) - c->tocsize, SEEK_SET));
    1.88 ++	c->tocsize = sizeof(*c->toc) * c->numblocks;
    1.89 ++	len = ntohl(tail.table_size);
    1.90 ++	toclen = (ntohl(tail.index_size) & 255) * c->numblocks;
    1.91 ++	OP(lseek(c->fh, end - sizeof(tail) - len, SEEK_SET));
    1.92 ++        ALLOC(c->toc,c->tocsize);
    1.93 ++        ALLOC(p,len);
    1.94 ++        OP(read_all(c->fh,p,len));  /* read Data Index */
    1.95 ++	if (uncompress((void *)c->toc,&toclen,p,len) != Z_OK)
    1.96 ++		exit(1);
    1.97 ++	free(p);
    1.98  +    }
    1.99 -     ALLOC(c->toc,c->tocsize);
   1.100 - 
   1.101 -     OP(read_all(c->fh,c->toc,c->tocsize));  /* read Data Index */
   1.102 ++    else {
   1.103 ++	c->tocsize = sizeof(*c->toc) * c->numblocks;
   1.104 ++        ALLOC(c->toc,c->tocsize);
   1.105 ++        OP(read_all(c->fh,c->toc,c->tocsize));  /* read Data Index */
   1.106 ++    }
   1.107  +    build_index(c->toc, c->numblocks);
   1.108       c->cblocksizecur=0;
   1.109       c->curblock=-1;
   1.110       return 0;
   1.111 -@@ -79,10 +90,10 @@
   1.112 +@@ -79,10 +101,10 @@
   1.113       if(page>=c->numblocks){errno=EFAULT;return -1;}
   1.114       c->curblock=page;
   1.115   
   1.116 @@ -133,7 +147,7 @@
   1.117   /* Extracts a filesystem back from a compressed fs file */
   1.118  +#define _LARGEFILE64_SOURCE
   1.119   #include "common_header.h"
   1.120 -+#define CLOOP_PREAMBLE "#!/bin/sh\n" "#V2.0 Format\n" "insmod cloop.o file=$0 && mount -r -t iso9660 /dev/cloop $1\n" "exit $?\n"
   1.121 ++#define CLOOP_PREAMBLE "#!/bin/sh\n" "#V2.0 Format\n" "modprobe cloop file=$0 && mount -r -t iso9660 /dev/cloop $1\n" "exit $?\n"
   1.122   
   1.123   int main(int argc, char *argv[])
   1.124   {
   1.125 @@ -151,7 +165,7 @@
   1.126   		exit(1);
   1.127   	}
   1.128   
   1.129 -@@ -24,44 +28,77 @@
   1.130 +@@ -24,44 +28,91 @@
   1.131   		exit(1);
   1.132   	}
   1.133   
   1.134 @@ -160,42 +174,55 @@
   1.135  -	clear_buffer = malloc(ntohl(head.block_size));
   1.136  -	fprintf(stderr, "%u blocks of size %u. Preamble:\n%s\n", 
   1.137  -		ntohl(head.num_blocks), ntohl(head.block_size), head.preamble);
   1.138 --
   1.139 ++	num_blocks = ntohl(head.num_blocks);
   1.140 ++	block_size = ntohl(head.block_size);
   1.141 ++	zblock_maxsize =  block_size + block_size/1000 + 12 + 4;
   1.142 ++	buffer = malloc(zblock_maxsize);
   1.143 ++	clear_buffer = malloc(block_size);
   1.144 + 
   1.145  -	for (i = 0; i < ntohl(head.num_blocks); i++) {
   1.146  -		int currpos;
   1.147  -		unsigned long destlen = ntohl(head.block_size);
   1.148  -		loff_t offset[2];
   1.149  -		unsigned int size;
   1.150 -+	num_blocks = ntohl(head.num_blocks);
   1.151 -+	block_size = ntohl(head.block_size);
   1.152 -+	zblock_maxsize =  block_size + block_size/1000 + 12 + 4;
   1.153 -+	buffer = malloc(zblock_maxsize);
   1.154 -+	clear_buffer = malloc(block_size);
   1.155 -+	fprintf(stderr, "%lu blocks of size %lu. Preamble:\n%s\n", 
   1.156 -+		num_blocks, block_size, head.preamble);
   1.157 -+
   1.158 -+	if (num_blocks == -1) {
   1.159 ++	if (num_blocks == (unsigned long) -1) {
   1.160 ++		void *table;
   1.161  +		struct cloop_tail tail;
   1.162 ++		unsigned long len, table_size;
   1.163  +		loff_t end = lseek64(handle, 0, SEEK_END);
   1.164 ++		
   1.165  +		if (lseek64(handle, end - sizeof(tail), SEEK_SET) < 0 ||
   1.166  +		    read(handle, &tail, sizeof(tail)) != sizeof(tail) ||
   1.167  +		    lseek64(handle, end - sizeof(tail) - 
   1.168 -+		    	  (ntohl(tail.num_blocks) * ntohl(tail.index_size)), 
   1.169 -+		    	  SEEK_SET) < 0) {
   1.170 ++		    	  ntohl(tail.table_size), SEEK_SET) < 0) {
   1.171  +			perror("Reading tail\n");
   1.172  +			exit(1);
   1.173  +		}
   1.174  +		head.num_blocks = tail.num_blocks;
   1.175  +		num_blocks = ntohl(head.num_blocks);
   1.176 -+		i = num_blocks * ntohl(tail.index_size);
   1.177 ++		table_size = ntohl(tail.table_size);
   1.178 ++		table = malloc(table_size);
   1.179 ++		len = i = num_blocks * (ntohl(tail.index_size) & 255);
   1.180 ++		offsets = malloc(num_blocks * sizeof(*offsets));
   1.181 ++		if (!table || !offsets || 
   1.182 ++		    read(handle, table, table_size) != table_size ||
   1.183 ++		    uncompress((void *)offsets, &len, table, table_size) != Z_OK ||
   1.184 ++		    len != i) {
   1.185 ++			perror("Reading index\n");
   1.186 ++			exit(1);
   1.187 ++		}
   1.188 ++		free(table);
   1.189  +	}
   1.190 -+	else i = num_blocks * sizeof(*offsets);
   1.191 -+	offsets = malloc(i);
   1.192 -+	if (!offsets || read(handle, offsets, i) != i) {
   1.193 -+		perror("Reading index\n");
   1.194 -+		exit(1);
   1.195 ++	else {
   1.196 ++		offsets = malloc(i = num_blocks * sizeof(*offsets));
   1.197 ++		if (!offsets || read(handle, offsets, i) != i) {
   1.198 ++			perror("Reading index\n");
   1.199 ++			exit(1);
   1.200 ++		}
   1.201  +	}
   1.202  +	
   1.203 ++	fprintf(stderr, "%lu blocks of size %lu. Preamble:\n%s\n", 
   1.204 ++		num_blocks, block_size, head.preamble);
   1.205  +	fprintf(stderr, "Index %s.\n", build_index(offsets, num_blocks));
   1.206  +	
   1.207  +	if (argc > 2) {
   1.208 @@ -256,7 +283,7 @@
   1.209   		if (i == 3) {
   1.210   			fprintf(stderr,
   1.211   				"Block head:%02X%02X%02X%02X%02X%02X%02X%02X\n",
   1.212 -@@ -105,12 +142,12 @@
   1.213 +@@ -105,12 +156,12 @@
   1.214   			fprintf(stderr, "Uncomp: unknown error %u\n", i);
   1.215   			exit(1);
   1.216   		}
   1.217 @@ -299,17 +326,68 @@
   1.218   	${CC} ${CFLAGS} ${LDFLAGS} -lz cloopreader.o ${FUSECFLAGS} ${FUSELDFLAGS} fusecloop.c debug.o -o fusecloop
   1.219   
   1.220  
   1.221 +
   1.222  --- create_compressed_fs.c
   1.223  +++ create_compressed_fs.c
   1.224 -@@ -0,0 +1,80 @@
   1.225 +@@ -0,0 +1,147 @@
   1.226 ++#ifdef FIND_BEST_COMPRESSION
   1.227 ++#include <compress.h>
   1.228 ++extern "C" {
   1.229 ++#include <stdlib.h>
   1.230 ++#include <string.h>
   1.231 ++
   1.232 ++static int best_compress(unsigned char *compressed,
   1.233 ++			 unsigned long *compressed_len,
   1.234 ++			 unsigned char *uncompressed,
   1.235 ++			 unsigned long uncompressed_len)
   1.236 ++{
   1.237 ++	int i, j, err;
   1.238 ++	unsigned char *buf[2];
   1.239 ++	unsigned len;
   1.240 ++	unsigned long llen,  best = *compressed_len * 2;
   1.241 ++	static unsigned char *buffer;
   1.242 ++	static unsigned long buffersz;
   1.243 ++
   1.244 ++	if (buffersz < *compressed_len) {
   1.245 ++		if (buffer) free(buffer);
   1.246 ++		buffer = (unsigned char *)  malloc(buffersz = *compressed_len);
   1.247 ++		if (!buffer) return Z_MEM_ERROR;
   1.248 ++	}
   1.249 ++	buf[0] = compressed;
   1.250 ++	buf[1] = buffer;
   1.251 ++	for (i = j = 0; i <= 10; i++) {
   1.252 ++		llen = len = *compressed_len;
   1.253 ++		if (i == 10) 
   1.254 ++			err = (compress_zlib(shrink_extreme, buf[j],
   1.255 ++		     		len, uncompressed,
   1.256 ++		     		uncompressed_len)) ? Z_OK : Z_DATA_ERROR;
   1.257 ++		else {
   1.258 ++			err = compress2(buf[j], &llen, uncompressed,
   1.259 ++				     uncompressed_len, i);
   1.260 ++			len = llen;
   1.261 ++		}
   1.262 ++		if (err != Z_OK) return err;
   1.263 ++		if (len < best) {
   1.264 ++			best = len;
   1.265 ++			j = 1 - j;
   1.266 ++		}
   1.267 ++	}
   1.268 ++	*compressed_len = best;
   1.269 ++	if (j == 0)
   1.270 ++		memcpy(compressed, buffer, best);
   1.271 ++	return err;
   1.272 ++}
   1.273 ++#define compress2(a,b,c,d,e) best_compress(a,b,c,d)
   1.274 ++#endif
   1.275 ++                        
   1.276  +/* Creates a compressed file */
   1.277  +#include "common_header.h"
   1.278  +
   1.279 -+#define CLOOP_PREAMBLE "#!/bin/sh\n" "#V3.0 Format\n" "insmod cloop.o file=$0 && mount -r -t iso9660 /dev/cloop $1\n" "exit $?\n"
   1.280 ++#define CLOOP_PREAMBLE "#!/bin/sh\n" "#V3.0 Format\n" "modprobe cloop file=$0 && mount -r -t iso9660 /dev/cloop $1\n" "exit $?\n"
   1.281  +#define CHUNK 65536
   1.282  +#define DEFAULT_BLOCKSIZE 65536
   1.283  +
   1.284 -+static void quit(char *s)
   1.285 ++static void quit(const char *s)
   1.286  +{
   1.287  +	fprintf(stderr, "%s\n", s);
   1.288  +	exit(1);
   1.289 @@ -337,6 +415,8 @@
   1.290  +	unsigned char *compressed, *uncompressed;
   1.291  +	unsigned long *index;
   1.292  +	int n, indexmax, zlenmax;
   1.293 ++	unsigned long len, pos;
   1.294 ++	static char padding[512];
   1.295  +	
   1.296  +	if (argc > 1) {
   1.297  +		if (argv[1][0] < '0' || argv[1][0] > '9')
   1.298 @@ -353,35 +433,51 @@
   1.299  +	head.num_blocks = -1;
   1.300  +	head.block_size = htonl(block_size);
   1.301  +	write(STDOUT_FILENO, &head, sizeof(head));
   1.302 ++	pos = sizeof(head);
   1.303  +	
   1.304 -+	compressed = malloc(zlenmax);
   1.305 -+	uncompressed = malloc(block_size);
   1.306 -+	index = malloc(indexmax = CHUNK);
   1.307 ++	compressed = (unsigned char *) malloc(zlenmax);
   1.308 ++	uncompressed = (unsigned char *) malloc(block_size);
   1.309 ++	index = (unsigned long *) malloc(indexmax = CHUNK);
   1.310  +	if (!compressed || !uncompressed || !index)
   1.311  +		quit("Malloc failed");
   1.312  +	
   1.313  +	for (n = 0; readblock(uncompressed, block_size); n++) {
   1.314 -+		unsigned long len = zlenmax;
   1.315 -+		
   1.316 ++		len = zlenmax;
   1.317  +		if (compress2(compressed, &len, uncompressed, block_size, 
   1.318  +				Z_BEST_COMPRESSION) != Z_OK)
   1.319  +			quit("Compression failed");
   1.320  +		fprintf(stderr, "Block %u length %lu => %lu\n",
   1.321  +			n, block_size, len);
   1.322  +		write(STDOUT_FILENO, compressed, len);
   1.323 ++		pos += len;
   1.324  +		if (n * sizeof(*index) >= indexmax) {
   1.325 -+			index = realloc(index, indexmax += CHUNK);
   1.326 ++			index = (unsigned long *) realloc(index,
   1.327 ++							  indexmax += CHUNK);
   1.328  +			if (!index)
   1.329  +				quit("Realloc");
   1.330  +		}
   1.331  +		index[n] = ntohl(len);
   1.332  +	}
   1.333 -+	write(STDOUT_FILENO, index, n * sizeof(*index));
   1.334  +	tail.index_size = ntohl(sizeof(*index));
   1.335  +	tail.num_blocks = ntohl(n);
   1.336 ++	n *= sizeof(*index);
   1.337 ++	len = n + n/1000 + 12;
   1.338 ++	compressed = (unsigned char *) realloc(compressed, n);
   1.339 ++	if (!compressed || compress2(compressed, &len, (unsigned char *) index,
   1.340 ++				     n, Z_BEST_COMPRESSION) != Z_OK)
   1.341 ++		quit("Index compression failed");
   1.342 ++	tail.table_size = ntohl(len);
   1.343 ++	pos += len + sizeof(tail);
   1.344 ++	n = pos & 511;
   1.345 ++	if (n) write(STDOUT_FILENO, padding, 512 - n);
   1.346 ++	write(STDOUT_FILENO, compressed, len);
   1.347  +	write(STDOUT_FILENO, &tail, sizeof(tail));
   1.348  +	return 0;
   1.349  +}
   1.350 ++#ifdef FIND_BEST_COMPRESSION
   1.351 ++}
   1.352 ++#endif
   1.353 +
   1.354  --- fusecloop.c
   1.355  +++ fusecloop.c
   1.356  @@ -65,7 +65,7 @@