From efb6ab552c5cdc9d12585c7c24b98667e212cb4c Mon Sep 17 00:00:00 2001 From: David Oberhollenzer Date: Fri, 29 May 2020 20:08:33 +0200 Subject: Block processor: merge finish & sync functions Signed-off-by: David Oberhollenzer --- lib/sqfs/block_processor/frontend.c | 27 +++++++++++++++++++++++++++ 1 file changed, 27 insertions(+) (limited to 'lib/sqfs/block_processor/frontend.c') diff --git a/lib/sqfs/block_processor/frontend.c b/lib/sqfs/block_processor/frontend.c index 9e9ecc7..daf12e7 100644 --- a/lib/sqfs/block_processor/frontend.c +++ b/lib/sqfs/block_processor/frontend.c @@ -197,6 +197,33 @@ int sqfs_block_processor_submit_block(sqfs_block_processor_t *proc, void *user, return proc->append_to_work_queue(proc, blk); } +int sqfs_block_processor_sync(sqfs_block_processor_t *proc) +{ + return proc->sync(proc); +} + +int sqfs_block_processor_finish(sqfs_block_processor_t *proc) +{ + sqfs_block_t *blk; + int status; + + status = proc->sync(proc); + + if (status == 0 && proc->frag_block != NULL) { + blk = proc->frag_block; + blk->next = NULL; + blk->flags |= BLK_FLAG_MANUAL_SUBMISSION; + proc->frag_block = NULL; + + status = proc->append_to_work_queue(proc, blk); + + if (status == 0) + status = proc->sync(proc); + } + + return status; +} + const sqfs_block_processor_stats_t *sqfs_block_processor_get_stats(const sqfs_block_processor_t *proc) { -- cgit v1.2.3