[libvirt] [PATCH v5 23/36] qemu_monitor: Introduce qemuMonitorCPUModelInfoNew
Jiri Denemark
jdenemar at redhat.com
Fri Jan 4 19:56:02 UTC 2019
On Sun, Dec 02, 2018 at 23:10:17 -0600, Chris Venteicher wrote:
> Use a helper function to allocate and initializes CPU Model Info structs.
>
> Signed-off-by: Chris Venteicher <cventeic at redhat.com>
> ---
> src/qemu/qemu_capabilities.c | 2 +-
> src/qemu/qemu_monitor.c | 32 +++++++++++++++++++++++++++-----
> src/qemu/qemu_monitor.h | 2 ++
> 3 files changed, 30 insertions(+), 6 deletions(-)
>
> diff --git a/src/qemu/qemu_capabilities.c b/src/qemu/qemu_capabilities.c
> index 038e3ecf7a..cd685298e6 100644
> --- a/src/qemu/qemu_capabilities.c
> +++ b/src/qemu/qemu_capabilities.c
> @@ -3047,7 +3047,7 @@ virQEMUCapsLoadHostCPUModelInfo(virQEMUCapsPtr qemuCaps,
> goto cleanup;
> }
>
> - if (VIR_ALLOC(hostCPU) < 0)
> + if (!(hostCPU = qemuMonitorCPUModelInfoNew(NULL)))
> goto cleanup;
>
> if (!(hostCPU->name = virXMLPropString(hostCPUNode, "model"))) {
This makes no sense. You have qemuMonitorCPUModelInfoNew which takes a
model name, call it with NULL and set hostCPU->name manually two lines
later.
> diff --git a/src/qemu/qemu_monitor.c b/src/qemu/qemu_monitor.c
> index 84065c59dc..5effc74736 100644
> --- a/src/qemu/qemu_monitor.c
> +++ b/src/qemu/qemu_monitor.c
> @@ -3670,6 +3670,31 @@ qemuMonitorGetCPUModelExpansion(qemuMonitorPtr mon,
> }
>
>
> +qemuMonitorCPUModelInfoPtr
> +qemuMonitorCPUModelInfoNew(const char *name)
> +{
> + qemuMonitorCPUModelInfoPtr ret = NULL;
> + qemuMonitorCPUModelInfoPtr model;
> +
> + if (VIR_ALLOC(model) < 0)
> + return NULL;
> +
> + model->name = NULL;
> + model->nprops = 0;
> + model->props = NULL;
> + model->migratability = false;
VIR_ALLOC() clears the memory, which is why you won't see any code
resetting anything to 0 (NULL, false) after allocation. Please, drop
this part, it will likely become incomplete once a new field is added
into the structure anyway.
> +
> + if (VIR_STRDUP(model->name, name) < 0)
> + goto cleanup;
> +
> + VIR_STEAL_PTR(ret, model);
> +
> + cleanup:
> + qemuMonitorCPUModelInfoFree(model);
> + return ret;
> +}
> +
> +
> void
> qemuMonitorCPUModelInfoFree(qemuMonitorCPUModelInfoPtr model_info)
> {
> @@ -3693,18 +3718,15 @@ qemuMonitorCPUModelInfoFree(qemuMonitorCPUModelInfoPtr model_info)
> qemuMonitorCPUModelInfoPtr
> qemuMonitorCPUModelInfoCopy(const qemuMonitorCPUModelInfo *orig)
> {
> - qemuMonitorCPUModelInfoPtr copy;
> + qemuMonitorCPUModelInfoPtr copy = NULL;
> size_t i;
>
> - if (VIR_ALLOC(copy) < 0)
> + if (!orig || !(copy = qemuMonitorCPUModelInfoNew(orig->name)))
I think the !orig part is not really necessary here, unless you
explicitly want to support qemuMonitorCPUModelInfoCopy(NULL). But if
that's the case, the change should go into separate patch with a
description why it is useful. This way it's hidden in an unrelated
patch.
> goto error;
>
> if (VIR_ALLOC_N(copy->props, orig->nprops) < 0)
> goto error;
>
> - if (VIR_STRDUP(copy->name, orig->name) < 0)
> - goto error;
> -
> copy->migratability = orig->migratability;
> copy->nprops = orig->nprops;
>
> diff --git a/src/qemu/qemu_monitor.h b/src/qemu/qemu_monitor.h
> index 66bfdb0e5c..d486af201a 100644
> --- a/src/qemu/qemu_monitor.h
> +++ b/src/qemu/qemu_monitor.h
> @@ -1042,6 +1042,8 @@ int qemuMonitorGetCPUModelExpansion(qemuMonitorPtr mon,
>
> void qemuMonitorCPUModelInfoFree(qemuMonitorCPUModelInfoPtr model_info);
>
> +qemuMonitorCPUModelInfoPtr qemuMonitorCPUModelInfoNew(const char *name);
> +
> qemuMonitorCPUModelInfoPtr
> qemuMonitorCPUModelInfoCopy(const qemuMonitorCPUModelInfo *orig);
Looking at all users of qemuMonitorCPUModelInfoPtr I can see the new
function should also be used in qemuMonitorJSONGetCPUModelExpansion.
Jirka
More information about the libvir-list
mailing list