运行"Hello World" Linux 模块时出现问题



我正试图编译并运行《Linux设备驱动程序》一书中的"Hello World"模块我试图编译的程序~/ldd3/hello.c是:

/*                                                     
* $Id: hello.c,v 1.5 2004/10/26 03:32:21 corbet Exp $ 
*/                                                    
#include <linux/init.h>
#include <linux/module.h>
MODULE_LICENSE("Dual BSD/GPL");
static int hello_init(void)
{
printk(KERN_ALERT "Hello, worldn");
return 0;
}
static void hello_exit(void)
{
printk(KERN_ALERT "Goodbye, cruel worldn");
}
module_init(hello_init);
module_exit(hello_exit);

Makefile是:

obj-m += hello.o
all:
make -C /lib/modules/$(shell uname -r)/build M=$(PWD) modules
clean:
make -C /lib/modules/$(shell uname -r)/build M=$(PWD) clean

当我运行make时,编译似乎还可以:

root@deb:/home/deb/ldd3# make
make -C /lib/modules/4.14.86/build M=/home/deb/ldd3 modules
make[1]: Entering directory '/home/deb/src/linux-4.14.86'
Building modules, stage 2.
MODPOST 1 modules
make[1]: Leaving directory '/home/deb/src/linux-4.14.86'

但当我跑步时:

root@deb:/home/deb/ldd3# insmod ./hello.ko
root@deb:/home/deb/ldd3#

"Hello World"消息不会打印出来。运行时也不会打印消息

rmmod hello

你能告诉我为什么吗?感谢

为了查看内核消息,可以使用dmesg。或者,您可以查看系统日志tail var/log/syslog

相关内容

  • 没有找到相关文章

最新更新