qemu-io: Don't leak pattern file in error path

qemu_io_alloc_from_file() needs to close the pattern file even if some
error occurred.

Setting f = NULL in the success path and checking it for NULL in the
error path isn't strictly necessary at this point, but let's do it
anyway in case someone later adds a 'goto error' after closing the file.

Coverity: CID 1405303
Fixes: 4d731510d3
Signed-off-by: Kevin Wolf <kwolf@redhat.com>
Reviewed-by: Max Reitz <mreitz@redhat.com>
Reviewed-by: Stefano Garzarella <sgarzare@redhat.com>
This commit is contained in:
Kevin Wolf 2019-09-10 09:03:06 +02:00
parent 4e08bee467
commit c8e68b43e1

View File

@ -401,6 +401,7 @@ static void *qemu_io_alloc_from_file(BlockBackend *blk, size_t len,
} }
fclose(f); fclose(f);
f = NULL;
if (len > pattern_len) { if (len > pattern_len) {
len -= pattern_len; len -= pattern_len;
@ -420,6 +421,9 @@ static void *qemu_io_alloc_from_file(BlockBackend *blk, size_t len,
error: error:
qemu_io_free(buf_origin); qemu_io_free(buf_origin);
if (f) {
fclose(f);
}
return NULL; return NULL;
} }