From: Max Reitz Date: Wed, 28 May 2014 22:19:54 +0000 (+0200) Subject: qcow2: Return useful error code in refcount_init() X-Git-Tag: TizenStudio_2.0_p2.3.2~208^2~656^2~3 X-Git-Url: http://review.tizen.org/git/?a=commitdiff_plain;h=8fcffa9853473ab148d36858f15c5531161a1824;p=sdk%2Femulator%2Fqemu.git qcow2: Return useful error code in refcount_init() If bdrv_pread() returns an error, it is very unlikely that it was ENOMEM. In this case, the return value should be passed along; as bdrv_pread() will always either return the number of bytes read or a negative value (the error code), the condition for checking whether bdrv_pread() failed can be simplified (and clarified) as well. Signed-off-by: Max Reitz Signed-off-by: Kevin Wolf Reviewed-by: Benoit Canet --- diff --git a/block/qcow2-refcount.c b/block/qcow2-refcount.c index 87a56d8..d60e2fe 100644 --- a/block/qcow2-refcount.c +++ b/block/qcow2-refcount.c @@ -50,19 +50,21 @@ int qcow2_refcount_init(BlockDriverState *bs) if (s->refcount_table_size > 0) { if (s->refcount_table == NULL) { + ret = -ENOMEM; goto fail; } BLKDBG_EVENT(bs->file, BLKDBG_REFTABLE_LOAD); ret = bdrv_pread(bs->file, s->refcount_table_offset, s->refcount_table, refcount_table_size2); - if (ret != refcount_table_size2) + if (ret < 0) { goto fail; + } for(i = 0; i < s->refcount_table_size; i++) be64_to_cpus(&s->refcount_table[i]); } return 0; fail: - return -ENOMEM; + return ret; } void qcow2_refcount_close(BlockDriverState *bs)