2010-01-16 01:12:54 +01:00
Index: xen-4.0.0-testing/tools/blktap/drivers/blktapctrl.c
2008-07-19 01:04:37 +02:00
===================================================================
2010-01-16 01:12:54 +01:00
--- xen-4.0.0-testing.orig/tools/blktap/drivers/blktapctrl.c
+++ xen-4.0.0-testing/tools/blktap/drivers/blktapctrl.c
@@ -347,6 +347,7 @@ static int write_msg(int fd, int msgtype
2008-07-19 01:04:37 +02:00
msg_dev = (msg_newdev_t *)(buf + sizeof(msg_hdr_t));
msg_dev->devnum = blkif->minor;
msg_dev->domid = blkif->domid;
+ msg_dev->be_id = blkif->be_id;
break;
2010-01-16 01:12:54 +01:00
Index: xen-4.0.0-testing/tools/blktap/lib/blktaplib.h
2008-07-19 01:04:37 +02:00
===================================================================
2010-01-16 01:12:54 +01:00
--- xen-4.0.0-testing.orig/tools/blktap/lib/blktaplib.h
+++ xen-4.0.0-testing/tools/blktap/lib/blktaplib.h
2008-08-18 00:24:29 +02:00
@@ -189,6 +189,7 @@ typedef struct msg_hdr {
2008-07-19 01:04:37 +02:00
typedef struct msg_newdev {
uint8_t devnum;
uint16_t domid;
+ uint32_t be_id;
} msg_newdev_t;
typedef struct msg_pid {
2010-01-16 01:12:54 +01:00
Index: xen-4.0.0-testing/tools/ioemu-remote/hw/xen_blktap.c
2008-07-19 01:04:37 +02:00
===================================================================
2010-01-16 01:12:54 +01:00
--- xen-4.0.0-testing.orig/tools/ioemu-remote/hw/xen_blktap.c
+++ xen-4.0.0-testing/tools/ioemu-remote/hw/xen_blktap.c
2009-05-04 18:38:09 +02:00
@@ -67,6 +67,8 @@ int write_fd;
2008-07-19 01:04:37 +02:00
static pid_t process;
fd_list_entry_t *fd_start = NULL;
+extern char* get_snapshot_name(int devid);
+
static void handle_blktap_iomsg(void* private);
struct aiocb_info {
2010-01-16 01:12:54 +01:00
@@ -500,6 +502,10 @@ static void handle_blktap_ctrlmsg(void*
2008-07-19 01:04:37 +02:00
char buf[MSG_SIZE];
+#ifndef QEMU_TOOL
2010-03-01 16:05:50 +01:00
+ char *snapshot;
2008-07-19 01:04:37 +02:00
+#endif
+
length = read(read_fd, buf, MSG_SIZE);
if (length > 0 && length >= sizeof(msg_hdr_t))
2010-01-16 01:12:54 +01:00
@@ -555,7 +561,39 @@ static void handle_blktap_ctrlmsg(void*
2008-07-19 01:04:37 +02:00
if (s != NULL) {
ret = ((map_new_dev(s, msg_dev->devnum)
== msg_dev->devnum ? 0: -1));
- }
+ }
+
+#ifndef QEMU_TOOL
+ fprintf(stderr, "Reading snapshot name for %d\n", msg_dev->be_id);
+ snapshot = get_snapshot_name(msg_dev->be_id);
+ if (snapshot) {
+ fprintf(stderr, "Using snapshot %s\n", snapshot);
2008-11-21 15:57:01 +01:00
+ ret = bdrv_snapshot_goto(s->bs, snapshot);
+ switch (ret) {
+ case 0:
+ /* Success */
+ break;
+ case -ENOTSUP:
+ if (s->flags & TD_RDONLY) {
+ fprintf(stderr, "Snapshots not supported for "
+ "image format of a read-only image\n");
+ } else {
+ fprintf(stderr, "Snapshots not supported "
+ "for this image format");
+ ret = -1;
+ }
+ break;
+ case -ENOENT:
+ fprintf(stderr, "No such snapshot");
+ ret = -1;
+ break;
+ default:
2008-07-19 01:04:37 +02:00
+ fprintf(stderr, "Could not load snapshot");
2008-11-21 15:57:01 +01:00
+ ret = -1;
+ break;
+ }
2008-07-19 01:04:37 +02:00
+ }
+#endif
memset(buf, 0x00, MSG_SIZE);
msglen = sizeof(msg_hdr_t);
2010-01-16 01:12:54 +01:00
Index: xen-4.0.0-testing/tools/ioemu-remote/xenstore.c
2008-07-19 01:04:37 +02:00
===================================================================
2010-01-16 01:12:54 +01:00
--- xen-4.0.0-testing.orig/tools/ioemu-remote/xenstore.c
+++ xen-4.0.0-testing/tools/ioemu-remote/xenstore.c
2010-03-01 16:05:50 +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;
2010-03-01 16:05:50 +01:00
@@ -644,8 +646,33 @@ void xenstore_parse_domain_config(int hv
2008-07-19 01:04:37 +02:00
}
}
2008-08-18 00:24:29 +02:00
pstrcpy(bs->filename, sizeof(bs->filename), params);
2009-05-04 18:38:09 +02:00
- if (bdrv_open2(bs, params, BDRV_O_CACHE_WB /* snapshot and write-back */, format) < 0)
+ 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
2010-03-01 16:05:50 +01:00
@@ -779,6 +806,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)