Commit 176082fb authored by Trond Myklebust's avatar Trond Myklebust

RPC: Fix a bug in rpc_killall_tasks().

  Shirly Ma reported seeing problems with rpc_killall_tasks() causing
  the task->tk_magic debugging test to trigger. It turns out we may be
  killing tasks that are not yet running or even initialized.
Signed-off-by: default avatarTrond Myklebust <Trond.Myklebust@netapp.com>
parent 65a909fb
...@@ -762,11 +762,6 @@ void rpc_init_task(struct rpc_task *task, struct rpc_clnt *clnt, rpc_action call ...@@ -762,11 +762,6 @@ void rpc_init_task(struct rpc_task *task, struct rpc_clnt *clnt, rpc_action call
if (!RPC_IS_ASYNC(task)) if (!RPC_IS_ASYNC(task))
init_waitqueue_head(&task->u.tk_wait.waitq); init_waitqueue_head(&task->u.tk_wait.waitq);
/* Add to global list of all tasks */
spin_lock(&rpc_sched_lock);
list_add(&task->tk_task, &all_tasks);
spin_unlock(&rpc_sched_lock);
if (clnt) { if (clnt) {
atomic_inc(&clnt->cl_users); atomic_inc(&clnt->cl_users);
if (clnt->cl_softrtry) if (clnt->cl_softrtry)
...@@ -779,6 +774,11 @@ void rpc_init_task(struct rpc_task *task, struct rpc_clnt *clnt, rpc_action call ...@@ -779,6 +774,11 @@ void rpc_init_task(struct rpc_task *task, struct rpc_clnt *clnt, rpc_action call
task->tk_magic = 0xf00baa; task->tk_magic = 0xf00baa;
task->tk_pid = rpc_task_id++; task->tk_pid = rpc_task_id++;
#endif #endif
/* Add to global list of all tasks */
spin_lock(&rpc_sched_lock);
list_add_tail(&task->tk_task, &all_tasks);
spin_unlock(&rpc_sched_lock);
dprintk("RPC: %4d new task procpid %d\n", task->tk_pid, dprintk("RPC: %4d new task procpid %d\n", task->tk_pid,
current->pid); current->pid);
} }
...@@ -952,12 +952,15 @@ void rpc_killall_tasks(struct rpc_clnt *clnt) ...@@ -952,12 +952,15 @@ void rpc_killall_tasks(struct rpc_clnt *clnt)
* Spin lock all_tasks to prevent changes... * Spin lock all_tasks to prevent changes...
*/ */
spin_lock(&rpc_sched_lock); spin_lock(&rpc_sched_lock);
alltask_for_each(rovr, le, &all_tasks) alltask_for_each(rovr, le, &all_tasks) {
if (! RPC_IS_ACTIVATED(rovr))
continue;
if (!clnt || rovr->tk_client == clnt) { if (!clnt || rovr->tk_client == clnt) {
rovr->tk_flags |= RPC_TASK_KILLED; rovr->tk_flags |= RPC_TASK_KILLED;
rpc_exit(rovr, -EIO); rpc_exit(rovr, -EIO);
rpc_wake_up_task(rovr); rpc_wake_up_task(rovr);
} }
}
spin_unlock(&rpc_sched_lock); spin_unlock(&rpc_sched_lock);
} }
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment