mirror of
https://gitlab.com/libvirt/libvirt.git
synced 2025-01-24 21:45:21 +00:00
storage: Handle failure from refreshVol
Commit id '155ca616' added the 'refreshVol' API. In an NFS root-squash environment it was possible that if the just created volume from XML wasn't properly created with the right uid/gid and/or mode, then the followup refreshVol will fail to open the volume in order to get the allocation/ capacity values. This would leave the volume still on the server and cause a libvirtd crash because 'voldef' would be in the pool list, but the cleanup code would free it.
This commit is contained in:
parent
454cb7c40d
commit
605b120683
@ -1734,8 +1734,12 @@ storageVolCreateXML(virStoragePoolPtr obj,
|
|||||||
}
|
}
|
||||||
|
|
||||||
if (backend->refreshVol &&
|
if (backend->refreshVol &&
|
||||||
backend->refreshVol(obj->conn, pool, voldef) < 0)
|
backend->refreshVol(obj->conn, pool, voldef) < 0) {
|
||||||
|
storageVolDeleteInternal(volobj, backend, pool, voldef,
|
||||||
|
0, false);
|
||||||
|
voldef = NULL;
|
||||||
goto cleanup;
|
goto cleanup;
|
||||||
|
}
|
||||||
|
|
||||||
/* Update pool metadata */
|
/* Update pool metadata */
|
||||||
pool->def->allocation += buildvoldef->target.allocation;
|
pool->def->allocation += buildvoldef->target.allocation;
|
||||||
|
Loading…
x
Reference in New Issue
Block a user