From: Eric Blake Date: Tue, 3 May 2011 17:44:04 +0000 (-0600) Subject: storage: avoid null deref and leak on failure X-Git-Url: http://xenbits.xensource.com/gitweb?a=commitdiff_plain;h=4644f0b253e7b661e80f6c946a5f130998edc321;p=libvirt.git storage: avoid null deref and leak on failure Detected by clang. NULL deref added in commit 343a27a (Mar 11), but leak of voldef present since commit 2cd9b2d (Apr 09). * src/storage/storage_driver.c (storageVolumeCreateXML): Don't leak voldef or dereference null volobj. --- diff --git a/src/storage/storage_driver.c b/src/storage/storage_driver.c index 1ea5d120d0..5118ffb1ec 100644 --- a/src/storage/storage_driver.c +++ b/src/storage/storage_driver.c @@ -1,7 +1,7 @@ /* * storage_driver.c: core driver for storage APIs * - * Copyright (C) 2006-2010 Red Hat, Inc. + * Copyright (C) 2006-2011 Red Hat, Inc. * Copyright (C) 2006-2008 Daniel P. Berrange * * This library is free software; you can redistribute it and/or @@ -1319,8 +1319,12 @@ storageVolumeCreateXML(virStoragePoolPtr obj, pool->volumes.objs[pool->volumes.count++] = voldef; volobj = virGetStorageVol(obj->conn, pool->def->name, voldef->name, voldef->key); + if (!volobj) { + pool->volumes.count--; + goto cleanup; + } - if (volobj && backend->buildVol) { + if (backend->buildVol) { int buildret; virStorageVolDefPtr buildvoldef = NULL;