Bug fix: zisofs compression caused SIGSEGV (by reading) with files larger than

524160 KiB.
This commit is contained in:
Thomas Schmitt 2015-08-11 22:58:37 +02:00
parent c8ed18695f
commit bdbaf81e9c

View File

@ -130,9 +130,9 @@ int ziso_running_new(ZisofsFilterRuntime **running, int flag)
o->block_size = ziso_block_size; o->block_size = ziso_block_size;
#ifdef Libisofs_with_zliB #ifdef Libisofs_with_zliB
o->buffer_size= compressBound((uLong) ziso_block_size); o->buffer_size = compressBound((uLong) ziso_block_size);
#else #else
o->buffer_size= 2 * ziso_block_size; o->buffer_size = 2 * ziso_block_size;
#endif #endif
o->read_buffer = calloc(o->block_size, 1); o->read_buffer = calloc(o->block_size, 1);
o->block_buffer = calloc(o->buffer_size, 1); o->block_buffer = calloc(o->buffer_size, 1);
@ -381,7 +381,7 @@ int ziso_stream_compress(IsoStream *stream, void *buf, size_t desired)
if (todo * 4 > rng->buffer_size) if (todo * 4 > rng->buffer_size)
todo = rng->buffer_size / 4; todo = rng->buffer_size / 4;
memcpy(rng->block_buffer, memcpy(rng->block_buffer,
data->block_pointers + 4 * rng->block_pointer_rpos, data->block_pointers + rng->block_pointer_rpos,
todo * 4); todo * 4);
rng->buffer_rpos = 0; rng->buffer_rpos = 0;
rng->buffer_fill = todo * 4; rng->buffer_fill = todo * 4;