在执行期间访问.eh_frame数据
我正在尝试从其中访问正在运行的程序的.eh_frame
部分的内容(具体来说,该程序是Linux内核2.6.34.8)。 .eh_frame
包含用于exception处理的有用数据,我想在内核代码内部使用它。 该部分已由gcc
编写( readelf -a vmlinux.o
包含.eh_frame
),问题是从代码中读取它。 我很确定精灵格式的文档说在代码执行期间可以访问.eh_frame
。
我查看了glibc
的源代码,以寻找.eh_frame
用法,并在sysdeps/generic/sysdep.h
找到了大多数CFA指令的宏,但没有找到加载.eh_frame
数据的实际代码。
是否需要修改加载内核以从文件加载数据的过程,或者.eh_frame
info / .eh_frame_hdr
段指针存储在某处作为宏/汇编程序名称(因此可以将其提取到C变量中)?
vmlinux.o
不是加载的实际内核。
实际的内核映像(通常是bzImage
)不是ELF文件,只包含运行内核所需的数据。
此外,大多数内核不会使用exception处理信息进行编译。