diff options
author | Oleg Nesterov <oleg@redhat.com> | 2015-08-04 18:33:34 +0200 |
---|---|---|
committer | David S. Miller <davem@davemloft.net> | 2015-08-07 08:52:44 +0200 |
commit | 7ba8bd75ddc6b041b5716dbb29e49df3e9cc2928 (patch) | |
tree | 042783b9d9b3458790c4c914e9a219e9ac69c175 | |
parent | xen/netback: Wake dealloc thread after completing zerocopy work (diff) | |
download | linux-7ba8bd75ddc6b041b5716dbb29e49df3e9cc2928.tar.xz linux-7ba8bd75ddc6b041b5716dbb29e49df3e9cc2928.zip |
net: pktgen: don't abuse current->state in pktgen_thread_worker()
Commit 1fbe4b46caca "net: pktgen: kill the Wait for kthread_stop
code in pktgen_thread_worker()" removed (in particular) the final
__set_current_state(TASK_RUNNING) and I didn't notice the previous
set_current_state(TASK_INTERRUPTIBLE). This triggers the warning
in __might_sleep() after return.
Afaics, we can simply remove both set_current_state()'s, and we
could do this a long ago right after ef87979c273a2 "pktgen: better
scheduler friendliness" which changed pktgen_thread_worker() to
use wait_event_interruptible_timeout().
Reported-by: Huang Ying <ying.huang@intel.com>
Signed-off-by: Oleg Nesterov <oleg@redhat.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
-rw-r--r-- | net/core/pktgen.c | 3 |
1 files changed, 0 insertions, 3 deletions
diff --git a/net/core/pktgen.c b/net/core/pktgen.c index 1ebdf1c0d118..1cbd209192ea 100644 --- a/net/core/pktgen.c +++ b/net/core/pktgen.c @@ -3514,8 +3514,6 @@ static int pktgen_thread_worker(void *arg) set_freezable(); - __set_current_state(TASK_RUNNING); - while (!kthread_should_stop()) { pkt_dev = next_to_run(t); @@ -3560,7 +3558,6 @@ static int pktgen_thread_worker(void *arg) try_to_freeze(); } - set_current_state(TASK_INTERRUPTIBLE); pr_debug("%s stopping all device\n", t->tsk->comm); pktgen_stop(t); |