news 2026/3/20 10:54:51

内核模块符号的导出

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
内核模块符号的导出
grep -rn "EXPORT_SYMBOL"

搜索EXPORT_SYSMBOL这个宏

这一节讲的是 **“内核模块之间如何共享函数 / 变量” 的核心机制 **,可以拆解为 3 个关键部分理解:

1. 为什么需要 “内核模块符号导出”?

内核模块编译后是独立的.ko文件,默认情况下:

  • 模块 A 里的函数 / 变量,模块 B 是 “看不见” 的,没法直接调用;
  • 但复杂驱动需要分层(比如把 “硬件控制” 和 “业务逻辑” 拆成两个模块),这时候就需要让模块 A 把自己的函数 / 变量 “暴露出来”,供模块 B 调用 —— 这个 “暴露” 的操作,就是 “符号导出”。

2. 什么是 “内核模块符号导出”?

简单说:在模块里,用特定宏把函数 / 变量标记为 “公共可用”,当这个模块加载到内核时,这些函数 / 变量会被记录到内核公共符号表里,其他模块加载时就能从这个表中找到并调用它们。

3. 具体怎么实现(用到的工具)?

这一节里提到的两个宏,就是实现符号导出的核心:

作用
EXPORT_SYMBOL(sym)导出符号(函数 / 变量,sym是要导出的名字),所有内核模块都能调用
EXPORT_SYMBOL_GPL(sym)仅允许遵循 GPL 协议的内核模块调用(因为 Linux 内核是 GPL 协议的)

4. 额外注意点

  • 头文件不用单独引:这两个宏定义在include/linux/export.h里,但内核模块的常用头文件module.h已经包含了export.h,所以写模块代码时,只要包含了#include <linux/module.h>,就可以直接用这两个宏。
  • 符号表的记录:导出的符号会被记录到内核的Module.symvers文件中(之前提到的那个文件),其他模块编译时需要依赖这个文件,才能找到导出的符号。

举个简单例子(帮助理解)

比如你写了两个模块:

  • 模块 A(导出方)

    c

    #include <linux/module.h> // 定义一个要导出的函数 void my_shared_func(void) { printk("这是模块A导出的函数\n"); } // 导出这个函数,供其他模块调用 EXPORT_SYMBOL(my_shared_func); // 模块加载/卸载函数(省略) module_init(xxx_init); module_exit(xxx_exit); MODULE_LICENSE("GPL");
  • 模块 B(调用方)

    c

    #include <linux/module.h> // 声明要调用的、模块A导出的函数 extern void my_shared_func(void); static int __init b_init(void) { my_shared_func(); // 直接调用模块A导出的函数 return 0; } module_init(b_init); MODULE_LICENSE("GPL");

当模块 A 先加载到内核,模块 B 再加载时,就能成功调用my_shared_func—— 这就是符号导出的实际作用。

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/3/16 2:53:45

Python爬虫实战:利用最新技术从交易所API爬取比特币/加密货币价格与交易数据

引言 在数字货币的浪潮中,获取实时、准确的加密货币数据对于投资者、分析师和开发者至关重要。本文将详细介绍如何使用Python爬虫技术从各大交易所API获取比特币及其他加密货币的价格与交易数据,并进行基本的行情分析。我们将使用最新的Python库和技术栈,包括异步请求、数据…

作者头像 李华
网站建设 2026/3/15 20:54:30

电影推荐系统架构图](https://fakeimg.pl/600x200/ff0000/000?text=SystemArchitecture

hadoop电影推荐系统 大数据电影推荐系统源码 技术栈:javaspringbootlayuihadoop 数据集:豆瓣电影 推荐思路:用户注册登录后浏览电影&#xff0c;对电影进行评分&#xff0c;算法模块定时执行&#xff0c;从mysql读取数据上传到hdfs&#xff0c;并通过执行mapreduce实现的基于用…

作者头像 李华
网站建设 2026/3/15 2:36:43

Kubernetes 环境 NFS 卡死问题排查与解决纪要

Kubernetes 环境 NFS 卡死问题排查与解决纪要 一、事件背景 在 Kubernetes 集群运行过程中&#xff0c;xxxx 命名空间内多个业务 Pod 出现启动异常&#xff0c;部分 Pod 长时间处于 CreateContainerError 或 ContainerCreating 状态&#xff0c;重建 Pod、重启业务均无法恢复。…

作者头像 李华