内核模块编程---符号导出(EXPORT_SYMBOL()) (3)

1、现在有两个内核模块函数分别为:

EXPORT_SYMBOL()作用是,导出本模块函数给“其他模块函数使用”

(1)、calculate.c内核模块

#include <linux/init.h>                                
#include <linux/module.h>                              
MODULE_LICENSE("GPL");                                                                
int add_integar(int a,int b)                                
{                                
return a+b;                             
}                               
int sub_integar(int a,int b)                                
{                                
return a-b;                             
}                            
static int __init sym_init()
{
    return 0;
}
static void __exit sym_exit()
{


}
module_init(sym_init);
module_exit(sym_exit);
/* EXPORT_SYMBOL(add_integar); */
/* EXPORT_SYMBOL(sub_integar); */

(2)、hello.c内核模块

#include <linux/module.h>
#include <linux/init.h>
MODULE_LICENSE("GPL");
MODULE_AUTHOR("David Xie");
MODULE_DESCRIPTION("Hello World Module");
MODULE_ALIAS("a simplest module");
extern int add_integar(int a,int b); 
extern int sub_integar(int a,int b);

static int __init hello_init()
{
    int res = add_integar(1,2);   // “ hello.c内核模块” 引用 “calculate.c内核模块”
    return 0;
}
static void __exit hello_exit()
{
    int res = sub_integar(2,1);  //
}
module_init(hello_init);
module_exit(hello_exit);

说明:使用cat /proc/kallsyms | grep add_integar 查看导出文件

kallsyms文件中“记录所有输出到系统中的函数”,供其他模块调用

2、Makefile 文件如下

ifneq ($(KERNELRELEASE),)
obj-m := hello.o calculate.o
else
KDIR := /lib/modules/2.6.18-53.el5/build
all:
make -C $(KDIR) M=$(PWD) modules
clean:
rm -f *.ko *.o *.mod.o *.mod.c *.symvers

endif

<think>好的,用户想了解 Linux 内核中的 EXPORT_SYMBOL 函数的使用说明和示例。首先,我需要回忆一下相关知识,并结合提供的引用内容来组织回答。 首先,用户提到的引用[1]和[2]已经解释了EXPORT_SYMBOL的基本作用,即导出符号供其他模块使用。需要先介绍它的基本概念和用途,然后说明其工作原理,比如符号表管理和模块加载过程。引用[4]提到宏定义展开和链接脚本,这部分可能需要稍微深入一点,但用户可能更关注用法,所以可以简要提及。 接下来,用户需要使用说明,应该分步骤讲解如何在代码中使用EXPORT_SYMBOL,比如定义函数、导出符号、其他模块声明并使用。同时,要给出示例代码,像引用[1]中的示例,但可能需要更详细,比如两个模块的代码示例,一个导出,一个使用。 注意事项部分需要包括作用域、依赖关系、版本兼容性等,引用[2]和[4]可能有相关内容,比如符号表管理和版本问题。此外,要提到GPL协议的问题,因为内核模块如果使用EXPORT_SYMBOL_GPL的话需要注意许可证兼容性。 然后生成相关问题,要围绕EXPORT_SYMBOL的相关知识点,比如原理、与GPL版本的区别、调试方法、应用场景等。 需要注意的是,回答要符合用户的要求,结构清晰,分点说明,同时正确使用LaTeX格式,比如变量名用$...$包裹,代码块用三个反引号标注语言。另外,引用标识要正确添加到对应的引用内容后面,比如在提到导出符号时引用[1],在原理部分引用[2]和[4]。 最后,检查是否有遗漏的信息,比如是否覆盖了使用步骤、示例、注意事项,以及相关问题是否相关。确保语言口语化,避免使用专业术语过多,保持自然的中文表达。</think>### EXPORT_SYMBOL 函数介绍及用法 #### 1. 核心功能 `EXPORT_SYMBOL` 是 Linux 内核提供的宏,用于将模块中的**函数或变量**导出到内核符号表,使其他内核模块能跨模块调用这些符号[^1]。这是实现模块间动态交互的基础机制。 #### 2. 工作原理 - **符号表管理**:导出符号会被记录在`__ksymtab`段中,形成全局可见的符号表[^4] - **模块依赖**:加载模块时,内核通过符号表解析跨模块调用关系[^2] - **地址绑定**:编译时生成未解析的符号引用,运行时通过符号表完成地址绑定[^4] #### 3. 使用步骤 1. **定义待导出函数** ```c // module_a.c void my_exported_func(void) { printk("Exported function called\n"); } EXPORT_SYMBOL(my_exported_func); // 关键导出语句 ``` 2. **外部模块调用** ```c // module_b.c extern void my_exported_func(void); // 声明外部符号 static int __init mod_init(void) { my_exported_func(); // 跨模块调用 return 0; } ``` #### 4. 完整示例 **导出模块 (export_demo.c):** ```c #include <linux/init.h> #include <linux/module.h> int shared_var = 100; EXPORT_SYMBOL(shared_var); // 导出变量 void demo_func(void) { printk(KERN_INFO "Demo function executed\n"); } EXPORT_SYMBOL(demo_func); // 导出函数 MODULE_LICENSE("GPL"); ``` **调用模块 (use_demo.c):** ```c #include <linux/init.h> #include <linux/module.h> extern int shared_var; // 导入变量 extern void demo_func();// 导入函数 static int __init mod_init(void) { printk("Shared value: %d\n", shared_var); demo_func(); return 0; } module_init(mod_init); MODULE_LICENSE("GPL"); ``` #### 5. 关键注意事项 1. **符号可见性**:导出符号必须是非静态(non-static)的 2. **依赖顺序**:被调用模块需要先于调用模块加载 3. **版本控制**:使用`EXPORT_SYMBOL_GPL`限制仅GPL兼容模块可用[^4] 4. **命名冲突**:避免与内核已有符号重名 5. **内存安全**:确保导出符号的生命周期覆盖所有调用者 #### 6. 调试技巧 - 查看符号表:`cat /proc/kallsyms | grep <symbol>` - 模块依赖检查:`modinfo <module_name>` - 动态加载测试:`insmod`/`rmmod`顺序验证
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值