免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 2099 | 回复: 4
打印 上一主题 下一主题

[硬件及驱动] 关于__kcrctab section的疑问。。。 [复制链接]

论坛徽章:
4
酉鸡
日期:2014-03-21 23:19:50狮子座
日期:2014-08-01 22:11:40酉鸡
日期:2015-01-10 21:31:442015年辞旧岁徽章
日期:2015-03-03 16:54:15
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2015-08-27 13:55 |只看该作者 |倒序浏览
本帖最后由 chishanmingshen 于 2015-08-27 14:09 编辑

这个section是在哪里填充的?貌似是modpost.c?
谢谢!

论坛徽章:
20
程序设计版块每日发帖之星
日期:2015-08-17 06:20:00程序设计版块每日发帖之星
日期:2016-07-16 06:20:00程序设计版块每日发帖之星
日期:2016-07-18 06:20:00每日论坛发贴之星
日期:2016-07-18 06:20:00黑曼巴
日期:2016-12-26 16:00:3215-16赛季CBA联赛之江苏
日期:2017-06-26 11:05:5615-16赛季CBA联赛之上海
日期:2017-07-21 18:12:5015-16赛季CBA联赛之青岛
日期:2017-09-04 17:32:0515-16赛季CBA联赛之吉林
日期:2018-03-26 10:02:16程序设计版块每日发帖之星
日期:2016-07-15 06:20:0015-16赛季CBA联赛之江苏
日期:2016-07-07 18:37:512015亚冠之萨济拖拉机
日期:2015-08-17 12:21:08
2 [报告]
发表于 2015-08-31 20:53 |只看该作者
应该是的。

参考scripts/mod/modpost.c::handle_modversions

论坛徽章:
4
酉鸡
日期:2014-03-21 23:19:50狮子座
日期:2014-08-01 22:11:40酉鸡
日期:2015-01-10 21:31:442015年辞旧岁徽章
日期:2015-03-03 16:54:15
3 [报告]
发表于 2015-09-01 09:44 |只看该作者
回复 2# nswcfd


    那个函数是填充__versions section的,不是__kcrctab section啊。

论坛徽章:
20
程序设计版块每日发帖之星
日期:2015-08-17 06:20:00程序设计版块每日发帖之星
日期:2016-07-16 06:20:00程序设计版块每日发帖之星
日期:2016-07-18 06:20:00每日论坛发贴之星
日期:2016-07-18 06:20:00黑曼巴
日期:2016-12-26 16:00:3215-16赛季CBA联赛之江苏
日期:2017-06-26 11:05:5615-16赛季CBA联赛之上海
日期:2017-07-21 18:12:5015-16赛季CBA联赛之青岛
日期:2017-09-04 17:32:0515-16赛季CBA联赛之吉林
日期:2018-03-26 10:02:16程序设计版块每日发帖之星
日期:2016-07-15 06:20:0015-16赛季CBA联赛之江苏
日期:2016-07-07 18:37:512015亚冠之萨济拖拉机
日期:2015-08-17 12:21:08
4 [报告]
发表于 2015-09-01 15:34 |只看该作者
本帖最后由 nswcfd 于 2015-09-01 15:37 编辑

对于EXPORT_SYMBOL导出的符号,比如int x, EXPORT_SYMBOL生成以下信息
  1. extern int x;
  2. extern void *__crc_x;                                                   // weak symbol
  3. static const unsigned long __kcrctab_x = &__crc_x;                      // @ __kcrctab
  4. static const char __kstrtab_x[] = "x";                                  // @ __ksymtab_strings
  5. static const struct kernel_symbol __ksymtab_x = { &x, __kstrtab_x };    // @ __ksymtab
复制代码
__kcrctab section的内容(就是__crc_变量的地址),在编译的时候就有了(不过这时候是weak symbol)。
只是__crc_x这些变量还没有被定义,它们是通过scripts/genksyms/genksyms程序生成的。
例如:
$ printf "int x; void y(int i) { }; EXPORT_SYMBOL(x); EXPORT_SYMBOL(y); " | ./genksyms/genksyms
__crc_x = 0xb8a39400 ;
__crc_y = 0xcad00b48 ;

genksyms是作为rule_cc_o_c的一部分,在生成.o的过程中被调用的(scripts/Makefile.build)
  1. #define rule_cc_o_c
  2.         ...
  3.         $(cmd_modversions)
  4.         ..
  5. #enddef
  6. cmd_mod_versions = if objdump -h .tmp_$(@F) | grep -q __ksymtab; \
  7.         then \
  8.                 #see cmd_gensymtypes \
  9.                 cpp -D__GENKSYMS $< | genksyms -a $(ARCH) -r /dev/null > .tmp_$(@F:.o=.ver) \
  10.                 ld -r -o $@ .tmp_$(@F) -T .tmp_$(@F:.o=.ver) \
  11.         fi
复制代码
如果当前模块是xyz.ko,那么$@=xyz.o $<=xyz.c,上述命令就是
  1. #gcc -c -o .tmp_xyz.o xyz.c
  2. if objdump -h .tmp_xyz.o | grep -q __ksysmtab; then
  3.         cpp -D__GENKEYSYMS xyz.c | genksyms -a x86_64 -r /dev/null > .tmp_xyz.ver
  4.         ld -r -o xyz.o .tmp_xyz.o -T .tmp_xyz.ver
  5. fi
复制代码
关键一步是最后的ld,把weak symbol转换为abs value。

论坛徽章:
4
酉鸡
日期:2014-03-21 23:19:50狮子座
日期:2014-08-01 22:11:40酉鸡
日期:2015-01-10 21:31:442015年辞旧岁徽章
日期:2015-03-03 16:54:15
5 [报告]
发表于 2015-09-05 22:40 |只看该作者
回复 4# nswcfd

谢谢!确实如此!

看来还是得好好搞清楚kernel makefile。。。
   
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP