+2006-02-21  Miklos Szeredi <miklos@szeredi.hu>
+
+       * fusexmp_fh: implement flush() method and call close() on the
+       open file descriptor.  This is needed if used on an NFS
+       filesystem, which buffers data until file is closed.  Franco Broi
+       spotted the situation when 'cp -p' failed to set the modification
+       time because of this.
+
 2006-02-20  Miklos Szeredi <miklos@szeredi.hu>
 
        * Released 2.6.0-pre1
 
     return 0;
 }
 
+static int xmp_flush(const char *path, struct fuse_file_info *fi)
+{
+    int res;
+
+    (void) path;
+    /* This is called from every close on an open file, so call the
+       close on the underlying filesystem.  But since flush may be
+       called multiple times for an open file, this must not really
+       close the file.  This is important if used on a network
+       filesystem like NFS which flush the data/metadata on close() */
+    res = close(dup(fi->fh));
+    if (res == -1)
+        return -errno;
+
+    return 0;
+}
+
 static int xmp_release(const char *path, struct fuse_file_info *fi)
 {
     (void) path;
     .read      = xmp_read,
     .write     = xmp_write,
     .statfs    = xmp_statfs,
+    .flush     = xmp_flush,
     .release   = xmp_release,
     .fsync     = xmp_fsync,
 #ifdef HAVE_SETXATTR