diff options
author | Ingo Molnar <mingo@elte.hu> | 2008-01-25 15:08:02 -0500 |
---|---|---|
committer | Ingo Molnar <mingo@elte.hu> | 2008-01-25 15:08:02 -0500 |
commit | 82a1fcb90287052aabfa235e7ffc693ea003fe69 (patch) | |
tree | 826b464a248bebe259fe787f7b8d17d5626cf2c5 /kernel/sched.c | |
parent | d0d23b5432fe61229dd3641c5e94d4130bc4e61b (diff) |
softlockup: automatically detect hung TASK_UNINTERRUPTIBLE tasks
this patch extends the soft-lockup detector to automatically
detect hung TASK_UNINTERRUPTIBLE tasks. Such hung tasks are
printed the following way:
------------------>
INFO: task prctl:3042 blocked for more than 120 seconds.
"echo 0 > /proc/sys/kernel/hung_task_timeout_secs" disables this message
prctl D fd5e3793 0 3042 2997
f6050f38 00000046 00000001 fd5e3793 00000009 c06d8264 c06dae80 00000286
f6050f40 f6050f00 f7d34d90 f7d34fc8 c1e1be80 00000001 f6050000 00000000
f7e92d00 00000286 f6050f18 c0489d1a f6050f40 00006605 00000000 c0133a5b
Call Trace:
[<c04883a5>] schedule_timeout+0x6d/0x8b
[<c04883d8>] schedule_timeout_uninterruptible+0x15/0x17
[<c0133a76>] msleep+0x10/0x16
[<c0138974>] sys_prctl+0x30/0x1e2
[<c0104c52>] sysenter_past_esp+0x5f/0xa5
=======================
2 locks held by prctl/3042:
#0: (&sb->s_type->i_mutex_key#5){--..}, at: [<c0197d11>] do_fsync+0x38/0x7a
#1: (jbd_handle){--..}, at: [<c01ca3d2>] journal_start+0xc7/0xe9
<------------------
the current default timeout is 120 seconds. Such messages are printed
up to 10 times per bootup. If the system has crashed already then the
messages are not printed.
if lockdep is enabled then all held locks are printed as well.
this feature is a natural extension to the softlockup-detector (kernel
locked up without scheduling) and to the NMI watchdog (kernel locked up
with IRQs disabled).
[ Gautham R Shenoy <ego@in.ibm.com>: CPU hotplug fixes. ]
[ Andrew Morton <akpm@linux-foundation.org>: build warning fix. ]
Signed-off-by: Ingo Molnar <mingo@elte.hu>
Signed-off-by: Arjan van de Ven <arjan@linux.intel.com>
Diffstat (limited to 'kernel/sched.c')
-rw-r--r-- | kernel/sched.c | 4 |
1 files changed, 2 insertions, 2 deletions
diff --git a/kernel/sched.c b/kernel/sched.c index c0e2db683e29..5b3d46574eeb 100644 --- a/kernel/sched.c +++ b/kernel/sched.c | |||
@@ -4945,7 +4945,7 @@ out_unlock: | |||
4945 | 4945 | ||
4946 | static const char stat_nam[] = "RSDTtZX"; | 4946 | static const char stat_nam[] = "RSDTtZX"; |
4947 | 4947 | ||
4948 | static void show_task(struct task_struct *p) | 4948 | void sched_show_task(struct task_struct *p) |
4949 | { | 4949 | { |
4950 | unsigned long free = 0; | 4950 | unsigned long free = 0; |
4951 | unsigned state; | 4951 | unsigned state; |
@@ -4998,7 +4998,7 @@ void show_state_filter(unsigned long state_filter) | |||
4998 | */ | 4998 | */ |
4999 | touch_nmi_watchdog(); | 4999 | touch_nmi_watchdog(); |
5000 | if (!state_filter || (p->state & state_filter)) | 5000 | if (!state_filter || (p->state & state_filter)) |
5001 | show_task(p); | 5001 | sched_show_task(p); |
5002 | } while_each_thread(g, p); | 5002 | } while_each_thread(g, p); |
5003 | 5003 | ||
5004 | touch_all_softlockup_watchdogs(); | 5004 | touch_all_softlockup_watchdogs(); |