提交 9579b6bc 编写于 作者: L Laine Stump

Fix crash in virNetDevGetVirtualFunctions

Commit 9a3ff01d (which was ACKed at
the end of January, but for some reason didn't get pushed until during
the 1.0.4 freeze) fixed the logic in virPCIGetVirtualFunctions().
Unfortunately, a typo in the fix (replacing VIR_REALLOC_N with
VIR_ALLOC_N during code movement) caused not only a memory leak, but
also resulted in most of the elements of the result array being
replaced with NULL. virNetDevGetVirtualFunctions() assumed (and I think
rightly so) that virPCIGetVirtualFunctions() wouldn't return any NULL
elements in the array, so it ended up segfaulting.

This was found when attempting to use a virtual network with an
auto-created pool of SRIOV VFs, e.g.:

    <forward mode='hostdev' managed='yes'>
      <pf dev='eth4'/>
    </forward>

(the pool of PCI addresses is discovered by calling
virNetDevGetVirtualFunctions() on the PF dev).
上级 96c45f66
...@@ -2026,8 +2026,8 @@ virPCIGetVirtualFunctions(const char *sysfs_path, ...@@ -2026,8 +2026,8 @@ virPCIGetVirtualFunctions(const char *sysfs_path,
continue; continue;
} }
if (VIR_ALLOC_N(*virtual_functions, if (VIR_REALLOC_N(*virtual_functions,
*num_virtual_functions + 1) < 0) { *num_virtual_functions + 1) < 0) {
virReportOOMError(); virReportOOMError();
VIR_FREE(config_addr); VIR_FREE(config_addr);
goto error; goto error;
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册