summary refs log tree commit diff stats
path: root/savevm.c
diff options
context:
space:
mode:
authorPaolo Bonzini <pbonzini@redhat.com>2013-02-22 17:36:37 +0100
committerJuan Quintela <quintela@redhat.com>2013-03-11 13:32:02 +0100
commitce39ee3184a02eca7f9529cc19b1582f6f704c70 (patch)
treef7d8e40a1e0253f805651852ce3431be67ec0393 /savevm.c
parent817b9ed5eb300dbb434d752da416441028539a96 (diff)
downloadfocaccia-qemu-ce39ee3184a02eca7f9529cc19b1582f6f704c70.tar.gz
focaccia-qemu-ce39ee3184a02eca7f9529cc19b1582f6f704c70.zip
qemu-file: fsync a writable stdio QEMUFile
This is what fd_close does.  Prepare for switching to a QEMUFile.

Reviewed-by: Orit Wasserman <owasserm@redhat.com>
Reviewed-by: Juan Quintela <quintela@redhat.com>
Signed-off-by: Paolo Bonzini <pbonzini@redhat.com>
Signed-off-by: Juan Quintela <quintela@redhat.com>
Diffstat (limited to 'savevm.c')
-rw-r--r--savevm.c18
1 files changed, 18 insertions, 0 deletions
diff --git a/savevm.c b/savevm.c
index 38699de4a3..1d49fde68b 100644
--- a/savevm.c
+++ b/savevm.c
@@ -256,6 +256,24 @@ static int stdio_fclose(void *opaque)
 {
     QEMUFileStdio *s = opaque;
     int ret = 0;
+
+    if (s->file->ops->put_buffer) {
+        int fd = fileno(s->stdio_file);
+        struct stat st;
+
+        ret = fstat(fd, &st);
+        if (ret == 0 && S_ISREG(st.st_mode)) {
+            /*
+             * If the file handle is a regular file make sure the
+             * data is flushed to disk before signaling success.
+             */
+            ret = fsync(fd);
+            if (ret != 0) {
+                ret = -errno;
+                return ret;
+            }
+        }
+    }
     if (fclose(s->stdio_file) == EOF) {
         ret = -errno;
     }