2011-03-21 17:47:37 +01:00
Index: xen-4.1.0-testing/tools/ioemu-qemu-xen/xenstore.c
2008-07-19 01:04:37 +02:00
===================================================================
2011-03-21 17:47:37 +01:00
--- xen-4.1.0-testing.orig/tools/ioemu-qemu-xen/xenstore.c
+++ xen-4.1.0-testing/tools/ioemu-qemu-xen/xenstore.c
2010-03-02 01:46:56 +01:00
@@ -103,6 +103,8 @@ int xenstore_watch_new_callback(const ch
2010-01-16 01:12:54 +01:00
}
2008-07-19 01:04:37 +02:00
+char* get_snapshot_name(int devid);
+
static int pasprintf(char **buf, const char *fmt, ...)
{
va_list ap;
2011-03-21 17:47:37 +01:00
@@ -708,8 +710,33 @@ void xenstore_parse_domain_config(int hv
2010-09-28 00:07:21 +02:00
fprintf(stderr, "Using file %s in read-%s mode\n", bs->filename, is_readonly ? "only" : "write");
- if (bdrv_open2(bs, params, flags, format) < 0)
2009-05-04 18:38:09 +02:00
+ if (bdrv_open2(bs, params, BDRV_O_CACHE_WB /* snapshot and write-back */, format) < 0) {
2008-07-19 01:04:37 +02:00
fprintf(stderr, "qemu: could not open vbd '%s' or hard disk image '%s' (drv '%s' format '%s')\n", buf, params, drv ? drv : "?", format ? format->format_name : "0");
+ } else {
2009-05-04 18:38:09 +02:00
+ char* snapshot = get_snapshot_name(atoi(e_danger[i]));
2008-07-19 01:04:37 +02:00
+ if (snapshot) {
+ fprintf(stderr, "Using snapshot %s\n", snapshot);
2008-11-21 15:57:01 +01:00
+ ret = bdrv_snapshot_goto(bs, snapshot);
+ switch (ret) {
+ case 0:
+ /* Success */
+ break;
+ case -ENOTSUP:
+ /* Don't abort here (could be read-only ISO) */
+ fprintf(stderr, "Snapshots are not supported for "
+ "this image file format\n");
+ break;
+ case -ENOENT:
+ fprintf(stderr, "No such snapshot, skipping this "
+ "image file\n");
+ continue;
+ default:
+ fprintf(stderr, "Could not load snapshot, skipping"
+ " this image file\n");
+ continue;
+ }
2008-07-19 01:04:37 +02:00
+ }
+ }
}
2010-01-16 01:12:54 +01:00
#endif
2011-03-21 17:47:37 +01:00
@@ -839,6 +866,23 @@ int xenstore_parse_disable_pf_config ()
2009-05-04 18:38:09 +02:00
return disable_pf;
2008-07-19 01:04:37 +02:00
}
+
+char* get_snapshot_name(int devid)
+{
+ char* path = NULL;
+ char* name = NULL;
+ unsigned int len;
+
+ if (pasprintf(&path,
+ "/local/domain/0/backend/tap/%u/%u/snapshot", domid, devid) == -1)
+ return NULL;
+ name = xs_read(xsh, XBT_NULL, path, &len);
+
+ free(path);
+ return name;
+}
+
+
int xenstore_fd(void)
{
if (xsh)