From: Markus Armbruster Date: Wed, 28 May 2014 09:16:56 +0000 (+0200) Subject: qcow2: Plug memory leak on qcow2_invalidate_cache() error paths X-Git-Tag: v2.0.1~53 X-Git-Url: http://git.ipfire.org/?a=commitdiff_plain;h=207f61dc286fbcb322514007778b99d20e48416b;p=thirdparty%2Fqemu.git qcow2: Plug memory leak on qcow2_invalidate_cache() error paths Introduced in commit 5a8a30d. Spotted by Coverity. Signed-off-by: Markus Armbruster Reviewed-by: Benoit Canet Signed-off-by: Kevin Wolf (cherry picked from commit a1904e48c4a9fb114d155419700bfb7d760273b9) Signed-off-by: Michael Roth --- diff --git a/block/qcow2.c b/block/qcow2.c index e903d971c30..57c353d2217 100644 --- a/block/qcow2.c +++ b/block/qcow2.c @@ -1306,6 +1306,7 @@ static void qcow2_invalidate_cache(BlockDriverState *bs, Error **errp) options = qdict_clone_shallow(bs->options); ret = qcow2_open(bs, options, flags, &local_err); + QDECREF(options); if (local_err) { error_setg(errp, "Could not reopen qcow2 layer: %s", error_get_pretty(local_err)); @@ -1316,8 +1317,6 @@ static void qcow2_invalidate_cache(BlockDriverState *bs, Error **errp) return; } - QDECREF(options); - if (crypt_method) { s->crypt_method = crypt_method; memcpy(&s->aes_encrypt_key, &aes_encrypt_key, sizeof(aes_encrypt_key));