通过在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");
}
}
sysctl_hung_task_panic
最新推荐文章于 2024-09-01 13:51:51 发布