[libvirt] [PATCH 24/41] conf: Introduce virCPUDefMoveModel

John Ferlan jferlan at redhat.com
Tue Aug 30 14:24:07 UTC 2016



On 08/12/2016 09:33 AM, Jiri Denemark wrote:
> The function moves CPU model related parts from one CPU definition to
> another. It can be used to avoid unnecessary copies from a temporary CPU
> definitions which will be freed anyway.
> 
> Signed-off-by: Jiri Denemark <jdenemar at redhat.com>
> ---
>  src/conf/cpu_conf.c      | 17 +++++++++++++++++
>  src/conf/cpu_conf.h      |  4 ++++
>  src/libvirt_private.syms |  1 +
>  3 files changed, 22 insertions(+)
> 

Less "Move" and more "Take"... virCPUDefStealModel is a suggestion - of
course it's more than ->model, but close enough I think.

> diff --git a/src/conf/cpu_conf.c b/src/conf/cpu_conf.c
> index c6e847a..13f3da3 100644
> --- a/src/conf/cpu_conf.c
> +++ b/src/conf/cpu_conf.c
> @@ -115,6 +115,23 @@ virCPUDefCopyModel(virCPUDefPtr dst,
>  }
>  
>  
> +void
> +virCPUDefMoveModel(virCPUDefPtr dst,
> +                   virCPUDefPtr src)
> +{
> +    virCPUDefFreeModel(dst);
> +
> +    VIR_STEAL_PTR(dst->model, src->model);
> +    VIR_STEAL_PTR(dst->vendor, src->vendor);
> +    VIR_STEAL_PTR(dst->vendor_id, src->vendor_id);
> +    VIR_STEAL_PTR(dst->features, src->features);
> +    dst->nfeatures_max = src->nfeatures_max;
> +    src->nfeatures_max = 0;
> +    dst->nfeatures = src->nfeatures;
> +    src->nfeatures = 0;
> +}
> +
> +
>  virCPUDefPtr
>  virCPUDefCopyWithoutModel(const virCPUDef *cpu)
>  {
> diff --git a/src/conf/cpu_conf.h b/src/conf/cpu_conf.h
> index 2bbab9e..d866a89 100644
> --- a/src/conf/cpu_conf.h
> +++ b/src/conf/cpu_conf.h
> @@ -123,6 +123,10 @@ virCPUDefCopyModel(virCPUDefPtr dst,
>                     const virCPUDef *src,
>                     bool resetPolicy);
>  
> +void
> +virCPUDefMoveModel(virCPUDefPtr dst,
> +                   virCPUDefPtr src);
> +
>  virCPUDefPtr
>  virCPUDefCopy(const virCPUDef *cpu);
>  
> diff --git a/src/libvirt_private.syms b/src/libvirt_private.syms
> index 26f5bc8..1cfebd5 100644
> --- a/src/libvirt_private.syms
> +++ b/src/libvirt_private.syms
> @@ -71,6 +71,7 @@ virCPUDefFormat;
>  virCPUDefFormatBuf;
>  virCPUDefFree;
>  virCPUDefFreeModel;
> +virCPUDefMoveModel;
>  virCPUDefParseXML;
>  virCPUDefUpdateFeature;
>  virCPUModeTypeToString;
> 




More information about the libvir-list mailing list