2011-02-04 22:19:54 +01:00
|
|
|
Index: xen-4.0.2-testing/tools/ioemu-qemu-xen/xenstore.c
|
2010-03-01 16:05:50 +01:00
|
|
|
===================================================================
|
2011-02-04 22:19:54 +01:00
|
|
|
--- xen-4.0.2-testing.orig/tools/ioemu-qemu-xen/xenstore.c
|
|
|
|
+++ xen-4.0.2-testing/tools/ioemu-qemu-xen/xenstore.c
|
2010-09-28 00:07:21 +02:00
|
|
|
@@ -935,6 +935,18 @@ static void xenstore_process_dm_command_
|
2008-09-01 02:39:12 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
snapshot_name = xs_read(xsh, XBT_NULL, path, &len);
|
|
|
|
+ } else if (!strncmp(command, "snapshot-delete", len)) {
|
|
|
|
+ if (pasprintf(&path,
|
|
|
|
+ "/local/domain/0/device-model/%u/parameter", domid) == -1) {
|
|
|
|
+ fprintf(logfile, "out of memory reading dm command parameter\n");
|
|
|
|
+ goto out;
|
|
|
|
+ }
|
|
|
|
+ par = xs_read(xsh, XBT_NULL, path, &len);
|
|
|
|
+ if (!par)
|
|
|
|
+ goto out;
|
2008-11-21 15:57:01 +01:00
|
|
|
+ if (delete_disk_snapshots(par) == 0)
|
|
|
|
+ xenstore_record_dm_state("snapshot-deleted");
|
2009-05-04 18:38:09 +02:00
|
|
|
+ free(par);
|
2008-09-01 02:39:12 +02:00
|
|
|
} else if (!strncmp(command, "continue", len)) {
|
|
|
|
fprintf(logfile, "dm-command: continue after state save\n");
|
|
|
|
xen_pause_requested = 0;
|
2011-02-04 22:19:54 +01:00
|
|
|
Index: xen-4.0.2-testing/tools/ioemu-qemu-xen/savevm.c
|
2010-03-01 16:05:50 +01:00
|
|
|
===================================================================
|
2011-02-04 22:19:54 +01:00
|
|
|
--- xen-4.0.2-testing.orig/tools/ioemu-qemu-xen/savevm.c
|
|
|
|
+++ xen-4.0.2-testing/tools/ioemu-qemu-xen/savevm.c
|
2009-05-04 18:38:09 +02:00
|
|
|
@@ -1096,6 +1096,35 @@ the_end:
|
2008-11-21 15:57:01 +01:00
|
|
|
return ret;
|
|
|
|
}
|
|
|
|
|
|
|
|
+int delete_disk_snapshots(const char* name)
|
|
|
|
+{
|
|
|
|
+ BlockDriverState *bs, *bs1;
|
|
|
|
+ int i, ret;
|
|
|
|
+
|
|
|
|
+ bs = get_bs_snapshots();
|
|
|
|
+ if (!bs) {
|
|
|
|
+ xenstore_record_dm_error("No block device supports snapshots");
|
|
|
|
+ return -1;
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ for(i = 0; i <= nb_drives; i++) {
|
|
|
|
+ bs1 = drives_table[i].bdrv;
|
|
|
|
+ if (bdrv_has_snapshot(bs1)) {
|
|
|
|
+ ret = bdrv_snapshot_delete(bs1, name);
|
|
|
|
+ if (ret < 0) {
|
|
|
|
+ if (ret == -ENOTSUP)
|
|
|
|
+ fprintf(stderr, "Snapshots not supported on device '%s'\n",
|
|
|
|
+ bdrv_get_device_name(bs1));
|
|
|
|
+ else
|
|
|
|
+ fprintf(stderr, "Error %d while deleting snapshot on "
|
|
|
|
+ "'%s'\n", ret, bdrv_get_device_name(bs1));
|
|
|
|
+ }
|
|
|
|
+ }
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ return 0;
|
|
|
|
+}
|
|
|
|
+
|
2009-05-04 18:38:09 +02:00
|
|
|
#ifndef CONFIG_DM
|
|
|
|
|
|
|
|
void do_savevm(const char *name)
|
2011-02-04 22:19:54 +01:00
|
|
|
Index: xen-4.0.2-testing/tools/ioemu-qemu-xen/qemu-xen.h
|
2010-03-01 16:05:50 +01:00
|
|
|
===================================================================
|
2011-02-04 22:19:54 +01:00
|
|
|
--- xen-4.0.2-testing.orig/tools/ioemu-qemu-xen/qemu-xen.h
|
|
|
|
+++ xen-4.0.2-testing/tools/ioemu-qemu-xen/qemu-xen.h
|
2009-05-04 18:38:09 +02:00
|
|
|
@@ -42,6 +42,7 @@ enum {
|
2008-11-21 15:57:01 +01:00
|
|
|
|
|
|
|
/* xen-vl-extra.c */
|
|
|
|
int save_disk_snapshots(const char* name);
|
|
|
|
+int delete_disk_snapshots(const char* name);
|
|
|
|
|
|
|
|
/* helper2.c */
|
|
|
|
extern long time_offset;
|