这是我的基本内核模块代码。
#include <linux/kernel.h>
#include <linux/module.h>
MODULE_LICENSE("GPL");
static int test_bug_init(void)
{
printk(KERN_INFO"%s: In init\n", __func__);
BUG();
return 0;
}
static void test_bug_exit(void)
{
printk(KERN_INFO"%s: In exit\n", __func__);
}
module_init(test_bug_init);
module_exit(test_bug_exit);
当我加载此模块时,它已成功加载,但是在卸载时会收到诸如“模块正在使用”之类的消息。
那么,为什么我们在BUG()
调用之后不能卸载模块?还有其他卸载模块的方法吗?
答案 0 :(得分:3)
在内核源代码中,您可以看到BUG()
代码最终会调用unreachable()
宏:
# define unreachable() do { } while (1)
由于其中存在无限循环,因此正在使用初始化函数test_bug_init()
-无法返回。通过添加类似的内容来验证这一点
//...
BUG();
printk(KERN_INFO "%s: After BUG()\n", __func__);
因此您不会在日志中看到此打印内容。
另请参阅:BUG() FAQ
还有另一种卸载模块的方法吗?
您不能卸载它,因为它正在“使用中”,并且您不能以某种方式使其不使用(无法停止使用)。只需重启即可。