sysctl_hung_task_panic

通过在grub中添加参数hung_task_panic=1,可以在进程stuck的时候dump当前所有cpu的stack
其源码分析如下:
__setup("hung_task_panic=", hung_task_panic_setup);
static int __init hung_task_panic_setup(char *str)
{
	int rc = kstrtouint(str, 0, &sysctl_hung_task_panic);

	if (rc)
		return rc;
	return 1;
}
添加这个参数后事实上就是让sysctl_hung_task_panic等于1,这样在cpu hang检测的check_hung_task 中就会触发callstack
static void check_hung_task(struct task_struct *t, unsigned long timeout)
{
	unsigned long switch_count = t->nvcsw + t->nivcsw;

	#正常情况下sysctl_hung_task_warnings  等于10,如果sysctl_hung_task_panic等于零的话,这个函数就返回了

	if (!sysctl_hung_task_warnings && !sysctl_hung_task_panic)
		return;
	#相反如果设置了sysctl_hung_task_panic的话,则下面这个if条件会成立,最终会调用trigger_all_cpu_backtrace来打印所有cpu上的callstack

	if (sysctl_hung_task_panic) {
		if (hung_task_show_lock)
			debug_show_all_locks();
		trigger_all_cpu_backtrace();
		panic("hung_task: blocked tasks");
	}
}

你可能感兴趣的:(Linux,源码分析)