关于export_symbol的信息

http://www.itjxue.com  2023-02-14 08:38  来源:未知  点击次数: 

如何在Linux内核源代码中增加EXPORT_SYMBOL_GPL宏

添加EXPORT_SYMBOL_GPL只是步骤之一,你还需要将func_xxx在头文件中申明,然后#include该头文件才能使用。

linux怎么导出内核中的文件?

linux内核之模块参数及导出符号

1. 模块参数

用 “module_param (参数名,参数类型,参数读 / 写权限) ” 为模块定义一个参数,例如下列代码定义了 1 个整型参数和 1 个字符指针参数:

1 static char *book_name = "dissecting Linux Device Driver";

2 module_param(book_name, charp, S_IRUGO);

3 static int book_num = 4000;

4 module_param(book_num, int, S_IRUGO);

在装载内核模块时,用户可以向模块传递参数,形式为 “insmode 模块名 参数名 = 参数值,如果不传递,参数将使用模块内定义的缺省值。参数类型可以是 byte 、 short 、 ushort 、 int 、 uint 、 long 、 ulong 、 charp (字符指针)、 bool 或 invbool (布尔的反),在模块被编译时会将 module_param 中声明的类型与变量定义的类型进行比较,判断是否一致。模块被加载后,在 /sys/module/ 目录下将出现以此模块名命名的目录。在此模块的目录下还将出现 parameters 目录,其中包含一系列以参数名命名的文件节点,这些文件的权限值就是传入module_param ()的 “参数读 / 写权限” ,而文件的内容为参数的值。

insmod命令加载模块后,通过查看 “/var/log/messages” 日志文件可以看到内核的输出:

# tail -n 2 /var/log/messages

tail -n 2表示输入文件的最后2行

2. 导出符号

Linux 的 “/proc/kallsyms” 文件对应着内核符号表,它记录了符号以及符号所在的内存地址。模块可以使用如下宏导出符号到内核符号表中:

EXPORT_SYMBOL( 符号名 );

EXPORT_SYMBOL_GPL( 符号名 );

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

如果符号名是“e_symbol”,从 “/proc/kallsyms” 文件中找出 e_symbol 的相关信息:

# grep e_symbol /proc/kallsyms

8000af1c t e_symbol [export_symb]

获取Linux内核未导出符号的几种方式

只有在内核中使用EXPORT_SYMBOL或EXPORT_SYMBOL_GPL导出的符号才能在内核模块中直接使用。然而,内核并没有导出所有的符号。例如,在3.8.0的内核中,do_page_fault就没有被导出。 而我的内核模块中需要使用do_page_fault,那么有那些方法呢?这些方法分别有什么优劣呢? 下面以do_page_fault为例,一一进行分析: 修改内核,添加EXPORT_SYMBOL(do_page_fault)或EXPORT_SYMBOL_GPL(do_page_fault)。这种方法适用于可以修改内核的情形。在可以修改内核的情况下,这是最简单的方式。 使用kallsyms_lookup_name读取kallsyms_lookup_name本身也是一个内核符号,如果这个符号被导出了,那么就可以在内核模块中调用kallsyms_lookup_name("do_page_fault")来获得do_page_fault的符号地址。这种方法的局限性在于kallsyms_lookup_name本身不一定被导出。 读取/boot/System.map-,再使用内核模块参数传入内核模块System.map-是编译内核时产生的,它里面记录了编译时内核符号的地址。如果能够保证当前使用的内核与System.map-是一一对应的,那么从System.map-中读出的符号地址就是正确的。其中,kernel-version可以通过'uname -r'获得。但是这种方法也有局限性,在模块运行的时候,System.map-文件不一定存在,即使存在也不能保证与当前内核是正确对应的。 读取/proc/kallsyms,再使用内核模块参数传入内核模块/proc/kallsyms是一个特殊的文件,它并不是存储在磁盘上的文件。这个文件只有被读取的时候,才会由内核产生内容。因为这些内容是内核动态生成的,所以可以保证其中读到的地址是正确的,不会有System.map-的问题。需要注意的是,从内核2.6.37开始,普通用户是没有办法从/proc/kallsyms中读到正确的值。在某些版本中,该文件为空。在较新的版本中,该文件中所有符号的地址均为0(除非/porc/sys/kernel/kptr_restrict 的值被设为0)。但是root用户是可以从/proc/kallsyms中读到正确的值的。好在加载模块也需要root权限,可以在加载模块时用脚本获取符号的地址。

Linux内核模块可以为其它模块提供服务symbols,请问如何查看某模块的symbol,刚学,求大虾们请教!!!!!

模块代码里有 EXPORT_SYMBOL(symbol) //symbol是为其他模块提供的。

你在内核代码里 用 grep -R "EXPORT_SYMBOL" * 就可以看到了

全局变量 与export symbol区别

symbol 意思是交易产品 如: eurusd xauusd

order 意思是订单 如:20121223(这是订单号码 以区别于订单的不同 )

他俩共同表示一个订单产品 (全部的还包括 time. type .price. s/l . t/p .profit. )

(责任编辑:IT教学网)

更多

推荐安全技术文章