static void print_qemu_command_line (guestfs_h *g, char **argv);
static int connect_unix_socket (guestfs_h *g, const char *sock);
static int qemu_supports (guestfs_h *g, const char *option);
+static char *qemu_drive_param (guestfs_h *g, const struct drive *drv);
#if 0
static int qemu_supports_re (guestfs_h *g, const pcre *option_regex);
ret = safe_malloc (g, sizeof (char *) * (count + 1));
- for (i = 0, drv = g->drives; drv; i++, drv = drv->next) {
- size_t len = 64 + strlen (drv->path) + strlen (drv->iface);
- if (drv->format) len += strlen (drv->format);
-
- ret[i] = safe_malloc (g, len);
-
- snprintf (ret[i], len, "file=%s%s%s%s%s,if=%s",
- drv->path,
- drv->readonly ? ",snapshot=on" : "",
- drv->use_cache_off ? ",cache=off" : "",
- drv->format ? ",format=" : "",
- drv->format ? drv->format : "",
- drv->iface);
- }
+ for (i = 0, drv = g->drives; drv; i++, drv = drv->next)
+ ret[i] = qemu_drive_param (g, drv);
ret[count] = NULL;
int readonly;
char *format;
char *iface;
+ char *name;
int use_cache_off;
if (strchr (filename, ',') != NULL) {
? safe_strdup (g, optargs->format) : NULL;
iface = optargs->bitmask & GUESTFS_ADD_DRIVE_OPTS_IFACE_BITMASK
? safe_strdup (g, optargs->iface) : safe_strdup (g, DRIVE_IF);
+ name = optargs->bitmask & GUESTFS_ADD_DRIVE_OPTS_NAME_BITMASK
+ ? safe_strdup (g, optargs->name) : NULL;
if (format && !valid_format_iface (format)) {
error (g, _("%s parameter is empty or contains disallowed characters"),
"format");
free (format);
free (iface);
+ free (name);
return -1;
}
if (!valid_format_iface (iface)) {
"iface");
free (format);
free (iface);
+ free (name);
return -1;
}
if (use_cache_off == -1) {
free (format);
free (iface);
+ free (name);
return -1;
}
perrorf (g, "%s", filename);
free (format);
free (iface);
+ free (name);
return -1;
}
}
(*i)->readonly = readonly;
(*i)->format = format;
(*i)->iface = iface;
+ (*i)->name = name;
(*i)->use_cache_off = use_cache_off;
return 0;
g->cmdline[0] = g->qemu;
/* Add drives */
- struct drive *i = g->drives;
- while (i != NULL) {
+ struct drive *drv = g->drives;
+ while (drv != NULL) {
/* Construct the final -drive parameter. */
- size_t len = 64 + strlen (i->path) + strlen (i->iface);
- if (i->format) len += strlen (i->format);
- char buf[len];
-
- snprintf (buf, len, "file=%s%s%s%s%s,if=%s",
- i->path,
- i->readonly ? ",snapshot=on" : "",
- i->use_cache_off ? ",cache=off" : "",
- i->format ? ",format=" : "",
- i->format ? i->format : "",
- i->iface);
+ char *buf = qemu_drive_param (g, drv);
add_cmdline (g, "-drive");
add_cmdline (g, buf);
+ free (buf);
- i = i->next;
+ drv = drv->next;
}
if (qemu_supports (g, "-nodefconfig"))
return 1;
}
+static char *
+qemu_drive_param (guestfs_h *g, const struct drive *drv)
+{
+ size_t len = 64;
+ char *r;
+
+ len += strlen (drv->path);
+ len += strlen (drv->iface);
+ if (drv->format)
+ len += strlen (drv->format);
+
+ r = safe_malloc (g, len);
+
+ snprintf (r, len, "file=%s%s%s%s%s,if=%s",
+ drv->path,
+ drv->readonly ? ",snapshot=on" : "",
+ drv->use_cache_off ? ",cache=off" : "",
+ drv->format ? ",format=" : "",
+ drv->format ? drv->format : "",
+ drv->iface);
+
+ return r; /* caller frees */
+}
+
/* You had to call this function after launch in versions <= 1.0.70,
* but it is now a no-op.
*/