转自:http://www.myexception.cn/h/704185.html linux模块加载出现问题,printk打印信息,终端里看不到 #include <linux/kernel.h> #include <linux/init.h> #include <linux/module.h> MODULE_AUTHOR("xiao yehua"); MODULE_LICENSE("GPL"); static int __init hello_init(void) { printk(KERN_DEBUG "hello world enter!\n"); return 0; } static void __exit hello_exit(void) { printk(KERN_INFO "hello world exit!\n"); } module_init(hello_init); module_exit(hello_exit); //-------------Makefile-------------------- obj-m := hello.o KDIR := /lib/modules/2.6.18-128.el5/build PWD := $(shell pwd) default: make -C $(KDIR) M=$(PWD) modules 刚开始学驱动模块,编译.ko文件正常, 但加载模块到内核时没有信息打印到 终端上面, 用lsmod查看,确实有hello模块 不知道为什么无法打印(printk)信息?? ------解决方案-------------------------------------------------------- printk 打印信息有7个等级,等级越小的,打印可能越大。你这里的KERN_DEBUG 就是等级说明。 printk(KERN_DEBUG "hello world enter!\n"); 你可你试一下 printk(KERN_ALERT "Hello,world\n"); 这个我用过可以在终端显示 ------解决方案-------------------------------------------------------- 这是虚拟机的通病。你可以开一个终端,在终端上输入: [root@xxxxx]#while true > do > cat /proc/kmsg > sleep 1 > done 这样你的终端就相当于一个串口终端了,你可以在这里察看你的打印信息