博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
EXPORT_SYMBOL()
阅读量:4051 次
发布时间:2019-05-25

本文共 1172 字,大约阅读时间需要 3 分钟。

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

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

 

  1. EXPORT_SYMBOL(符号名);  
  2. EXPORT_SYMBOL_GPL(符号名)  

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

代码演示:

 

  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 b;  
  8.  
  9. int sub_integar(int a,int b)  
  10.  
  11.     return 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.     add_integar(1,1);  
  25.     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

显示:

 

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

转载地址:http://blsci.baihongyu.com/

你可能感兴趣的文章
python_time模块
查看>>
python_configparser(解析ini)
查看>>
selenium学习资料
查看>>
<转>文档视图指针互获
查看>>
从mysql中 导出/导入表及数据
查看>>
HQL语句大全(转)
查看>>
几个常用的Javascript字符串处理函数 spilt(),join(),substring()和indexof()
查看>>
javascript传参字符串 与引号的嵌套调用
查看>>
swiper插件的的使用
查看>>
layui插件的使用
查看>>
JS牛客网编译环境的使用
查看>>
9、VUE面经
查看>>
关于进制转换的具体实现代码
查看>>
Golang 数据可视化利器 go-echarts ,实际使用
查看>>
mysql 跨机器查询,使用dblink
查看>>
mysql5.6.34 升级到mysql5.7.32
查看>>
dba 常用查询
查看>>
Oracle 异机恢复
查看>>
Oracle 12C DG 搭建(RAC-RAC/RAC-单机)
查看>>
Truncate 表之恢复
查看>>