aboutsummaryrefslogtreecommitdiffstats
path: root/fs/nfsd/vfs.c
diff options
context:
space:
mode:
authorChuck Lever <chuck.lever@oracle.com>2018-03-27 10:53:27 -0400
committerJ. Bruce Fields <bfields@redhat.com>2018-04-03 15:08:15 -0400
commitd890be159a71395bd4ceca09233a8a56d7da69ee (patch)
treec8e7089ab7e52770d57842ecd189275de08bd789 /fs/nfsd/vfs.c
parentf394b62b7b0dd24757e9813e19f4b6091c5a28f6 (diff)
nfsd: Add I/O trace points in the NFSv4 write path
NFSv4 write compound processing invokes nfsd_vfs_write directly. The trace points currently in nfsd_write are not effective for NFSv4 writes. Move the trace points into the shared nfsd_vfs_write() helper. After the I/O, we also want to record any local I/O error that might have occurred, and the total count of bytes that were actually moved (rather than the requested number). Signed-off-by: Chuck Lever <chuck.lever@oracle.com> Signed-off-by: J. Bruce Fields <bfields@redhat.com>
Diffstat (limited to 'fs/nfsd/vfs.c')
-rw-r--r--fs/nfsd/vfs.c23
1 files changed, 12 insertions, 11 deletions
diff --git a/fs/nfsd/vfs.c b/fs/nfsd/vfs.c
index 857031952970..ee59a0b24fab 100644
--- a/fs/nfsd/vfs.c
+++ b/fs/nfsd/vfs.c
@@ -965,13 +965,15 @@ nfsd_vfs_write(struct svc_rqst *rqstp, struct svc_fh *fhp, struct file *file,
965{ 965{
966 struct svc_export *exp; 966 struct svc_export *exp;
967 struct iov_iter iter; 967 struct iov_iter iter;
968 __be32 err = 0; 968 __be32 nfserr;
969 int host_err; 969 int host_err;
970 int use_wgather; 970 int use_wgather;
971 loff_t pos = offset; 971 loff_t pos = offset;
972 unsigned int pflags = current->flags; 972 unsigned int pflags = current->flags;
973 rwf_t flags = 0; 973 rwf_t flags = 0;
974 974
975 trace_nfsd_write_opened(rqstp, fhp, offset, *cnt);
976
975 if (test_bit(RQ_LOCAL, &rqstp->rq_flags)) 977 if (test_bit(RQ_LOCAL, &rqstp->rq_flags))
976 /* 978 /*
977 * We want less throttling in balance_dirty_pages() 979 * We want less throttling in balance_dirty_pages()
@@ -994,22 +996,23 @@ nfsd_vfs_write(struct svc_rqst *rqstp, struct svc_fh *fhp, struct file *file,
994 host_err = vfs_iter_write(file, &iter, &pos, flags); 996 host_err = vfs_iter_write(file, &iter, &pos, flags);
995 if (host_err < 0) 997 if (host_err < 0)
996 goto out_nfserr; 998 goto out_nfserr;
997 *cnt = host_err; 999 nfsdstats.io_write += *cnt;
998 nfsdstats.io_write += host_err;
999 fsnotify_modify(file); 1000 fsnotify_modify(file);
1000 1001
1001 if (stable && use_wgather) 1002 if (stable && use_wgather)
1002 host_err = wait_for_concurrent_writes(file); 1003 host_err = wait_for_concurrent_writes(file);
1003 1004
1004out_nfserr: 1005out_nfserr:
1005 dprintk("nfsd: write complete host_err=%d\n", host_err); 1006 if (host_err >= 0) {
1006 if (host_err >= 0) 1007 trace_nfsd_write_io_done(rqstp, fhp, offset, *cnt);
1007 err = 0; 1008 nfserr = nfs_ok;
1008 else 1009 } else {
1009 err = nfserrno(host_err); 1010 trace_nfsd_write_err(rqstp, fhp, offset, host_err);
1011 nfserr = nfserrno(host_err);
1012 }
1010 if (test_bit(RQ_LOCAL, &rqstp->rq_flags)) 1013 if (test_bit(RQ_LOCAL, &rqstp->rq_flags))
1011 current_restore_flags(pflags, PF_LESS_THROTTLE); 1014 current_restore_flags(pflags, PF_LESS_THROTTLE);
1012 return err; 1015 return nfserr;
1013} 1016}
1014 1017
1015/* 1018/*
@@ -1067,9 +1070,7 @@ nfsd_write(struct svc_rqst *rqstp, struct svc_fh *fhp, loff_t offset,
1067 if (err) 1070 if (err)
1068 goto out; 1071 goto out;
1069 1072
1070 trace_nfsd_write_opened(rqstp, fhp, offset, *cnt);
1071 err = nfsd_vfs_write(rqstp, fhp, file, offset, vec, vlen, cnt, stable); 1073 err = nfsd_vfs_write(rqstp, fhp, file, offset, vec, vlen, cnt, stable);
1072 trace_nfsd_write_io_done(rqstp, fhp, offset, *cnt);
1073 fput(file); 1074 fput(file);
1074out: 1075out:
1075 trace_nfsd_write_done(rqstp, fhp, offset, *cnt); 1076 trace_nfsd_write_done(rqstp, fhp, offset, *cnt);