关于EXPORT_SYMBOL

本文介绍如何在Linux内核2.6中使用EXPORT_SYMBOL宏导出模块函数,并通过示例展示如何在一个模块中导出函数供其他模块使用。

linux2.6的“/prob/kallsyms”文件对应着内核符号表,记录了符号以及符号所在的内存地址。

模块可以使用如下宏导出符号到内核符号表:

[c-sharp]  view plain copy
  1. EXPORT_SYMBOL(符号名);  
  2. EXPORT_SYMBOL_GPL(符号名)  

导出的符号可以被其他模块使用,不过使用之前一定要声明一下。EXPORT_SYMBOL_GPL()只适用于包含GPL许可权的模块。

 

代码演示:

[c-sharp]  view plain copy
  1. //hello.c文件,定义2个函数,用于导出  
  2. #include <linux/init.h>  
  3. #include <linux/module.h>  
  4. MODULE_LICENSE("Dual BSD/GPL");  
  5. int add_integar(int a,int b)  
  6. {  
  7.     return a + b;  
  8. }  
  9. int sub_integar(int a,int b)  
  10. {  
  11.     return a - b;  
  12. }  
  13. EXPORT_SYMBOL(add_integar);  
  14. EXPORT_SYMBOL(sub_integar);  
  15. //test.c 用于调用hello模块导出的函数  
  16. #include <linux/init.h>  
  17. #include <linux/module.h>  
  18. MODULE_LICENSE("Dual BSD/GPL");  
  19. extern int add_integar(int ,int); //声明要调用的函数  
  20. extern int sub_integar(int ,int); //声明要调用的函数  
  21. int result(void)  
  22. {  
  23.     int a,b;  
  24.     a = add_integar(1,1);  
  25.     b = sub_integar(1,1);  
  26.       
  27.     printk("%d/n",a);  
  28.     printk("%d/n",b);  
  29.       
  30.     return 0;  
  31. }  

 

make后,先加在hello模块,再加载test模块。

然后cat /proc/kallsyms | grep integer

显示:

[c-sharp]  view plain copy
  1. [root@localhost test]# cat /proc/kallsyms |grep integar  
  2. e053d000 u add_integar  [test]  
  3. e053d004 u sub_integar  [test]  
  4. e053d02c r __ksymtab_sub_integar        [hello]  
  5. e053d03c r __kstrtab_sub_integar        [hello]  
  6. e053d034 r __ksymtab_add_integar        [hello]  
  7. e053d048 r __kstrtab_add_integar        [hello]  
  8. e053d000 T add_integar  [hello]  
  9. e053d004 T sub_integar  [hello]  

在Linux内核模块开发中,`EXPORT_SYMBOL` 和 `EXPORT_SYMBOL_GPL` 是用于将函数或变量符号导出给其他模块使用的宏。它们的主要区别在于使用权限和适用范围。 ### 1. 功能与可见性 - `EXPORT_SYMBOL` 将符号导出为全局可见,允许任何内核模块(无论其许可证是否为GPL)访问该符号。这意味着即使非GPL许可的模块也可以调用这些符号[^3]。 - `EXPORT_SYMBOL_GPL` 则仅将符号导出给那些声明自己为GPL兼容许可证的模块使用。如果一个非GPL模块尝试使用这些符号,加载时会报错,提示许可证不匹配问题。这是为了确保某些特定功能只能被遵循GPL协议的模块使用,从而保护代码的开源性质[^3]。 ### 2. 安全性与合规性 - 使用 `EXPORT_SYMBOL_GPL` 可以提高系统的安全性与合规性,因为它限制了只有符合GPL协议的模块才能访问某些关键接口。这有助于防止闭源驱动程序或其他非自由软件利用这些功能。 - 相比之下,`EXPORT_SYMBOL` 更加开放,但也因此可能带来一定的安全风险或违反开源协议的风险。 ### 3. 内核版本支持 - `EXPORT_SYMBOL_GPL` 在较新的内核版本中得到了更好的支持,并且是推荐的做法,特别是在涉及核心内核功能或需要维护GPL合规性的场景下。 - `EXPORT_SYMBOL` 自早期内核版本就已存在,广泛用于传统的符号导出需求。 ### 示例代码 以下是一个简单的示例,展示如何使用这两个宏: ```c #include <linux/module.h> #include <linux/kernel.h> void my_function(void) { printk(KERN_INFO "Hello from my_function!\n"); } EXPORT_SYMBOL(my_function); // 允许所有模块访问 void my_gpl_function(void) { printk(KERN_INFO "Hello from my_gpl_function!\n"); } EXPORT_SYMBOL_GPL(my_gpl_function); // 仅允许GPL模块访问 ``` ### 4. 总结 选择 `EXPORT_SYMBOL` 还是 `EXPORT_SYMBOL_GPL` 应根据具体需求决定。如果希望符号对所有模块开放,则使用 `EXPORT_SYMBOL`;如果希望限制符号仅对GPL模块开放,则使用 `EXPORT_SYMBOL_GPL`。 ---
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值