carlwgeorge / rpms / qemu

Forked from rpms/qemu a year ago
Clone
a7b9285
From b38aa57a296bd4fdc31a9ebf3f28ffb612ad6e32 Mon Sep 17 00:00:00 2001
Alon Levy 408bdb5
From: Paolo Bonzini <pbonzini@redhat.com>
Alon Levy 408bdb5
Date: Fri, 22 Feb 2013 17:36:39 +0100
a7b9285
Subject: [PATCH] qemu-file: add writable socket QEMUFile
Alon Levy 408bdb5
Alon Levy 408bdb5
Reviewed-by: Orit Wasserman <owasserm@redhat.com>
Alon Levy 408bdb5
Reviewed-by: Juan Quintela <quintela@redhat.com>
Alon Levy 408bdb5
Signed-off-by: Paolo Bonzini <pbonzini@redhat.com>
Alon Levy 408bdb5
Signed-off-by: Juan Quintela <quintela@redhat.com>
a7b9285
(cherry picked from commit 0cc3f3ccc9d29acc94b995430518bda1c7c01bef)
Alon Levy 408bdb5
---
Alon Levy 408bdb5
 include/migration/qemu-file.h |  2 +-
Alon Levy 408bdb5
 migration-tcp.c               |  2 +-
Alon Levy 408bdb5
 migration-unix.c              |  2 +-
Alon Levy 408bdb5
 savevm.c                      | 33 +++++++++++++++++++++++++++++++--
Alon Levy 408bdb5
 4 files changed, 34 insertions(+), 5 deletions(-)
Alon Levy 408bdb5
Alon Levy 408bdb5
diff --git a/include/migration/qemu-file.h b/include/migration/qemu-file.h
Alon Levy 408bdb5
index 987e719..25e8461 100644
Alon Levy 408bdb5
--- a/include/migration/qemu-file.h
Alon Levy 408bdb5
+++ b/include/migration/qemu-file.h
Alon Levy 408bdb5
@@ -76,7 +76,7 @@ typedef struct QEMUFileOps {
Alon Levy 408bdb5
 QEMUFile *qemu_fopen_ops(void *opaque, const QEMUFileOps *ops);
Alon Levy 408bdb5
 QEMUFile *qemu_fopen(const char *filename, const char *mode);
Alon Levy 408bdb5
 QEMUFile *qemu_fdopen(int fd, const char *mode);
Alon Levy 408bdb5
-QEMUFile *qemu_fopen_socket(int fd);
Alon Levy 408bdb5
+QEMUFile *qemu_fopen_socket(int fd, const char *mode);
Alon Levy 408bdb5
 QEMUFile *qemu_popen_cmd(const char *command, const char *mode);
Alon Levy 408bdb5
 int qemu_get_fd(QEMUFile *f);
Alon Levy 408bdb5
 int qemu_fclose(QEMUFile *f);
Alon Levy 408bdb5
diff --git a/migration-tcp.c b/migration-tcp.c
Alon Levy 408bdb5
index 59e3b7e..a748195 100644
Alon Levy 408bdb5
--- a/migration-tcp.c
Alon Levy 408bdb5
+++ b/migration-tcp.c
Alon Levy 408bdb5
@@ -95,7 +95,7 @@ static void tcp_accept_incoming_migration(void *opaque)
Alon Levy 408bdb5
         goto out;
Alon Levy 408bdb5
     }
Alon Levy 408bdb5
 
Alon Levy 408bdb5
-    f = qemu_fopen_socket(c);
Alon Levy 408bdb5
+    f = qemu_fopen_socket(c, "rb");
Alon Levy 408bdb5
     if (f == NULL) {
Alon Levy 408bdb5
         fprintf(stderr, "could not qemu_fopen socket\n");
Alon Levy 408bdb5
         goto out;
Alon Levy 408bdb5
diff --git a/migration-unix.c b/migration-unix.c
Alon Levy 408bdb5
index 0ca2a21..d078f43 100644
Alon Levy 408bdb5
--- a/migration-unix.c
Alon Levy 408bdb5
+++ b/migration-unix.c
Alon Levy 408bdb5
@@ -95,7 +95,7 @@ static void unix_accept_incoming_migration(void *opaque)
Alon Levy 408bdb5
         goto out;
Alon Levy 408bdb5
     }
