export_symbol
linux2.6的“/proc/kallsyms”文件对应着内核符号表,记录了符号以及符号所在的内存地址。
模块可以使用如下宏导出符号到内核符号表:
[c-sharp] view plaincopy
导出的符号可以被其他模块使用,不过使用之前一定要声明一下。EXPORT_SYMBOL_GPL()只适用于包含GPL许可权的模块。
代码演示:
[c-sharp] view plaincopy
- //hello.c文件,定义2个函数,用于导出
- #include <linux/init.h>
- #include <linux/module.h>
- MODULE_LICENSE("Dual BSD/GPL");
- int add_integar(int a,int b)
- {
- return a + b;
- }
- int sub_integar(int a,int b)
- {
- return a - b;
- }
- EXPORT_SYMBOL(add_integar);
- EXPORT_SYMBOL(sub_integar);
- //test.c 用于调用hello模块导出的函数
- #include <linux/init.h>
- #include <linux/module.h>
- MODULE_LICENSE("Dual BSD/GPL");
- extern int add_integar(int ,int); //声明要调用的函数
- extern int sub_integar(int ,int); //声明要调用的函数
- int result(void)
- {
- int a,b;
- a = add_integar(1,1);
- b = sub_integar(1,1);
- printk("%d/n",a);
- printk("%d/n",b);
- return 0;
- }
make后,先加在hello模块,再加载test模块。
然后cat /proc/kallsyms | grep integer
显示:
[c-sharp] view plaincopy
- [root@localhost test]# cat /proc/kallsyms |grep integar
- e053d000 u add_integar [test]
- e053d004 u sub_integar [test]
- e053d02c r __ksymtab_sub_integar [hello]
- e053d03c r __kstrtab_sub_integar [hello]
- e053d034 r __ksymtab_add_integar [hello]
- e053d048 r __kstrtab_add_integar [hello]
- e053d000 T add_integar [hello]
# lsmod
Module Size Used by Not tainted
# insmod hello.ko
# insmod test.ko
# cat /proc/kallsyms |grep integar
bf000014 u sub_integar [test]
bf000000 u add_integar [test]
bf000028 r __ksymtab_sub_integar [hello]
bf000038 r __kstrtab_sub_integar [hello]
bf000030 r __ksymtab_add_integar [hello]
bf000044 r __kstrtab_add_integar [hello]
bf000014 T sub_integar [hello]
bf000000 T add_integar [hello]
#
相关阅读
从零开始之驱动发开、linux驱动(三十五、利用EXPORT_SY
Linux内核头文件提供了一个方便的方法用来管理符号的对模块外部的可见性,因此减少了命名空间的污染(命名空间的名称可能会与内核
EXPORT_SYMBOL只出现在2.6内核中,在2.4内核默认的非static 函数和变量都会自动导入到kernel 空间的, 都不用EXPORT_SYMBOL() 做标记