diff options
Diffstat (limited to 'kernel/hung_task.c')
| -rw-r--r-- | kernel/hung_task.c | 17 | 
1 files changed, 16 insertions, 1 deletions
diff --git a/kernel/hung_task.c b/kernel/hung_task.c index 3e97fb126e6b..9328b80eaf14 100644 --- a/kernel/hung_task.c +++ b/kernel/hung_task.c @@ -16,11 +16,12 @@  #include <linux/export.h>  #include <linux/sysctl.h>  #include <linux/utsname.h> +#include <trace/events/sched.h>  /*   * The number of tasks checked:   */ -unsigned long __read_mostly sysctl_hung_task_check_count = PID_MAX_LIMIT; +int __read_mostly sysctl_hung_task_check_count = PID_MAX_LIMIT;  /*   * Limit number of tasks checked in a batch. @@ -92,6 +93,9 @@ static void check_hung_task(struct task_struct *t, unsigned long timeout)  		t->last_switch_count = switch_count;  		return;  	} + +	trace_sched_process_hang(t); +  	if (!sysctl_hung_task_warnings)  		return;  	sysctl_hung_task_warnings--; @@ -203,6 +207,14 @@ int proc_dohung_task_timeout_secs(struct ctl_table *table, int write,  	return ret;  } +static atomic_t reset_hung_task = ATOMIC_INIT(0); + +void reset_hung_task_detector(void) +{ +	atomic_set(&reset_hung_task, 1); +} +EXPORT_SYMBOL_GPL(reset_hung_task_detector); +  /*   * kthread which checks for tasks stuck in D state   */ @@ -216,6 +228,9 @@ static int watchdog(void *dummy)  		while (schedule_timeout_interruptible(timeout_jiffies(timeout)))  			timeout = sysctl_hung_task_timeout_secs; +		if (atomic_xchg(&reset_hung_task, 0)) +			continue; +  		check_hung_uninterruptible_tasks(timeout);  	}  | 
