02-内核模块签名问题解决方法

问题描述:
动态安装模块的时候出现insmod error required key not available,内核签名问题

解决方法:
在顶层配置里面关闭内核签名的功能
kernel/msm-3.18/arch/arm64/configs/msmcortex_defconfig 调试版本
kernel/msm-3.18/arch/arm64/configs/msmcortex-perf_defconfig     非调试版本

将这两个文件里面的下面三个配置参数关闭
CONFIG_MODULE_SIG=n
CONFIG_MODULE_SIG_FORCE=n
CONFIG_MODULE_SIG_SHA512=n

然后重新编译内核,adb和fastboot更新boot.img,就可以进行动态安装模块了。
  • 1
    点赞
  • 14
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
Linux 动态加载内核模块(Kernel Module)是一种先进的模块化技术,它允许开发者在运行时将新的代码添加到内核中,而无需重新启动系统。这种机制主要涉及以下几个关键步骤和运行原理: 1. **模块加载**: - 用户空间程序通过`insmod`或`modprobe`命令将模块的加载请求传递给内核- 内核加载器`ld-linux.so`(或在64位系统中为`ld-so.2`)处理这些请求,它会检查模块签名并确保其来源可信。 - 加载器将模块映射到内存,初始化模块的入口点,并执行初始化函数(如`module_init()`)。 2. **模块的符号表**: - 内核模块包含一个符号表,包含了模块中导出的函数、数据结构等接口,这样其他内核组件可以通过名称调用它们。 - 加载时,加载器会确保符号表与实际代码匹配,并设置适当的权限。 3. **模块的动态链接**: - 内核模块通常是用位置无关代码(Position Independent Code, PIC)编译的,这样它们可以被加载到任意内存地址。 - 加载器根据需要调整模块的符号引用,使之指向正确的内核地址空间。 4. **模块的运行和交互**: - 加载后,模块可以与其他内核模块或用户空间进程进行交互,提供服务或修改内核功能。 -模块不再需要时,调用`rmmod`或`kmodunload`命令可以卸载模块,执行相应的清理操作(如`module_exit()`)。 5. **模块的生命周期管理**: - 模块在被加载和卸载时,都有特定的钩子函数(如`module_init()`、`module_exit()`、`sys_initcall()`等)执行特定任务。 - 使用`sysfs`文件系统,内核提供了对模块状态的监控和控制,允许用户查看加载状态和调试信息。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值