Phi*_*rry 4 linux logs kernel dmesg
我创建了一个基本的 Linux 内核模块,它执行以下操作:
static __init int init(void)
{
printk(KERN_DEBUG "Banana");
return 0;
}
Run Code Online (Sandbox Code Playgroud)
而且当然:
module_init(init);
Run Code Online (Sandbox Code Playgroud)
奇怪的是,我通过插入模块后找不到字符串“Banana”
insmod banana_module.ko
Run Code Online (Sandbox Code Playgroud)
命令
dmesg -k | grep Banana
Run Code Online (Sandbox Code Playgroud)
不返回任何内容。
但是,当我卸下模块并再次插入时,我可以找到它。然后我找到了两根香蕉,一根是之前的,一根是当前插入的。这是由于冲洗问题吗?我觉得这种行为有点奇怪,在互联网上找不到类似的问题。
顺便说一句,这种情况发生在我的台式机和笔记本电脑上的虚拟机(没有虚拟机)上。
那么,为什么内核不喜欢香蕉呢?
我已经弄清楚问题出在哪里:
我没有在内核消息末尾指定结束符 \n 。如果您忽略它,它的行为就像上面描述的那样。原因是,内核消息被视为仅在完成时才打印出来的记录。有关更多信息,请参阅这篇有关 printk 问题的文章
| 归档时间: |
|
| 查看次数: |
1577 次 |
| 最近记录: |