0

所以,我试图安装一个 hello world 内核,展示了 Corbet, Jonathan 所著的“Linux Device Drivers”一书。

这是文件 hello.c 的代码

#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 "Good Bye Module!!\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 all
sudo insmod ./hello.ko

我有错误

ERROR: could not insert module Operation not permitted

以 root 权限安装内核空间模块。也试过

sudo su
sudo insmod ./hello.ko

也试过

sudo modprove -v hello.ko

有类似的错误。

4

1 回答 1

1

因此,发生了几件事,主要问题是您的计算机(通常是笔记本电脑)secure boot在 BIOS 中启用了该选项。

这通常可以解决问题,但是在某些笔记本电脑中,该选项不会出现(或被禁用),直到您为 bios 设置管理密码。

如果将secure boot选项更改为disabled有时是不够的。在一些较新的英特尔笔记本电脑中,您还需要从 BIOS禁用英特尔平台信任技术。

最后,您可以毫无问题地运行 insmod 或 modprobe。

要检查printk(KERN_ALERT "Hello World!!\n");你需要做的输出

tail -f /var/log/kern.log

那应该行得通。

于 2020-08-17T10:41:13.637 回答