suspend通过console debug

来源:互联网 发布:淘宝起什么名字好 编辑:程序博客网 时间:2024/04/28 13:04
当在传递给kernel的cmdline 添加no_console_suspend的时候
static int __init console_suspend_disable(char *str)
{
    console_suspend_enabled = false;
    return 1;
}
__setup("no_console_suspend", console_suspend_disable);
通过上面的code可以看到主要是让console_suspend_enabled = false。这样调用suspend_console的时候就不会
让console_suspended = 1;
void suspend_console(void)
{
    if (!console_suspend_enabled)
        return;
    printk("Suspending console(s) (use no_console_suspend to debug)\n");
    console_lock();
    console_suspended = 1;
    up_console_sem();
}
这样打印的时候调用console_lock的时候就不会在if (console_suspended)的时候返回了。log就可以正常打印出来。
void console_lock(void)
{
    might_sleep();

    down_console_sem();
    if (console_suspended)
        return;
    console_locked = 1;
    console_may_schedule = 1;
}
也就是说通过让console_suspend_enabled = false;可以让console driver不进行suspend操作,从而进行suspend的时候继续打印log来debug
0 0