sched/wait: Introduce TASK_NOLOAD and TASK_IDLE
authorPeter Zijlstra <peterz@infradead.org>
Fri, 8 May 2015 12:23:45 +0000 (14:23 +0200)
committerIngo Molnar <mingo@kernel.org>
Tue, 19 May 2015 06:39:18 +0000 (08:39 +0200)
commit80ed87c8a9ca0cad7ca66cf3bbdfb17559a66dcf
tree7da247bcde968e1ee6900dde15c875a44d145e3b
parent8222dbe21e79338de92d5e1956cd1e3994cc9f93
sched/wait: Introduce TASK_NOLOAD and TASK_IDLE

Currently people use TASK_INTERRUPTIBLE to idle kthreads and wait for
'work' because TASK_UNINTERRUPTIBLE contributes to the loadavg. Having
all idle kthreads contribute to the loadavg is somewhat silly.

Now mostly this works OK, because kthreads have all their signals
masked. However there's a few sites where this is causing problems and
TASK_UNINTERRUPTIBLE should be used, except for that loadavg issue.

This patch adds TASK_NOLOAD which, when combined with
TASK_UNINTERRUPTIBLE avoids the loadavg accounting.

As most of imagined usage sites are loops where a thread wants to
idle, waiting for work, a helper TASK_IDLE is introduced.

Signed-off-by: Peter Zijlstra (Intel) <peterz@infradead.org>
Cc: Julian Anastasov <ja@ssi.bg>
Cc: Linus Torvalds <torvalds@linux-foundation.org>
Cc: NeilBrown <neilb@suse.de>
Cc: Oleg Nesterov <oleg@redhat.com>
Cc: Peter Zijlstra <peterz@infradead.org>
Cc: Thomas Gleixner <tglx@linutronix.de>
Signed-off-by: Ingo Molnar <mingo@kernel.org>
include/linux/sched.h
include/trace/events/sched.h