[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

Re: [PATCH v20210701 12/40] tools: unify type checking for data pfns in migration stream


  • To: Olaf Hering <olaf@xxxxxxxxx>, <xen-devel@xxxxxxxxxxxxxxxxxxxx>
  • From: Andrew Cooper <andrew.cooper3@xxxxxxxxxx>
  • Date: Fri, 2 Jul 2021 20:43:13 +0100
  • Arc-authentication-results: i=1; mx.microsoft.com 1; spf=pass smtp.mailfrom=citrix.com; dmarc=pass action=none header.from=citrix.com; dkim=pass header.d=citrix.com; arc=none
  • Arc-message-signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=microsoft.com; s=arcselector9901; h=From:Date:Subject:Message-ID:Content-Type:MIME-Version:X-MS-Exchange-SenderADCheck; bh=WQm8/LM5DZNPep69o2xTgCMxTO2rUFu6G+DGUi9imyU=; b=ZnnIDGJidU8W4yLPGT9cYTIQMi32QAQUQ5M5S1Ej2jT6v/EHwO7S7LMEGcJfW1d/S5ZXXqEZXpWRgF9rqs/xdOleae0cHICI7HYcW2wd1RA/+nImaVSf/0mT86bw3fb7owIF1QUBsYck9DnRRjFu5icGadJfpGmjruqeQSMacYYTNUv9NN2qFFsK1imLA8BCSEssDPSrjPJlMFNXKKzxKkJy3zkTIbkjlGvRIf7aOW+4bm/tPITo9JmRUgazTH6ovxC+2nWw/xbJ5f0h4X8EsbQlpb/9EkeP0rWTrb27awZqNLqDm9Hfw7g7l6DTCMqlwVQ8t56v2Ekw4S5/dPGdog==
  • Arc-seal: i=1; a=rsa-sha256; s=arcselector9901; d=microsoft.com; cv=none; b=W00Z/toL/YgW0tAhVjwDX+ObOdXSiqzHfGIIzUPo6JFYSncPw8znVQPMlBtDpiL1lUhhS4Ipm3P6i1LYiArskxpKMCwCI34ukUEUGevcxjg5hROyyCs3T5BrzDjDKiuk6Z6mLUshbaJewd4wLLuSXDUmx6tCoBc36+GxqTHerbeKXAeiE9Xef5yW83XHV6pLGuUOpVLbIhlWWy7mBJXT17OrU5jTgY6dXdabDw9owIJL8XJZHWZXyjIbrNRSmklL6l7FxNa2NNlYaNpyi5hvugnGkXQNibESRCPiJgTB2YscLdAtL9ReMhhqrC2DexftxMstpH0sUhp9UXWg+u196Q==
  • Authentication-results: esa5.hc3370-68.iphmx.com; dkim=pass (signature verified) header.i=@citrix.onmicrosoft.com
  • Cc: Ian Jackson <iwj@xxxxxxxxxxxxxx>, Wei Liu <wl@xxxxxxx>, Juergen Gross <jgross@xxxxxxxx>
  • Delivery-date: Fri, 02 Jul 2021 19:43:32 +0000
  • Ironport-hdrordr: A9a23:JSp1Hah2mG4jYPZ6R3kLjb2ZwXBQXzF13DAbv31ZSRFFG/FwyP rAoB1L73PJYWgqNU3I+ergBEGBKUmskKKdkrNhQotKOzOWxFdATbsSkLcKpgePJ8SQzJ8k6U 4NSdkYNDS0NykBsS+Y2njKLz9D+qj/zEnAv463pB0MPGIaHp2IrT0JbjpzencGNDWubqBJcq Z0iPA3xQZINU5nFfhSURI+Lpn+TpDw5d7bSC9DIyRixBiFjDuu5rK/Ox+E3i0GWzcK5bs562 DKnyHw+63m6piAu1Hh/l6Wy64TtMrqy9NFCsDJos8JKg/0ggLtQIh6QbWNsB08venqwlc3l9 vnpQsmIq1ImjzsV1DwhSGo9xjr0T4o5XOn40Sfm2HfrcvwQy9/I9ZdhKpCGyGpqHYIjZVZ6u ZmzmiZv51YAVfrhyLm/eXFUBlsiw6dvWciq+gOlHZSOLFuKIO5lbZvuX+9La1wWB4TsOscYa 5T5YDnlbdrmGqhHjLkVjIF+q3rYpxbdS32MHTruaSuonNrdT5CvhIlLfck7wA9HaQGOtF5Dt T/Q9BVfY51P7krhIJGda08qJiMeyHwqSylChPaHb2xLtB4B5uKke+u3IkI
  • Ironport-sdr: /uMgw+MXHXzfAZzVVxrrweiVstwx+G33gy7ZY9viQjp5y9Nhp4y55Srmzn5Ku0WGN84qA4xvEa GkbGjBL45GUmKEqvfQzKE1Jv2Y44Rfd9asVnlbHNNpKVG7Z435+zyY4w3HZXOLtc63fPc3NxX5 adEhQ2fEkjIdk04OlCtSyk0VsZw+jnrGE3JNouneXs4aeETeX6IadtOzZW65KG35tbZvaqbU7U juDmMCxPtDsuiS3LA2yp4hrNDmJ5C+4bYI2KDhXtLlOrVF38Him1joKQfOoHeT+c8hc+RPOown Nl8=
  • List-id: Xen developer discussion <xen-devel.lists.xenproject.org>

On 01/07/2021 10:56, Olaf Hering wrote:
> Introduce a helper which decides if a given pfn in the migration
> stream is backed by memory.
>
> This specifically deals with type XEN_DOMCTL_PFINFO_XALLOC, which was
> a synthetic toolstack-only type used in Xen 4.2 to 4.5. It indicated a
> dirty page on the sending side for which no data will be send in the
> initial iteration.
>
> No change in behavior intended.
>
> Signed-off-by: Olaf Hering <olaf@xxxxxxxxx>
> ---
>  tools/libs/saverestore/common.h  | 17 +++++++++++++++++
>  tools/libs/saverestore/restore.c |  5 ++---
>  2 files changed, 19 insertions(+), 3 deletions(-)
>
> diff --git a/tools/libs/saverestore/common.h b/tools/libs/saverestore/common.h
> index 07c506360c..fa242e808d 100644
> --- a/tools/libs/saverestore/common.h
> +++ b/tools/libs/saverestore/common.h
> @@ -500,6 +500,23 @@ static inline bool sr_is_known_page_type(xen_pfn_t type)
>      return ret;
>  }
>  
> +static inline bool page_type_to_populate(uint32_t type)
> +{
> +    bool ret;
> +
> +    switch (type)
> +    {

Same style comments as before.

> +    case XEN_DOMCTL_PFINFO_XTAB:
> +    case XEN_DOMCTL_PFINFO_BROKEN:
> +        ret = false;
> +        break;
> +    case XEN_DOMCTL_PFINFO_XALLOC:
> +    default:
> +        ret = true;
> +        break;

I know you're replacing the logic as-was, but in hindsight, I'm not sure
it was great to begin with.  It defaults the unallocated types to being
considered populated, which isn't a clever idea.

Anyone adding a new page type is going to have to audit/edit each of
these helpers.  I think it would be better to write all the true cases
explicitly.

> +    }
> +    return ret;
> +}
>  #endif
>  /*
>   * Local variables:
> diff --git a/tools/libs/saverestore/restore.c 
> b/tools/libs/saverestore/restore.c
> index 324b9050e2..477b7527a1 100644
> --- a/tools/libs/saverestore/restore.c
> +++ b/tools/libs/saverestore/restore.c
> @@ -152,9 +152,8 @@ int populate_pfns(struct xc_sr_context *ctx, unsigned int 
> count,
>  
>      for ( i = 0; i < count; ++i )
>      {
> -        if ( (!types || (types &&
> -                         (types[i] != XEN_DOMCTL_PFINFO_XTAB &&
> -                          types[i] != XEN_DOMCTL_PFINFO_BROKEN))) &&
> +        if ( (!types ||
> +              (types && page_type_to_populate(types[i]) == true)) &&

I'm surprised not to have seen a compiler or static analysis complaint
about this.

!A || (A && B) is redundant, and simplifies to !A || B.

Clearly need to blame whichever numpty wrote this code to begin with.

~Andrew




 


Rackspace

Lists.xenproject.org is hosted with RackSpace, monitoring our
servers 24x7x365 and backed by RackSpace's Fanatical Support®.