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

Re: [Xen-devel] [PATCH v2 2/2] xen: Simplify TSC domctls by removing double info field



On 26/05/15 12:14, Ian Campbell wrote:
> There is no need to have this twice and we can simply inline
> xen_guest_tsc_info into xen_domctl_tsc_info as well.
>
> Signed-off-by: Ian Campbell <ian.campbell@xxxxxxxxxx>

Nice diffstat.

Reviewed-by: Andrew Cooper <andrew.cooper3@xxxxxxxxxx>

> ---
> ---
>  tools/libxc/xc_domain.c     |   23 ++++++++---------------
>  xen/arch/x86/domctl.c       |   21 +++++++++------------
>  xen/include/public/domctl.h |    9 ++-------
>  3 files changed, 19 insertions(+), 34 deletions(-)
>
> diff --git a/tools/libxc/xc_domain.c b/tools/libxc/xc_domain.c
> index 7cb36d9..b01a7df 100644
> --- a/tools/libxc/xc_domain.c
> +++ b/tools/libxc/xc_domain.c
> @@ -759,10 +759,10 @@ int xc_domain_set_tsc_info(xc_interface *xch,
>      DECLARE_DOMCTL;
>      domctl.cmd = XEN_DOMCTL_settscinfo;
>      domctl.domain = (domid_t)domid;
> -    domctl.u.tsc_info.info.tsc_mode = tsc_mode;
> -    domctl.u.tsc_info.info.elapsed_nsec = elapsed_nsec;
> -    domctl.u.tsc_info.info.gtsc_khz = gtsc_khz;
> -    domctl.u.tsc_info.info.incarnation = incarnation;
> +    domctl.u.tsc_info.tsc_mode = tsc_mode;
> +    domctl.u.tsc_info.elapsed_nsec = elapsed_nsec;
> +    domctl.u.tsc_info.gtsc_khz = gtsc_khz;
> +    domctl.u.tsc_info.incarnation = incarnation;
>      return do_domctl(xch, &domctl);
>  }
>  
> @@ -775,24 +775,17 @@ int xc_domain_get_tsc_info(xc_interface *xch,
>  {
>      int rc;
>      DECLARE_DOMCTL;
> -    DECLARE_HYPERCALL_BUFFER(xen_guest_tsc_info_t, info);
> -
> -    info = xc_hypercall_buffer_alloc(xch, info, sizeof(*info));
> -    if ( info == NULL )
> -        return -1;
>  
>      domctl.cmd = XEN_DOMCTL_gettscinfo;
>      domctl.domain = (domid_t)domid;
> -    set_xen_guest_handle(domctl.u.tsc_info.out_info, info);
>      rc = do_domctl(xch, &domctl);
>      if ( rc == 0 )
>      {
> -        *tsc_mode = info->tsc_mode;
> -        *elapsed_nsec = info->elapsed_nsec;
> -        *gtsc_khz = info->gtsc_khz;
> -        *incarnation = info->incarnation;
> +        *tsc_mode = domctl.u.tsc_info.tsc_mode;
> +        *elapsed_nsec = domctl.u.tsc_info.elapsed_nsec;
> +        *gtsc_khz = domctl.u.tsc_info.gtsc_khz;
> +        *incarnation = domctl.u.tsc_info.incarnation;
>      }
> -    xc_hypercall_buffer_free(xch, info);
>      return rc;
>  }
>  
> diff --git a/xen/arch/x86/domctl.c b/xen/arch/x86/domctl.c
> index 6d3fe91..5ea9409 100644
> --- a/xen/arch/x86/domctl.c
> +++ b/xen/arch/x86/domctl.c
> @@ -856,16 +856,13 @@ long arch_do_domctl(
>              ret = -EINVAL;
>          else
>          {
> -            xen_guest_tsc_info_t info = { 0 };
> -
>              domain_pause(d);
> -            tsc_get_info(d, &info.tsc_mode,
> -                            &info.elapsed_nsec,
> -                            &info.gtsc_khz,
> -                            &info.incarnation);
> +            tsc_get_info(d, &domctl->u.tsc_info.tsc_mode,
> +                         &domctl->u.tsc_info.elapsed_nsec,
> +                         &domctl->u.tsc_info.gtsc_khz,
> +                         &domctl->u.tsc_info.incarnation);
>              domain_unpause(d);
> -            if ( copy_to_guest(domctl->u.tsc_info.out_info, &info, 1) )
> -                ret = -EFAULT;
> +            copyback = 1;
>          }
>          break;
>  
> @@ -875,10 +872,10 @@ long arch_do_domctl(
>          else
>          {
>              domain_pause(d);
> -            tsc_set_info(d, domctl->u.tsc_info.info.tsc_mode,
> -                         domctl->u.tsc_info.info.elapsed_nsec,
> -                         domctl->u.tsc_info.info.gtsc_khz,
> -                         domctl->u.tsc_info.info.incarnation);
> +            tsc_set_info(d, domctl->u.tsc_info.tsc_mode,
> +                         domctl->u.tsc_info.elapsed_nsec,
> +                         domctl->u.tsc_info.gtsc_khz,
> +                         domctl->u.tsc_info.incarnation);
>              domain_unpause(d);
>          }
>          break;
> diff --git a/xen/include/public/domctl.h b/xen/include/public/domctl.h
> index 10b51ef..9eb5eb5 100644
> --- a/xen/include/public/domctl.h
> +++ b/xen/include/public/domctl.h
> @@ -698,18 +698,13 @@ typedef struct xen_domctl_disable_migrate {
>  
>  /* XEN_DOMCTL_gettscinfo */
>  /* XEN_DOMCTL_settscinfo */
> -struct xen_guest_tsc_info {
> +typedef struct xen_domctl_tsc_info {
> +    /* IN/OUT */
>      uint32_t tsc_mode;
>      uint32_t gtsc_khz;
>      uint32_t incarnation;
>      uint32_t pad;
>      uint64_aligned_t elapsed_nsec;
> -};
> -typedef struct xen_guest_tsc_info xen_guest_tsc_info_t;
> -DEFINE_XEN_GUEST_HANDLE(xen_guest_tsc_info_t);
> -typedef struct xen_domctl_tsc_info {
> -    XEN_GUEST_HANDLE_64(xen_guest_tsc_info_t) out_info; /* OUT */
> -    xen_guest_tsc_info_t info; /* IN */
>  } xen_domctl_tsc_info_t;
>  
>  /* XEN_DOMCTL_gdbsx_guestmemio      guest mem io */


_______________________________________________
Xen-devel mailing list
Xen-devel@xxxxxxxxxxxxx
http://lists.xen.org/xen-devel


 


Rackspace

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