wok-current rev 10937

fusecloop: large file support
author Pascal Bellard <pascal.bellard@slitaz.org>
date Sun Aug 28 10:58:22 2011 +0200 (2011-08-28)
parents e5f7f1b3d407
children 1e7452b326f8
files fusecloop/stuff/fusecloop.u
line diff
     1.1 --- a/fusecloop/stuff/fusecloop.u	Sat Aug 27 17:16:27 2011 +0200
     1.2 +++ b/fusecloop/stuff/fusecloop.u	Sun Aug 28 10:58:22 2011 +0200
     1.3 @@ -129,8 +129,9 @@
     1.4  
     1.5  --- extract_compressed_fs.c
     1.6  +++ extract_compressed_fs.c
     1.7 -@@ -1,15 +1,18 @@
     1.8 +@@ -1,15 +1,19 @@
     1.9   /* Extracts a filesystem back from a compressed fs file */
    1.10 ++#define _LARGEFILE64_SOURCE
    1.11   #include "common_header.h"
    1.12  +#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.13   
    1.14 @@ -150,7 +151,7 @@
    1.15   		exit(1);
    1.16   	}
    1.17   
    1.18 -@@ -24,44 +27,76 @@
    1.19 +@@ -24,44 +28,77 @@
    1.20   		exit(1);
    1.21   	}
    1.22   
    1.23 @@ -175,11 +176,12 @@
    1.24  +
    1.25  +	if (num_blocks == -1) {
    1.26  +		struct cloop_tail tail;
    1.27 -+		if (lseek(handle, - sizeof(tail), SEEK_END) < 0 ||
    1.28 ++		loff_t end = lseek64(handle, 0, SEEK_END);
    1.29 ++		if (lseek64(handle, end - sizeof(tail), SEEK_SET) < 0 ||
    1.30  +		    read(handle, &tail, sizeof(tail)) != sizeof(tail) ||
    1.31 -+		    lseek(handle, - sizeof(tail) - 
    1.32 ++		    lseek64(handle, end - sizeof(tail) - 
    1.33  +		    	  (ntohl(tail.num_blocks) * ntohl(tail.index_size)), 
    1.34 -+		    	  SEEK_END) < 0) {
    1.35 ++		    	  SEEK_SET) < 0) {
    1.36  +			perror("Reading tail\n");
    1.37  +			exit(1);
    1.38  +		}
    1.39 @@ -208,7 +210,7 @@
    1.40  +		}
    1.41  +		data = __be64_to_cpu(offset);
    1.42  +		write(STDOUT_FILENO, &data, sizeof(data));
    1.43 -+		for (i = 0; i < num_blocks && lseek(handle, offsets[i].offset, SEEK_SET) >= 0; i++) {
    1.44 ++		for (i = 0; i < num_blocks && lseek64(handle, offsets[i].offset, SEEK_SET) >= 0; i++) {
    1.45  +			read(handle, buffer, offsets[i].size);
    1.46  +			write(STDOUT_FILENO, buffer, offsets[i].size);
    1.47  +		}
    1.48 @@ -224,7 +226,7 @@
    1.49  -                
    1.50  -		currpos = lseek(handle, 0, SEEK_CUR);
    1.51  -		if (lseek(handle, __be64_to_cpu(offset[0]), SEEK_SET) < 0) {
    1.52 -+		if (lseek(handle, offsets[i].offset, SEEK_SET) < 0) {
    1.53 ++		if (lseek64(handle, offsets[i].offset, SEEK_SET) < 0) {
    1.54   			fprintf(stderr, "lseek to %Lu: %s\n",
    1.55  -				__be64_to_cpu(offset[0]), strerror(errno));
    1.56  +				offsets[i].offset, strerror(errno));
    1.57 @@ -254,6 +256,23 @@
    1.58   		if (i == 3) {
    1.59   			fprintf(stderr,
    1.60   				"Block head:%02X%02X%02X%02X%02X%02X%02X%02X\n",
    1.61 +@@ -105,12 +142,12 @@
    1.62 + 			fprintf(stderr, "Uncomp: unknown error %u\n", i);
    1.63 + 			exit(1);
    1.64 + 		}
    1.65 +-		if (destlen != ntohl(head.block_size)) {
    1.66 +-			fprintf(stderr, "Uncomp: bad len %u (%lu not %u)\n", i,
    1.67 +-				destlen, ntohl(head.block_size));
    1.68 ++		if (destlen != block_size) {
    1.69 ++			fprintf(stderr, "Uncomp: bad len %u (%lu not %lu)\n", i,
    1.70 ++				destlen, block_size);
    1.71 + 			exit(1);
    1.72 + 		}
    1.73 +-		write(STDOUT_FILENO, clear_buffer, ntohl(head.block_size));
    1.74 ++		write(STDOUT_FILENO, clear_buffer, block_size);
    1.75 + 	}
    1.76 + 	return 0;
    1.77 + }
    1.78  @@ -105,12 +140,12 @@
    1.79   			fprintf(stderr, "Uncomp: unknown error %u\n", i);
    1.80   			exit(1);