内核中通过/proc/kallsyms获得符号的地址--全局变量snd_write_bypass

版权声明:本文为博主原创文章,未经博主允许不得转载。文章转载只能用于非商业性质,且不能带有虚拟货币、积分等附加条件;转载必须注明出处。 https://blog.csdn.net/xushx_bigbear/article/details/49764199

在内核中通过/proc/kallsyms获得符号的地址

 

Linux内核符号表/proc/kallsyms的形成过程
---------------------------------------------------------------------------

./scripts/kallsyms.c负责生成System.map
./kernel/kallsyms.c负责生成/proc/kallsyms

./scripts/kallsyms.c解析vmlinux(.tmp_vmlinux)生成kallsyms.S(.tmp_kallsyms.S),然后内核编译过程中将kallsyms.S(内核符号表)编入内核镜像uImage

内核启动后./kernel/kallsyms.c解析uImage形成/proc/kallsyms


/proc/kallsyms包含了内核中的函数符号(包括没有EXPORT_SYMBOL)、全局变量(用EXPORT_SYMBOL导出的全局变量)


为了更好地调试内核,引入了kallsyms。kallsyms抽取了内核用到的所有函数地址(全局的、静态的)和非栈数据变量地址,生成一个数据块,作为只读数据链接进kernel image,相当于内核中存了一个System.map。需要配置CONFIG_KALLSYMS

.config
CONFIG_KALLSYMS=y
CONFIG_KALLSYMS_ALL=y 符号表中包括所有的变量(包括没有用EXPORT_SYMBOL导出的变量)
CONFIG_KALLSYMS_EXTRA_PASS=y


make menuconfig
General setup  --->  
    [*] Configure standard kernel features (for small systems)  --->
        [*]   Load all symbols for debugging/ksymoops
        [*]     Include all symbols in kallsyms
        [*]     Do an extra kallsyms pass  

 

注: 配置CONFIG_KALLSYMS_ALL之后,就不需要修改all_symbol静态变量为1了


/dav/test #  cat /proc/kallsyms | grep snd_write_bypass
805330a0 r __ksymtab_snd_write_bypass
8054504d r __kstrtab_snd_write_bypass
8086e068 B snd_write_bypass


int snd_write_bypass = 0;
EXPORT_SYMBOL_GPL(snd_write_bypass);



[ 1858.449705] hello.ko,Hello, World - this is the kernel speaking
[ 1858.468448] current hello module usecount=10
[ 1858.476576] snd_write_bypass a=0x8086e068 v=0/dav/test # 
/dav/test # 
/dav/test # cat /proc/kallsyms | grep snd_write_bypass
805330a0 r __ksymtab_snd_write_bypass
8054504d r __kstrtab_snd_write_bypass
8086e068 B snd_write_bypass



阅读更多
想对作者说点什么?

博主推荐

换一批

没有更多推荐了,返回首页