运行“Hello World”linux模块时出现问题

loading...


0

我正在尝试编译并运行“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, world\n");
    return 0;
}

static void hello_exit(void)
{
    printk(KERN_ALERT "Goodbye, cruel world\n");
}

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

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

loading...

1回答

  • 0

    要查看内核消息,可以使用 dmesg . 或者,您可以看到syslog tail var/log/syslog .

评论

暂时没有评论!