Alon Levy 408bdb5
 
Alon Levy 408bdb5
-    f = qemu_fopen_socket(c);
Alon Levy 408bdb5
+    f = qemu_fopen_socket(c, "rb");
Alon Levy 408bdb5
     if (f == NULL) {
Alon Levy 408bdb5
         fprintf(stderr, "could not qemu_fopen socket\n");
Alon Levy 408bdb5
         goto out;
Alon Levy 408bdb5
diff --git a/savevm.c b/savevm.c
Alon Levy 408bdb5
index 6d6f1f1..76c88c7 100644
Alon Levy 408bdb5
--- a/savevm.c
Alon Levy 408bdb5
+++ b/savevm.c
Alon Levy 408bdb5
@@ -198,6 +198,18 @@ static int socket_get_buffer(void *opaque, uint8_t *buf, int64_t pos, int size)
Alon Levy 408bdb5
     return len;
Alon Levy 408bdb5
 }
Alon Levy 408bdb5
 
Alon Levy 408bdb5
+static int socket_put_buffer(void *opaque, const uint8_t *buf, int64_t pos, int size)
Alon Levy 408bdb5
+{
Alon Levy 408bdb5
+    QEMUFileSocket *s = opaque;
Alon Levy 408bdb5
+    ssize_t len;
Alon Levy 408bdb5
+
Alon Levy 408bdb5
+    len = qemu_send_full(s->fd, buf, size, 0);
Alon Levy 408bdb5
+    if (len < size) {
Alon Levy 408bdb5
+        len = -socket_error();
Alon Levy 408bdb5
+    }
Alon Levy 408bdb5
+    return len;
Alon Levy 408bdb5
+}
Alon Levy 408bdb5
+
Alon Levy 408bdb5
 static int socket_close(void *opaque)
Alon Levy 408bdb5
 {
Alon Levy 408bdb5
     QEMUFileSocket *s = opaque;
Alon Levy 408bdb5
@@ -369,12 +381,29 @@ static const QEMUFileOps socket_read_ops = {
Alon Levy 408bdb5
     .close =      socket_close
Alon Levy 408bdb5
 };
Alon Levy 408bdb5
 
Alon Levy 408bdb5
-QEMUFile *qemu_fopen_socket(int fd)
Alon Levy 408bdb5
+static const QEMUFileOps socket_write_ops = {
Alon Levy 408bdb5
+    .get_fd =     socket_get_fd,
Alon Levy 408bdb5
+    .put_buffer = socket_put_buffer,
Alon Levy 408bdb5
+    .close =      socket_close
Alon Levy 408bdb5
+};
Alon Levy 408bdb5
+
Alon Levy 408bdb5
+QEMUFile *qemu_fopen_socket(int fd, const char *mode)
Alon Levy 408bdb5
 {
Alon Levy 408bdb5
     QEMUFileSocket *s = g_malloc0(sizeof(QEMUFileSocket));
Alon Levy 408bdb5
 
Alon Levy 408bdb5
+    if (mode == NULL ||
Alon Levy 408bdb5
+        (mode[0] != 'r' && mode[0] != 'w') ||
Alon Levy 408bdb5
+        mode[1] != 'b' || mode[2] != 0) {
Alon Levy 408bdb5
+        fprintf(stderr, "qemu_fopen: Argument validity check failed\n");
Alon Levy 408bdb5
+        return NULL;
Alon Levy 408bdb5
+    }
Alon Levy 408bdb5
+
Alon Levy 408bdb5
     s->fd = fd;
Alon Levy 408bdb5
-    s->file = qemu_fopen_ops(s, &socket_read_ops);
Alon Levy 408bdb5
+    if (mode[0] == 'w') {
Alon Levy 408bdb5
+        s->file = qemu_fopen_ops(s, &socket_write_ops);
Alon Levy 408bdb5
+    } else {
Alon Levy 408bdb5
+        s->file = qemu_fopen_ops(s, &socket_read_ops);
Alon Levy 408bdb5
+    }
Alon Levy 408bdb5
     return s->file;
Alon Levy 408bdb5
 }
Alon Levy 408bdb5