aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--fs/nfs/iostat.h19
-rw-r--r--fs/nfs/nfs3proc.c13
-rw-r--r--fs/nfs/nfs4proc.c5
3 files changed, 27 insertions, 10 deletions
diff --git a/fs/nfs/iostat.h b/fs/nfs/iostat.h
index dc080e50ec57..7a7495153317 100644
--- a/fs/nfs/iostat.h
+++ b/fs/nfs/iostat.h
@@ -103,6 +103,7 @@ enum nfs_stat_eventcounters {
103 NFSIOS_SILLYRENAME, 103 NFSIOS_SILLYRENAME,
104 NFSIOS_SHORTREAD, 104 NFSIOS_SHORTREAD,
105 NFSIOS_SHORTWRITE, 105 NFSIOS_SHORTWRITE,
106 NFSIOS_DELAY,
106 __NFSIOS_COUNTSMAX, 107 __NFSIOS_COUNTSMAX,
107}; 108};
108 109
@@ -116,28 +117,38 @@ struct nfs_iostats {
116 unsigned long events[__NFSIOS_COUNTSMAX]; 117 unsigned long events[__NFSIOS_COUNTSMAX];
117} ____cacheline_aligned; 118} ____cacheline_aligned;
118 119
119static inline void nfs_inc_stats(struct inode *inode, enum nfs_stat_eventcounters stat) 120static inline void nfs_inc_server_stats(struct nfs_server *server, enum nfs_stat_eventcounters stat)
120{ 121{
121 struct nfs_iostats *iostats; 122 struct nfs_iostats *iostats;
122 int cpu; 123 int cpu;
123 124
124 cpu = get_cpu(); 125 cpu = get_cpu();
125 iostats = per_cpu_ptr(NFS_SERVER(inode)->io_stats, cpu); 126 iostats = per_cpu_ptr(server->io_stats, cpu);
126 iostats->events[stat] ++; 127 iostats->events[stat] ++;
127 put_cpu_no_resched(); 128 put_cpu_no_resched();
128} 129}
129 130
130static inline void nfs_add_stats(struct inode *inode, enum nfs_stat_bytecounters stat, unsigned long addend) 131static inline void nfs_inc_stats(struct inode *inode, enum nfs_stat_eventcounters stat)
132{
133 nfs_inc_server_stats(NFS_SERVER(inode), stat);
134}
135
136static inline void nfs_add_server_stats(struct nfs_server *server, enum nfs_stat_bytecounters stat, unsigned long addend)
131{ 137{
132 struct nfs_iostats *iostats; 138 struct nfs_iostats *iostats;
133 int cpu; 139 int cpu;
134 140
135 cpu = get_cpu(); 141 cpu = get_cpu();
136 iostats = per_cpu_ptr(NFS_SERVER(inode)->io_stats, cpu); 142 iostats = per_cpu_ptr(server->io_stats, cpu);
137 iostats->bytes[stat] += addend; 143 iostats->bytes[stat] += addend;
138 put_cpu_no_resched(); 144 put_cpu_no_resched();
139} 145}
140 146
147static inline void nfs_add_stats(struct inode *inode, enum nfs_stat_bytecounters stat, unsigned long addend)
148{
149 nfs_add_server_stats(NFS_SERVER(inode), stat, addend);
150}
151
141static inline struct nfs_iostats *nfs_alloc_iostats(void) 152static inline struct nfs_iostats *nfs_alloc_iostats(void)
142{ 153{
143 return alloc_percpu(struct nfs_iostats); 154 return alloc_percpu(struct nfs_iostats);
diff --git a/fs/nfs/nfs3proc.c b/fs/nfs/nfs3proc.c
index ed67567f0556..7204ba5b2bf8 100644
--- a/fs/nfs/nfs3proc.c
+++ b/fs/nfs/nfs3proc.c
@@ -19,6 +19,8 @@
19#include <linux/smp_lock.h> 19#include <linux/smp_lock.h>
20#include <linux/nfs_mount.h> 20#include <linux/nfs_mount.h>
21 21
22#include "iostat.h"
23
22#define NFSDBG_FACILITY NFSDBG_PROC 24#define NFSDBG_FACILITY NFSDBG_PROC
23 25
24extern struct rpc_procinfo nfs3_procedures[]; 26extern struct rpc_procinfo nfs3_procedures[];
@@ -58,10 +60,11 @@ nfs3_rpc_call_wrapper(struct rpc_clnt *clnt, u32 proc, void *argp, void *resp, i
58 nfs3_rpc_wrapper(clnt, msg, flags) 60 nfs3_rpc_wrapper(clnt, msg, flags)
59 61
60static int 62static int
61nfs3_async_handle_jukebox(struct rpc_task *task) 63nfs3_async_handle_jukebox(struct rpc_task *task, struct inode *inode)
62{ 64{
63 if (task->tk_status != -EJUKEBOX) 65 if (task->tk_status != -EJUKEBOX)
64 return 0; 66 return 0;
67 nfs_inc_stats(inode, NFSIOS_DELAY);
65 task->tk_status = 0; 68 task->tk_status = 0;
66 rpc_restart_call(task); 69 rpc_restart_call(task);
67 rpc_delay(task, NFS_JUKEBOX_RETRY_TIME); 70 rpc_delay(task, NFS_JUKEBOX_RETRY_TIME);
@@ -447,7 +450,7 @@ nfs3_proc_unlink_done(struct dentry *dir, struct rpc_task *task)
447 struct rpc_message *msg = &task->tk_msg; 450 struct rpc_message *msg = &task->tk_msg;
448 struct nfs_fattr *dir_attr; 451 struct nfs_fattr *dir_attr;
449 452
450 if (nfs3_async_handle_jukebox(task)) 453 if (nfs3_async_handle_jukebox(task, dir->d_inode))
451 return 1; 454 return 1;
452 if (msg->rpc_argp) { 455 if (msg->rpc_argp) {
453 dir_attr = (struct nfs_fattr*)msg->rpc_resp; 456 dir_attr = (struct nfs_fattr*)msg->rpc_resp;
@@ -748,7 +751,7 @@ static void nfs3_read_done(struct rpc_task *task, void *calldata)
748{ 751{
749 struct nfs_read_data *data = calldata; 752 struct nfs_read_data *data = calldata;
750 753
751 if (nfs3_async_handle_jukebox(task)) 754 if (nfs3_async_handle_jukebox(task, data->inode))
752 return; 755 return;
753 /* Call back common NFS readpage processing */ 756 /* Call back common NFS readpage processing */
754 if (task->tk_status >= 0) 757 if (task->tk_status >= 0)
@@ -786,7 +789,7 @@ static void nfs3_write_done(struct rpc_task *task, void *calldata)
786{ 789{
787 struct nfs_write_data *data = calldata; 790 struct nfs_write_data *data = calldata;
788 791
789 if (nfs3_async_handle_jukebox(task)) 792 if (nfs3_async_handle_jukebox(task, data->inode))
790 return; 793 return;
791 if (task->tk_status >= 0) 794 if (task->tk_status >= 0)
792 nfs_post_op_update_inode(data->inode, data->res.fattr); 795 nfs_post_op_update_inode(data->inode, data->res.fattr);
@@ -833,7 +836,7 @@ static void nfs3_commit_done(struct rpc_task *task, void *calldata)
833{ 836{
834 struct nfs_write_data *data = calldata; 837 struct nfs_write_data *data = calldata;
835 838
836 if (nfs3_async_handle_jukebox(task)) 839 if (nfs3_async_handle_jukebox(task, data->inode))
837 return; 840 return;
838 if (task->tk_status >= 0) 841 if (task->tk_status >= 0)
839 nfs_post_op_update_inode(data->inode, data->res.fattr); 842 nfs_post_op_update_inode(data->inode, data->res.fattr);
diff --git a/fs/nfs/nfs4proc.c b/fs/nfs/nfs4proc.c
index 77a565eba562..f1ff4fa6cce5 100644
--- a/fs/nfs/nfs4proc.c
+++ b/fs/nfs/nfs4proc.c
@@ -51,6 +51,7 @@
51 51
52#include "nfs4_fs.h" 52#include "nfs4_fs.h"
53#include "delegation.h" 53#include "delegation.h"
54#include "iostat.h"
54 55
55#define NFSDBG_FACILITY NFSDBG_PROC 56#define NFSDBG_FACILITY NFSDBG_PROC
56 57
@@ -2755,8 +2756,10 @@ nfs4_async_handle_error(struct rpc_task *task, const struct nfs_server *server)
2755 rpc_wake_up_task(task); 2756 rpc_wake_up_task(task);
2756 task->tk_status = 0; 2757 task->tk_status = 0;
2757 return -EAGAIN; 2758 return -EAGAIN;
2758 case -NFS4ERR_GRACE:
2759 case -NFS4ERR_DELAY: 2759 case -NFS4ERR_DELAY:
2760 nfs_inc_server_stats((struct nfs_server *) server,
2761 NFSIOS_DELAY);
2762 case -NFS4ERR_GRACE:
2760 rpc_delay(task, NFS4_POLL_RETRY_MAX); 2763 rpc_delay(task, NFS4_POLL_RETRY_MAX);
2761 task->tk_status = 0; 2764 task->tk_status = 0;
2762 return -EAGAIN; 2765 return -EAGAIN;