diff options
Diffstat (limited to 'fs/squashfs/zlib_wrapper.c')
| -rw-r--r-- | fs/squashfs/zlib_wrapper.c | 64 | 
1 files changed, 25 insertions, 39 deletions
| diff --git a/fs/squashfs/zlib_wrapper.c b/fs/squashfs/zlib_wrapper.c index 55d918fd2d86..8727caba6882 100644 --- a/fs/squashfs/zlib_wrapper.c +++ b/fs/squashfs/zlib_wrapper.c @@ -32,8 +32,9 @@  #include "squashfs_fs_sb.h"  #include "squashfs.h"  #include "decompressor.h" +#include "page_actor.h" -static void *zlib_init(struct squashfs_sb_info *dummy, void *buff, int len) +static void *zlib_init(struct squashfs_sb_info *dummy, void *buff)  {  	z_stream *stream = kmalloc(sizeof(z_stream), GFP_KERNEL);  	if (stream == NULL) @@ -61,44 +62,37 @@ static void zlib_free(void *strm)  } -static int zlib_uncompress(struct squashfs_sb_info *msblk, void **buffer, -	struct buffer_head **bh, int b, int offset, int length, int srclength, -	int pages) +static int zlib_uncompress(struct squashfs_sb_info *msblk, void *strm, +	struct buffer_head **bh, int b, int offset, int length, +	struct squashfs_page_actor *output)  { -	int zlib_err, zlib_init = 0; -	int k = 0, page = 0; -	z_stream *stream = msblk->stream; - -	mutex_lock(&msblk->read_data_mutex); +	int zlib_err, zlib_init = 0, k = 0; +	z_stream *stream = strm; -	stream->avail_out = 0; +	stream->avail_out = PAGE_CACHE_SIZE; +	stream->next_out = squashfs_first_page(output);  	stream->avail_in = 0;  	do {  		if (stream->avail_in == 0 && k < b) {  			int avail = min(length, msblk->devblksize - offset);  			length -= avail; -			wait_on_buffer(bh[k]); -			if (!buffer_uptodate(bh[k])) -				goto release_mutex; -  			stream->next_in = bh[k]->b_data + offset;  			stream->avail_in = avail;  			offset = 0;  		} -		if (stream->avail_out == 0 && page < pages) { -			stream->next_out = buffer[page++]; -			stream->avail_out = PAGE_CACHE_SIZE; +		if (stream->avail_out == 0) { +			stream->next_out = squashfs_next_page(output); +			if (stream->next_out != NULL) +				stream->avail_out = PAGE_CACHE_SIZE;  		}  		if (!zlib_init) {  			zlib_err = zlib_inflateInit(stream);  			if (zlib_err != Z_OK) { -				ERROR("zlib_inflateInit returned unexpected " -					"result 0x%x, srclength %d\n", -					zlib_err, srclength); -				goto release_mutex; +				squashfs_finish_page(output); +				goto out;  			}  			zlib_init = 1;  		} @@ -109,29 +103,21 @@ static int zlib_uncompress(struct squashfs_sb_info *msblk, void **buffer,  			put_bh(bh[k++]);  	} while (zlib_err == Z_OK); -	if (zlib_err != Z_STREAM_END) { -		ERROR("zlib_inflate error, data probably corrupt\n"); -		goto release_mutex; -	} +	squashfs_finish_page(output); -	zlib_err = zlib_inflateEnd(stream); -	if (zlib_err != Z_OK) { -		ERROR("zlib_inflate error, data probably corrupt\n"); -		goto release_mutex; -	} +	if (zlib_err != Z_STREAM_END) +		goto out; -	if (k < b) { -		ERROR("zlib_uncompress error, data remaining\n"); -		goto release_mutex; -	} +	zlib_err = zlib_inflateEnd(stream); +	if (zlib_err != Z_OK) +		goto out; -	length = stream->total_out; -	mutex_unlock(&msblk->read_data_mutex); -	return length; +	if (k < b) +		goto out; -release_mutex: -	mutex_unlock(&msblk->read_data_mutex); +	return stream->total_out; +out:  	for (; k < b; k++)  		put_bh(bh[k]); | 
