SUNRPC: Fix up tracking of timeouts
authorTrond Myklebust <trondmy@gmail.com>
Sun, 7 Apr 2019 17:58:50 +0000 (13:58 -0400)
committerAnna Schumaker <Anna.Schumaker@Netapp.com>
Thu, 25 Apr 2019 18:18:13 +0000 (14:18 -0400)
Add a helper to ensure that debugfs and friends print out the
correct current task timeout value.

Signed-off-by: Trond Myklebust <trond.myklebust@hammerspace.com>
Signed-off-by: Anna Schumaker <Anna.Schumaker@Netapp.com>
include/linux/sunrpc/sched.h
include/trace/events/sunrpc.h
net/sunrpc/clnt.c
net/sunrpc/debugfs.c
net/sunrpc/sched.c

index 61ba533..c5ad02c 100644 (file)
@@ -226,6 +226,7 @@ void                rpc_execute(struct rpc_task *);
 void           rpc_init_priority_wait_queue(struct rpc_wait_queue *, const char *);
 void           rpc_init_wait_queue(struct rpc_wait_queue *, const char *);
 void           rpc_destroy_wait_queue(struct rpc_wait_queue *);
+unsigned long  rpc_task_timeout(const struct rpc_task *task);
 void           rpc_sleep_on_timeout(struct rpc_wait_queue *queue,
                                        struct rpc_task *task,
                                        rpc_action action,
index 5e3b77d..dd301db 100644 (file)
@@ -186,7 +186,7 @@ DECLARE_EVENT_CLASS(rpc_task_queued,
                __entry->client_id = task->tk_client ?
                                     task->tk_client->cl_clid : -1;
                __entry->task_id = task->tk_pid;
-               __entry->timeout = task->tk_timeout;
+               __entry->timeout = rpc_task_timeout(task);
                __entry->runstate = task->tk_runstate;
                __entry->status = task->tk_status;
                __entry->flags = task->tk_flags;
index 216d5e5..b25f317 100644 (file)
@@ -2874,7 +2874,7 @@ static void rpc_show_task(const struct rpc_clnt *clnt,
 
        printk(KERN_INFO "%5u %04x %6d %8p %8p %8ld %8p %sv%u %s a:%ps q:%s\n",
                task->tk_pid, task->tk_flags, task->tk_status,
-               clnt, task->tk_rqstp, task->tk_timeout, task->tk_ops,
+               clnt, task->tk_rqstp, rpc_task_timeout(task), task->tk_ops,
                clnt->cl_program->name, clnt->cl_vers, rpc_proc_name(task),
                task->tk_action, rpc_waitq);
 }
index 19bb356..95ebd76 100644 (file)
@@ -33,7 +33,7 @@ tasks_show(struct seq_file *f, void *v)
 
        seq_printf(f, "%5u %04x %6d 0x%x 0x%x %8ld %ps %sv%u %s a:%ps q:%s\n",
                task->tk_pid, task->tk_flags, task->tk_status,
-               clnt->cl_clid, xid, task->tk_timeout, task->tk_ops,
+               clnt->cl_clid, xid, rpc_task_timeout(task), task->tk_ops,
                clnt->cl_program->name, clnt->cl_vers, rpc_proc_name(task),
                task->tk_action, rpc_waitq);
        return 0;
index 7e0f7b8..40944c3 100644 (file)
@@ -58,6 +58,20 @@ static struct rpc_wait_queue delay_queue;
 struct workqueue_struct *rpciod_workqueue __read_mostly;
 struct workqueue_struct *xprtiod_workqueue __read_mostly;
 
+unsigned long
+rpc_task_timeout(const struct rpc_task *task)
+{
+       unsigned long timeout = READ_ONCE(task->tk_timeout);
+
+       if (timeout != 0) {
+               unsigned long now = jiffies;
+               if (time_before(now, timeout))
+                       return timeout - now;
+       }
+       return 0;
+}
+EXPORT_SYMBOL_GPL(rpc_task_timeout);
+
 /*
  * Disable the timer for a given RPC task. Should be called with
  * queue->lock and bh_disabled in order to avoid races within