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

Re: [Xen-devel] [PATCH] xl: Return an error if an empty file is passed to cd-insert



On Fri, May 10, 2013 at 4:43 PM, George Dunlap
<george.dunlap@xxxxxxxxxxxxx> wrote:
> Two changes:
> * Stat the file before calling libxl_cdrom_insert()
> * Return an error if anything fails (including libxl_cdrom_insert)

Hmm -- not sure how "empty file" got into that description -- it
should say "non-existent file"...

 -George

>
> This is in part to work around the fact that the RAW disk type
> is used for things that aren't actually files; so we can't call
> stat in libxl_device.c:libxl__device_disk_set_backend() because
> it may be going over a remote protocol.
>
> Signed-off-by: George Dunlap <george.dunlap@xxxxxxxxxxxxx>
> CC: Ian Campbell <ian.campbell@xxxxxxxxxx>
> CC: Ian Jackson <ian.jackson@xxxxxxxxxx>
> ---
>  tools/libxl/xl_cmdimpl.c |   26 +++++++++++++++++++++-----
>  1 file changed, 21 insertions(+), 5 deletions(-)
>
> diff --git a/tools/libxl/xl_cmdimpl.c b/tools/libxl/xl_cmdimpl.c
> index c1a969b..e8ce35b 100644
> --- a/tools/libxl/xl_cmdimpl.c
> +++ b/tools/libxl/xl_cmdimpl.c
> @@ -2505,25 +2505,42 @@ int main_memset(int argc, char **argv)
>      return 0;
>  }
>
> -static void cd_insert(uint32_t domid, const char *virtdev, char *phys)
> +static int cd_insert(uint32_t domid, const char *virtdev, char *phys)
>  {
>      libxl_device_disk disk; /* we don't free disk's contents */
>      char *buf = NULL;
>      XLU_Config *config = 0;
> +    struct stat b;
> +    int rc = 0;
>
>
>      if (asprintf(&buf, "vdev=%s,access=r,devtype=cdrom,target=%s",
>                   virtdev, phys ? phys : "") < 0) {
>          fprintf(stderr, "out of memory\n");
> -        return;
> +        return 1;
>      }
>
>      parse_disk_config(&config, buf, &disk);
>
> -    libxl_cdrom_insert(ctx, domid, &disk, NULL);
> +    /* ATM the existence of the backing file is not checked for qdisk
> +     * in libxl_cdrom_insert() because RAW is used for remote
> +     * protocols as well as plain files.  This will ideally be changed
> +     * for 4.4, but this work-around fixes the problem of "cd-insert"
> +     * returning success for non-existent files. */
> +    if (disk.format != LIBXL_DISK_FORMAT_EMPTY
> +        && stat(disk.pdev_path, &b)) {
> +        fprintf(stderr, "Cannot stat file: %s\n",
> +                disk.pdev_path);
> +        return 1;
> +    }
> +
> +    if (libxl_cdrom_insert(ctx, domid, &disk, NULL))
> +        rc=1;
>
>      libxl_device_disk_dispose(&disk);
>      free(buf);
> +
> +    return rc;
>  }
>
>  int main_cd_eject(int argc, char **argv)
> @@ -2539,8 +2556,7 @@ int main_cd_eject(int argc, char **argv)
>      domid = find_domain(argv[optind]);
>      virtdev = argv[optind + 1];
>
> -    cd_insert(domid, virtdev, NULL);
> -    return 0;
> +    return cd_insert(domid, virtdev, NULL);
>  }
>
>  int main_cd_insert(int argc, char **argv)
> --
> 1.7.9.5
>
>
> _______________________________________________
> Xen-devel mailing list
> Xen-devel@xxxxxxxxxxxxx
> http://lists.xen.org/xen-devel

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