diff options
author | Trond Myklebust <Trond.Myklebust@netapp.com> | 2011-07-12 13:42:01 -0400 |
---|---|---|
committer | Trond Myklebust <Trond.Myklebust@netapp.com> | 2011-07-12 13:42:01 -0400 |
commit | 87ed5eb44ad9338b1617a0e78dea81d681325298 (patch) | |
tree | 17570d0d4cab601d13efad77d5aaaa02a8433dab | |
parent | c47abcf8ff4d0c56d20ce541e80d3e1c975f54b5 (diff) |
NFS: Don't use DATA_SYNC writes
If we're writing back data, and the FLUSH_STABLE flag is set, then we
always want to use NFS_FILE_SYNC, since we're always in a situation where
we're doing page reclaim, and so we want to free up the page as quickly
as possible.
If we're in the FLUSH_COND_STABLE case, then we either want to use another
unstable write (if we have to do a commit anyway) or again, we want to
use NFS_FILE_SYNC because we know that we have no more pages to write
out.
Signed-off-by: Trond Myklebust <Trond.Myklebust@netapp.com>
-rw-r--r-- | fs/nfs/write.c | 12 |
1 files changed, 8 insertions, 4 deletions
diff --git a/fs/nfs/write.c b/fs/nfs/write.c index 7f8732e31982..1af4d82c4959 100644 --- a/fs/nfs/write.c +++ b/fs/nfs/write.c | |||
@@ -872,10 +872,14 @@ static int nfs_write_rpcsetup(struct nfs_page *req, | |||
872 | data->args.context = get_nfs_open_context(req->wb_context); | 872 | data->args.context = get_nfs_open_context(req->wb_context); |
873 | data->args.lock_context = req->wb_lock_context; | 873 | data->args.lock_context = req->wb_lock_context; |
874 | data->args.stable = NFS_UNSTABLE; | 874 | data->args.stable = NFS_UNSTABLE; |
875 | if (how & (FLUSH_STABLE | FLUSH_COND_STABLE)) { | 875 | switch (how & (FLUSH_STABLE | FLUSH_COND_STABLE)) { |
876 | data->args.stable = NFS_DATA_SYNC; | 876 | case 0: |
877 | if (!nfs_need_commit(NFS_I(inode))) | 877 | break; |
878 | data->args.stable = NFS_FILE_SYNC; | 878 | case FLUSH_COND_STABLE: |
879 | if (nfs_need_commit(NFS_I(inode))) | ||
880 | break; | ||
881 | default: | ||
882 | data->args.stable = NFS_FILE_SYNC; | ||
879 | } | 883 | } |
880 | 884 | ||
881 | data->res.fattr = &data->fattr; | 885 | data->res.fattr = &data->fattr; |