From eb9a4b9034453ae3093d678a6f3898303dc5a5a0 Mon Sep 17 00:00:00 2001 From: David Oberhollenzer Date: Mon, 12 Jun 2023 18:32:12 +0200 Subject: libio: remove ostream_append_sparse and fallback implementation Instead of a separate append-sparse function, simply accept NULL as an input for append. For both Unix and Win32, a fallback needs to be implemented. For XFRM, we can just memset the input buffer to zero, same for the libsquashfs data writer. Signed-off-by: David Oberhollenzer --- lib/sqfs/src/block_processor/frontend.c | 12 +++++++++--- 1 file changed, 9 insertions(+), 3 deletions(-) (limited to 'lib/sqfs') diff --git a/lib/sqfs/src/block_processor/frontend.c b/lib/sqfs/src/block_processor/frontend.c index e8a4207..de89913 100644 --- a/lib/sqfs/src/block_processor/frontend.c +++ b/lib/sqfs/src/block_processor/frontend.c @@ -114,6 +114,7 @@ int sqfs_block_processor_append(sqfs_block_processor_t *proc, const void *data, sqfs_block_t *new; sqfs_u64 filesize; size_t diff; + void *dst; int err; if (!proc->begin_called) @@ -152,12 +153,17 @@ int sqfs_block_processor_append(sqfs_block_processor_t *proc, const void *data, if (diff > size) diff = size; - memcpy(proc->blk_current->data + proc->blk_current->size, - data, diff); + dst = proc->blk_current->data + proc->blk_current->size; + + if (data == NULL) { + memset(dst, 0, diff); + } else { + memcpy(dst, data, diff); + data = (const char *)data + diff; + } size -= diff; proc->blk_current->size += diff; - data = (const char *)data + diff; proc->stats.input_bytes_read += diff; } -- cgit v1.2.3