diff options
-rw-r--r-- | include/linux/sunrpc/sched.h | 12 | ||||
-rw-r--r-- | net/sunrpc/sched.c | 8 |
2 files changed, 3 insertions, 17 deletions
diff --git a/include/linux/sunrpc/sched.h b/include/linux/sunrpc/sched.h index 0d7be1642dc0..bf69fce84ed0 100644 --- a/include/linux/sunrpc/sched.h +++ b/include/linux/sunrpc/sched.h | |||
@@ -142,8 +142,7 @@ struct rpc_task_setup { | |||
142 | 142 | ||
143 | #define RPC_TASK_RUNNING 0 | 143 | #define RPC_TASK_RUNNING 0 |
144 | #define RPC_TASK_QUEUED 1 | 144 | #define RPC_TASK_QUEUED 1 |
145 | #define RPC_TASK_WAKEUP 2 | 145 | #define RPC_TASK_ACTIVE 2 |
146 | #define RPC_TASK_ACTIVE 3 | ||
147 | 146 | ||
148 | #define RPC_IS_RUNNING(t) test_bit(RPC_TASK_RUNNING, &(t)->tk_runstate) | 147 | #define RPC_IS_RUNNING(t) test_bit(RPC_TASK_RUNNING, &(t)->tk_runstate) |
149 | #define rpc_set_running(t) set_bit(RPC_TASK_RUNNING, &(t)->tk_runstate) | 148 | #define rpc_set_running(t) set_bit(RPC_TASK_RUNNING, &(t)->tk_runstate) |
@@ -165,15 +164,6 @@ struct rpc_task_setup { | |||
165 | smp_mb__after_clear_bit(); \ | 164 | smp_mb__after_clear_bit(); \ |
166 | } while (0) | 165 | } while (0) |
167 | 166 | ||
168 | #define rpc_start_wakeup(t) \ | ||
169 | (test_and_set_bit(RPC_TASK_WAKEUP, &(t)->tk_runstate) == 0) | ||
170 | #define rpc_finish_wakeup(t) \ | ||
171 | do { \ | ||
172 | smp_mb__before_clear_bit(); \ | ||
173 | clear_bit(RPC_TASK_WAKEUP, &(t)->tk_runstate); \ | ||
174 | smp_mb__after_clear_bit(); \ | ||
175 | } while (0) | ||
176 | |||
177 | #define RPC_IS_ACTIVATED(t) test_bit(RPC_TASK_ACTIVE, &(t)->tk_runstate) | 167 | #define RPC_IS_ACTIVATED(t) test_bit(RPC_TASK_ACTIVE, &(t)->tk_runstate) |
178 | 168 | ||
179 | /* | 169 | /* |
diff --git a/net/sunrpc/sched.c b/net/sunrpc/sched.c index 043eef4c15a2..88a686a8e43e 100644 --- a/net/sunrpc/sched.c +++ b/net/sunrpc/sched.c | |||
@@ -384,12 +384,8 @@ static void __rpc_do_wake_up_task(struct rpc_wait_queue *queue, struct rpc_task | |||
384 | */ | 384 | */ |
385 | static void rpc_wake_up_task_queue_locked(struct rpc_wait_queue *queue, struct rpc_task *task) | 385 | static void rpc_wake_up_task_queue_locked(struct rpc_wait_queue *queue, struct rpc_task *task) |
386 | { | 386 | { |
387 | if (!RPC_IS_QUEUED(task) || task->tk_waitqueue != queue) | 387 | if (RPC_IS_QUEUED(task) && task->tk_waitqueue == queue) |
388 | return; | 388 | __rpc_do_wake_up_task(queue, task); |
389 | if (rpc_start_wakeup(task)) { | ||
390 | __rpc_do_wake_up_task(queue, task); | ||
391 | rpc_finish_wakeup(task); | ||
392 | } | ||
393 | } | 389 | } |
394 | 390 | ||
395 | /* | 391 | /* |