diff options
author | Trond Myklebust <trond.myklebust@primarydata.com> | 2016-06-25 17:57:39 -0400 |
---|---|---|
committer | Trond Myklebust <trond.myklebust@primarydata.com> | 2016-07-05 19:11:08 -0400 |
commit | e95fc4a06983c14273a39d26aad9cc5a8a09ff64 (patch) | |
tree | b5a1fa10278be617175f2c8cb99ddf0cad3b85e8 /fs/nfs | |
parent | 837bb1d752d92ea4d870877ffbd6ec5cf76624b3 (diff) | |
download | linux-e95fc4a06983c14273a39d26aad9cc5a8a09ff64.tar.gz linux-e95fc4a06983c14273a39d26aad9cc5a8a09ff64.tar.bz2 linux-e95fc4a06983c14273a39d26aad9cc5a8a09ff64.zip |
NFSv4.2: llseek(SEEK_HOLE) and llseek(SEEK_DATA) don't require data sync
We want to ensure that we write the cached data to the server, but
don't require it be synced to disk. If the server reboots, we will
get a stateid error, which will cause us to retry anyway.
Signed-off-by: Trond Myklebust <trond.myklebust@primarydata.com>
Diffstat (limited to 'fs/nfs')
-rw-r--r-- | fs/nfs/nfs42proc.c | 6 |
1 files changed, 5 insertions, 1 deletions
diff --git a/fs/nfs/nfs42proc.c b/fs/nfs/nfs42proc.c index b7d457cea03f..616dc254b38b 100644 --- a/fs/nfs/nfs42proc.c +++ b/fs/nfs/nfs42proc.c @@ -269,7 +269,11 @@ static loff_t _nfs42_proc_llseek(struct file *filep, if (status) return status; - nfs_wb_all(inode); + status = nfs_filemap_write_and_wait_range(inode->i_mapping, + offset, LLONG_MAX); + if (status) + return status; + status = nfs4_call_sync(server->client, server, &msg, &args.seq_args, &res.seq_res, 0); if (status == -ENOTSUPP) |