mirror of
https://gitlab.com/libvirt/libvirt.git
synced 2025-01-10 14:57:42 +00:00
hyperv: Make it obvious that hypervAddEmbeddedParam() consumes an argument
Upon successful return hypervAddEmbeddedParam() transfers ownership of @table argument to @params. But because it takes only simple pointer (which hides this ownership transfer) it doesn't clear the @table pointer. Signed-off-by: Michal Privoznik <mprivozn@redhat.com> Reviewed-by: Matt Coleman <matt@datto.com>
This commit is contained in:
parent
49562e92e8
commit
e0a09c243c
@ -1794,14 +1794,14 @@ hypervDomainSetMemoryFlags(virDomainPtr domain, unsigned long memory,
|
|||||||
|
|
||||||
if (priv->wmiVersion == HYPERV_WMI_VERSION_V1) {
|
if (priv->wmiVersion == HYPERV_WMI_VERSION_V1) {
|
||||||
if (hypervAddEmbeddedParam(params, priv, "ResourceSettingData",
|
if (hypervAddEmbeddedParam(params, priv, "ResourceSettingData",
|
||||||
memResource, Msvm_MemorySettingData_WmiInfo) < 0) {
|
&memResource, Msvm_MemorySettingData_WmiInfo) < 0) {
|
||||||
hypervFreeEmbeddedParam(memResource);
|
hypervFreeEmbeddedParam(memResource);
|
||||||
goto cleanup;
|
goto cleanup;
|
||||||
}
|
}
|
||||||
|
|
||||||
} else if (priv->wmiVersion == HYPERV_WMI_VERSION_V2) {
|
} else if (priv->wmiVersion == HYPERV_WMI_VERSION_V2) {
|
||||||
if (hypervAddEmbeddedParam(params, priv, "ResourceSettings",
|
if (hypervAddEmbeddedParam(params, priv, "ResourceSettings",
|
||||||
memResource, Msvm_MemorySettingData_WmiInfo) < 0) {
|
&memResource, Msvm_MemorySettingData_WmiInfo) < 0) {
|
||||||
hypervFreeEmbeddedParam(memResource);
|
hypervFreeEmbeddedParam(memResource);
|
||||||
goto cleanup;
|
goto cleanup;
|
||||||
}
|
}
|
||||||
|
@ -362,15 +362,22 @@ hypervSetEmbeddedProperty(virHashTablePtr table, const char *name, char *value)
|
|||||||
* @params: Params list to add to
|
* @params: Params list to add to
|
||||||
* @priv: hypervPrivate object associated with the connection
|
* @priv: hypervPrivate object associated with the connection
|
||||||
* @name: Name of the parameter
|
* @name: Name of the parameter
|
||||||
* @table: table of properties to add
|
* @table: pointer to table of properties to add
|
||||||
* @info: WmiInfo of the object to serialize
|
* @info: WmiInfo of the object to serialize
|
||||||
*
|
*
|
||||||
* Add a virHashTable containing object properties as an embedded param to
|
* Add a virHashTable containing object properties as an embedded param to
|
||||||
* an invocation list. Returns -1 on failure, 0 on success.
|
* an invocation list.
|
||||||
|
*
|
||||||
|
* Upon successfull return the @table is consumed and the pointer is cleared out.
|
||||||
|
*
|
||||||
|
* Returns -1 on failure, 0 on success.
|
||||||
*/
|
*/
|
||||||
int
|
int
|
||||||
hypervAddEmbeddedParam(hypervInvokeParamsListPtr params, hypervPrivate *priv,
|
hypervAddEmbeddedParam(hypervInvokeParamsListPtr params,
|
||||||
const char *name, virHashTablePtr table, hypervWmiClassInfoListPtr info)
|
hypervPrivate *priv,
|
||||||
|
const char *name,
|
||||||
|
virHashTablePtr *table,
|
||||||
|
hypervWmiClassInfoListPtr info)
|
||||||
{
|
{
|
||||||
hypervParamPtr p = NULL;
|
hypervParamPtr p = NULL;
|
||||||
hypervWmiClassInfoPtr classInfo = NULL;
|
hypervWmiClassInfoPtr classInfo = NULL;
|
||||||
@ -385,7 +392,7 @@ hypervAddEmbeddedParam(hypervInvokeParamsListPtr params, hypervPrivate *priv,
|
|||||||
p = ¶ms->params[params->nbParams];
|
p = ¶ms->params[params->nbParams];
|
||||||
p->type = HYPERV_EMBEDDED_PARAM;
|
p->type = HYPERV_EMBEDDED_PARAM;
|
||||||
p->embedded.name = name;
|
p->embedded.name = name;
|
||||||
p->embedded.table = table;
|
p->embedded.table = g_steal_pointer(table);
|
||||||
p->embedded.info = classInfo;
|
p->embedded.info = classInfo;
|
||||||
params->nbParams++;
|
params->nbParams++;
|
||||||
|
|
||||||
|
@ -149,8 +149,11 @@ virHashTablePtr hypervCreateEmbeddedParam(hypervPrivate *priv,
|
|||||||
int hypervSetEmbeddedProperty(virHashTablePtr table, const char *name,
|
int hypervSetEmbeddedProperty(virHashTablePtr table, const char *name,
|
||||||
char *value);
|
char *value);
|
||||||
|
|
||||||
int hypervAddEmbeddedParam(hypervInvokeParamsListPtr params, hypervPrivate *priv,
|
int hypervAddEmbeddedParam(hypervInvokeParamsListPtr params,
|
||||||
const char *name, virHashTablePtr table, hypervWmiClassInfoListPtr info);
|
hypervPrivate *priv,
|
||||||
|
const char *name,
|
||||||
|
virHashTablePtr *table,
|
||||||
|
hypervWmiClassInfoListPtr info);
|
||||||
|
|
||||||
void hypervFreeEmbeddedParam(virHashTablePtr p);
|
void hypervFreeEmbeddedParam(virHashTablePtr p);
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user