diff options
| author | Takashi Iwai <tiwai@suse.de> | 2012-01-31 15:13:14 +0100 | 
|---|---|---|
| committer | Takashi Iwai <tiwai@suse.de> | 2012-01-31 15:13:14 +0100 | 
| commit | ea51e5040e24eefe44d70bc654a237ca1f0225b0 (patch) | |
| tree | df2e5922dcdfafae62a10d8cd97f98121064fc23 /kernel/hung_task.c | |
| parent | 3422a47041b8cb8f14ac1e3926bcf711121df6dc (diff) | |
| parent | 8dbd52daee38adaae4d5a674bcca837e694a4f4c (diff) | |
Merge branch 'fix/asoc' into for-linus
Diffstat (limited to 'kernel/hung_task.c')
| -rw-r--r-- | kernel/hung_task.c | 14 | 
1 files changed, 10 insertions, 4 deletions
| diff --git a/kernel/hung_task.c b/kernel/hung_task.c index 8b1748d0172c..2e48ec0c2e91 100644 --- a/kernel/hung_task.c +++ b/kernel/hung_task.c @@ -74,11 +74,17 @@ static void check_hung_task(struct task_struct *t, unsigned long timeout)  	/*  	 * Ensure the task is not frozen. -	 * Also, when a freshly created task is scheduled once, changes -	 * its state to TASK_UNINTERRUPTIBLE without having ever been -	 * switched out once, it musn't be checked. +	 * Also, skip vfork and any other user process that freezer should skip.  	 */ -	if (unlikely(t->flags & PF_FROZEN || !switch_count)) +	if (unlikely(t->flags & (PF_FROZEN | PF_FREEZER_SKIP))) +	    return; + +	/* +	 * When a freshly created task is scheduled once, changes its state to +	 * TASK_UNINTERRUPTIBLE without having ever been switched out once, it +	 * musn't be checked. +	 */ +	if (unlikely(!switch_count))  		return;  	if (switch_count != t->last_switch_count) { | 
