当在传递给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
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