本文共 855 字,大约阅读时间需要 2 分钟。
通过在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 中就会触发callstackstatic 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"); }}
转载地址:http://binmi.baihongyu.com/