我的老师给了我一个linux内核vmlinuz-3.17.2和一个rootfs.ext2,可以加载到qemu。他要我构建一个最简单的内核模块,打印一个hello world作为家庭作业。
但是,我无法在dmesg或/ var / log / messages中看到任何内容 有什么不对的吗?我怎么能这样做? 当我成功运行rmmod hello.ko时,也无需打印任何内容。
我的日志级别为7 4 1 7
我按照以下方式制作了hello.c:
#include <linux/init.h>
#include <linux/module.h>
static int __init hello_init(void)
{
pr_info("Hello World");
return -1;
// I changed this to -1 deliberately, Because It seems that the code is not executed.
}
static void __exit hello_exit(void)
{
printk(KERN_ERR "Goodbye, cruel world\n");
}
MODULE_LICENSE("GPL");
module_init(hello_init);
module_exit(hello_exit);
答案 0 :(得分:2)
<强> Buildroot里面强>
Buildroot是最简单的方法:
在Ubuntu 16.04上测试。