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

Re: [Xen-devel] [PATCH] libxl: handle errors from xc_sharing_* info functions



On Sep 3, 2012, at 8:48 AM, Ian Campbell wrote:

> # HG changeset patch
> # User Ian Campbell <ian.campbell@xxxxxxxxxx>
> # Date 1346676461 -3600
> # Node ID 99b7a5af9b3059bac2732a601fb1d574b9f02975
> # Parent  c4e822e1b491bb7efa962b38fff6f007f01596b5
> libxl: handle errors from xc_sharing_* info functions
> 
> On a 32 bit hypervisor xl info currently reports:
> sharing_freed_memory   : 72057594037927935
> sharing_used_memory    : 72057594037927935
> 
> Eat the ENOSYS and turn it into 0. Log and propagate other errors.
> 
> I don't have a 32 bit system handy, so tested on x86_64 with a libxc
> hacked to return -ENOSYS and -EINVAL.
> 
> Signed-off-by: Ian Campbell <ian.campbell@xxxxxxxxxx>
Acked-by: Andres Lagar-Cavilla <andres@xxxxxxxxxxxxxxxx>

Good catch!
Andres
> 
> diff -r c4e822e1b491 -r 99b7a5af9b30 tools/libxl/libxl.c
> --- a/tools/libxl/libxl.c     Mon Sep 03 09:59:35 2012 +0100
> +++ b/tools/libxl/libxl.c     Mon Sep 03 13:47:41 2012 +0100
> @@ -3622,6 +3622,7 @@ int libxl_get_physinfo(libxl_ctx *ctx, l
> {
>     xc_physinfo_t xcphysinfo = { 0 };
>     int rc;
> +    long l;
> 
>     rc = xc_physinfo(ctx->xch, &xcphysinfo);
>     if (rc != 0) {
> @@ -3636,8 +3637,20 @@ int libxl_get_physinfo(libxl_ctx *ctx, l
>     physinfo->total_pages = xcphysinfo.total_pages;
>     physinfo->free_pages = xcphysinfo.free_pages;
>     physinfo->scrub_pages = xcphysinfo.scrub_pages;
> -    physinfo->sharing_freed_pages = xc_sharing_freed_pages(ctx->xch);
> -    physinfo->sharing_used_frames = xc_sharing_used_frames(ctx->xch);
> +    l = xc_sharing_freed_pages(ctx->xch);
> +    if ( l < 0 && l != -ENOSYS ) {
> +        LIBXL__LOG_ERRNOVAL(ctx, LIBXL__LOG_ERROR, l,
> +                            "getting sharing freed pages");
> +        return ERROR_FAIL;
> +    }
> +    physinfo->sharing_freed_pages = (l == -ENOSYS) ? 0 : l;
> +    l = xc_sharing_used_frames(ctx->xch);
> +    if ( l < 0 && l != -ENOSYS ) {
> +        LIBXL__LOG_ERRNOVAL(ctx, LIBXL__LOG_ERROR, l,
> +                            "getting sharing used frames");
> +        return ERROR_FAIL;
> +    }
> +    physinfo->sharing_used_frames = (l == -ENOSYS) ? 0 : l;
>     physinfo->nr_nodes = xcphysinfo.nr_nodes;
>     memcpy(physinfo->hw_cap,xcphysinfo.hw_cap, sizeof(physinfo->hw_cap));
> 


_______________________________________________
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®.