Skip to content

Commit

Permalink
qcow2: Return useful error code in refcount_init()
Browse files Browse the repository at this point in the history
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 <mreitz@redhat.com>
Signed-off-by: Kevin Wolf <kwolf@redhat.com>
Reviewed-by: Benoit Canet <benoit@irqsave.net>
  • Loading branch information
XanClic authored and kevmw committed Aug 15, 2014
1 parent 7504edf commit 8fcffa9
Showing 1 changed file with 4 additions and 2 deletions.
6 changes: 4 additions & 2 deletions block/qcow2-refcount.c
Expand Up @@ -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)
Expand Down

0 comments on commit 8fcffa9

Please sign in to comment.