提交 dac697e8 编写于 作者: L Laine Stump

network: fix crash during cleanup from failure to allocate port

During networkPortCreateXML, if networkAllocatePort() failed,
networkReleasePort() would be called, which would (in the case of
network pools of macvtap passthrough devices) attempt to find the
allocated device by comparing port->plug.direct.linkdev to each device
in the pool. Since port->plug.direct.linkdev was still NULL, the
attempted strcmp would result in a SEGV.

Calling networkReleasePort() during error cleanup is something that
should only be done if networkAllocatePort() has already succeeded. It
turns out there is one other possible error exit from
networkPortCreateXML() that happens after networkAllocatePort() has
succeeded, so the code to call networkReleasePort() was just moved
down to there.

Resolves: https://bugzilla.redhat.com/1741390Signed-off-by: NLaine Stump <laine@redhat.com>
Reviewed-by: NMichal Privoznik <mprivozn@redhat.com>
上级 8d6eaf5e
...@@ -5592,20 +5592,20 @@ networkPortCreateXML(virNetworkPtr net, ...@@ -5592,20 +5592,20 @@ networkPortCreateXML(virNetworkPtr net,
rc = networkNotifyPort(obj, portdef); rc = networkNotifyPort(obj, portdef);
else else
rc = networkAllocatePort(obj, portdef); rc = networkAllocatePort(obj, portdef);
if (rc < 0) { if (rc < 0)
goto cleanup;
if (virNetworkObjAddPort(obj, portdef, driver->stateDir) < 0) {
virErrorPtr saved; virErrorPtr saved;
saved = virSaveLastError(); saved = virSaveLastError();
ignore_value(networkReleasePort(obj, portdef)); ignore_value(networkReleasePort(obj, portdef));
virNetworkPortDefFree(portdef);
virSetError(saved); virSetError(saved);
virFreeError(saved); virFreeError(saved);
goto cleanup; goto cleanup;
} }
if (virNetworkObjAddPort(obj, portdef, driver->stateDir) < 0) {
virNetworkPortDefFree(portdef);
goto cleanup;
}
ret = virGetNetworkPort(net, portdef->uuid); ret = virGetNetworkPort(net, portdef->uuid);
cleanup: cleanup:
virNetworkObjEndAPI(&obj); virNetworkObjEndAPI(&obj);
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册