【Linux内核】Ubuntu下printk函数无法在终端显示

在Ubuntu下使用insmod安装模块的时候,发现预设的调试信息并没有输出,但是使用dmesg命令可以看到在日志中确实有调试信息,下面分析一下可能的情况。

printk信息的输出去向

这是在内核的命令行参数console=ttyXXX里指定死了,比如console=tty1表示printk的信息输出到终端1。如果是这种情况,你需要使用Ctrl+Alt+(F1-F6)来切换终端。

日志输出级别过低

用printk,内核会根据日志级别,可能把消息打印到当前控制台上,这个控制台通常是一个字符模式的终端、一个串口打印机或是一个并口打印机。这些消息正常输出的前提是──日志输出级别高于console_loglevel(在内核中数字越小优先级越高)。

日志级别一共有8个级别,printk的日志级别定义如下(在include/linux/kernel.h中):

0 #define KERN_EMERG
1 #define KERN_ALERT
2 #define KERN_CRIT
3 #define KERN_ERR
4 #define KERN_WARNING
5 #define KERN_NOTICE
6 #define KERN_INFO
7 #define KERN_DEBUG

查看当前控制台的打印级别

cat /proc/sys/ker
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值