From 95b065590f236b924d05d6ed3d9109081fa3a960 Mon Sep 17 00:00:00 2001 From: Peter Krempa Date: Mon, 9 Jul 2012 14:10:05 +0200 Subject: [PATCH] storage_backend_fs: Don't free a part of a structure on error As the storage pool sources are stored in a list of structs, the pointer returned by virStoragePoolSourceListNewSource() shouldn't be freed as it points in the middle of a memory block. This combined with a regression that takes the error path every time on caused a double-free abort on the src struct in question. (cherry picked from commit ab9c72ae9e55e7190f52ad1550624630a5c7f78b) --- src/storage/storage_backend_fs.c | 2 -- 1 file changed, 2 deletions(-) diff --git a/src/storage/storage_backend_fs.c b/src/storage/storage_backend_fs.c index 26bbc32e45..cf213b8c09 100644 --- a/src/storage/storage_backend_fs.c +++ b/src/storage/storage_backend_fs.c @@ -213,10 +213,8 @@ virStorageBackendFileSystemNetFindPoolSourcesFunc(virStoragePoolObjPtr pool ATTR } src->format = VIR_STORAGE_POOL_NETFS_NFS; - src = NULL; ret = 0; cleanup: - virStoragePoolSourceFree(src); return ret; }