From: Trond Myklebust Date: Sun, 6 May 2012 23:10:59 +0000 (-0400) Subject: NFS: Don't do a full flush to disk on close() if we hold a delegation X-Git-Tag: v3.5-rc1~52^2~85 X-Git-Url: https://openfabrics.org/gitweb/?a=commitdiff_plain;h=14546c337588370dced50dcaf43398939be9829e;p=~emulex%2Finfiniband.git NFS: Don't do a full flush to disk on close() if we hold a delegation If we hold a delegation then we know that it should be safe to continue to cache the data beyond the close(). However since the process that wrote the data may die after close(), we may still want to send the data to server before those RPCSEC_GSS credentials expire. We therefore compromise by starting writeback to the server, but don't wait for completion. Signed-off-by: Trond Myklebust --- diff --git a/fs/nfs/file.c b/fs/nfs/file.c index aa9b709fd32..8eda8a6644c 100644 --- a/fs/nfs/file.c +++ b/fs/nfs/file.c @@ -174,6 +174,13 @@ nfs_file_flush(struct file *file, fl_owner_t id) if ((file->f_mode & FMODE_WRITE) == 0) return 0; + /* + * If we're holding a write delegation, then just start the i/o + * but don't wait for completion (or send a commit). + */ + if (nfs_have_delegation(inode, FMODE_WRITE)) + return filemap_fdatawrite(file->f_mapping); + /* Flush writes to the server and return any errors */ return vfs_fsync(file, 0); }