mirror of
https://gitlab.com/libvirt/libvirt.git
synced 2025-01-11 23:37:42 +00:00
conf: fix use after free in virChrdevOpen
Don't free the stream on error if we've successfully added it to the hash table, since it will be freed by virChrdevHashEntryFree callback. Preserve the error message before calling virStreamFree, since it resets the error. Introduced by4716138
, crashing since6921892
. Reported by Sergey Fionov on libvir-list.
This commit is contained in:
parent
a551e9e1fc
commit
a32b41746c
@ -341,6 +341,8 @@ int virChrdevOpen(virChrdevsPtr devs,
|
|||||||
virStreamPtr savedStream;
|
virStreamPtr savedStream;
|
||||||
char *path;
|
char *path;
|
||||||
int ret;
|
int ret;
|
||||||
|
bool added = false;
|
||||||
|
virErrorPtr savedError;
|
||||||
|
|
||||||
switch (source->type) {
|
switch (source->type) {
|
||||||
case VIR_DOMAIN_CHR_TYPE_PTY:
|
case VIR_DOMAIN_CHR_TYPE_PTY:
|
||||||
@ -397,6 +399,7 @@ int virChrdevOpen(virChrdevsPtr devs,
|
|||||||
|
|
||||||
if (virHashAddEntry(devs->hash, path, st) < 0)
|
if (virHashAddEntry(devs->hash, path, st) < 0)
|
||||||
goto error;
|
goto error;
|
||||||
|
added = true;
|
||||||
|
|
||||||
cbdata->devs = devs;
|
cbdata->devs = devs;
|
||||||
if (VIR_STRDUP(cbdata->path, path) < 0)
|
if (VIR_STRDUP(cbdata->path, path) < 0)
|
||||||
@ -429,8 +432,16 @@ int virChrdevOpen(virChrdevsPtr devs,
|
|||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
error:
|
error:
|
||||||
virStreamFree(st);
|
savedError = virSaveLastError();
|
||||||
virHashRemoveEntry(devs->hash, path);
|
|
||||||
|
if (added)
|
||||||
|
virHashRemoveEntry(devs->hash, path);
|
||||||
|
else
|
||||||
|
virStreamFree(st);
|
||||||
|
|
||||||
|
virSetError(savedError);
|
||||||
|
virFreeError(savedError);
|
||||||
|
|
||||||
if (cbdata)
|
if (cbdata)
|
||||||
VIR_FREE(cbdata->path);
|
VIR_FREE(cbdata->path);
|
||||||
VIR_FREE(cbdata);
|
VIR_FREE(cbdata);
|
||||||
|
Loading…
Reference in New Issue
Block a user