免费注册 查看新帖 |

Chinaunix

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

[内核模块] start_info_page: Unknown symbol _text (err 0) [复制链接]

论坛徽章:
1
IT运维版块每日发帖之星
日期:2015-12-20 06:20:00
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2014-05-23 17:11 |只看该作者 |倒序浏览
一个内核模块编译时有个warning,可以生成模块,但是加载时不能加载,出错:
start_info_page: Unknown symbol _text (err 0)

代码如下,很简单:
  1. #include <linux/kernel.h>
  2. #include <linux/module.h>
  3. #include <xen/page.h>

  4. extern int _text;

  5. static int start_info_page_init(void)
  6. {
  7.         struct xenstore_domain_interface * xenstore;
  8.         printk(KERN_DEBUG "start_info_page_address: %p\n", xen_start_info);
  9. //        printk(KERN_DEBUG "pseudo_physical_memory: %lu\n", machine_to_phys_mapping[xen_start_info->store_mfn]);
  10.         xenstore = (struct xenstore_domain_interface *)((machine_to_phys_mapping[xen_start_info->store_mfn] << 12) + ((unsigned long) &_text));
  11.         printk(KERN_DEBUG "xen store mfn: %p\n", xenstore);
  12.         return 0;
  13. }

  14. static void start_info_page_exit(void)
  15. {
  16.         printk(KERN_DEBUG "exit\n");
  17. }

  18. module_init(start_info_page_init);
  19. module_exit(start_info_page_exit);
  20. MODULE_LICENSE("GPL");
复制代码
_text这个符号我在System.map中能够找的到,请问还有可能是哪个地方的问题?

论坛徽章:
15
射手座
日期:2014-02-26 13:45:082015年迎新春徽章
日期:2015-03-04 09:54:452015年辞旧岁徽章
日期:2015-03-03 16:54:15羊年新春福章
日期:2015-02-26 08:47:552015年亚洲杯之卡塔尔
日期:2015-02-03 08:33:45射手座
日期:2014-12-31 08:36:51水瓶座
日期:2014-06-04 08:33:52天蝎座
日期:2014-05-14 14:30:41天秤座
日期:2014-04-21 08:37:08处女座
日期:2014-04-18 16:57:05戌狗
日期:2014-04-04 12:21:33技术图书徽章
日期:2014-03-25 09:00:29
2 [报告]
发表于 2014-05-23 19:52 |只看该作者
_text在哪定义的?

论坛徽章:
1
IT运维版块每日发帖之星
日期:2015-12-20 06:20:00
3 [报告]
发表于 2014-05-23 19:54 |只看该作者
回复 2# humjb_1983
在内核的链接脚本里头吧

   

论坛徽章:
1
IT运维版块每日发帖之星
日期:2015-12-20 06:20:00
4 [报告]
发表于 2014-05-23 19:55 |只看该作者
忘了说了,上面的是在Xen中的dom0做的

论坛徽章:
9
辰龙
日期:2014-08-18 20:38:42未羊
日期:2014-09-04 08:50:45丑牛
日期:2014-09-06 00:12:55寅虎
日期:2014-12-22 20:50:56摩羯座
日期:2015-01-14 22:28:15巳蛇
日期:2015-01-23 20:39:272015年辞旧岁徽章
日期:2015-03-03 16:54:1515-16赛季CBA联赛之青岛
日期:2016-03-13 23:37:1915-16赛季CBA联赛之深圳
日期:2016-03-29 18:52:38
5 [报告]
发表于 2014-05-23 20:09 |只看该作者
_text都没有导出,肯定不行呀。你能用的方式有:
1. 把你的KO编译进内核。
2. 在内核里通过EXPORT_SYMBOL_GPL把_text符号导出来。
3. 通过kallsyms_lookup_name从内核里头把符号地址取出来。

OVER

论坛徽章:
1
IT运维版块每日发帖之星
日期:2015-12-20 06:20:00
6 [报告]
发表于 2014-05-23 20:51 |只看该作者
回复 5# Tinnal
但是_text这个符号我在System.map中可以找到啊,Systme.map中有的符号不是都已经导出了吗?

   

论坛徽章:
9
辰龙
日期:2014-08-18 20:38:42未羊
日期:2014-09-04 08:50:45丑牛
日期:2014-09-06 00:12:55寅虎
日期:2014-12-22 20:50:56摩羯座
日期:2015-01-14 22:28:15巳蛇
日期:2015-01-23 20:39:272015年辞旧岁徽章
日期:2015-03-03 16:54:1515-16赛季CBA联赛之青岛
日期:2016-03-13 23:37:1915-16赛季CBA联赛之深圳
日期:2016-03-29 18:52:38
7 [报告]
发表于 2014-05-23 21:52 |只看该作者
Systme.map是了GCC导出的所有符号(包括局部的符号,类型为t;和全局的符号T,类型为T),全局符号可以被其它.o文件引用,由链接器ld进行链接。KO的链接不是由ld程序做的,而是内核里头的链接器去链接的。内核里的模块链接器只认EXPORT_SYMBOL_XX的符号,我们称为导出的符号。

你如果想解决问题,请按我给你的建议去做。如果你想搞清楚,就百度一下内核模块的装载过程。

论坛徽章:
9
辰龙
日期:2014-08-18 20:38:42未羊
日期:2014-09-04 08:50:45丑牛
日期:2014-09-06 00:12:55寅虎
日期:2014-12-22 20:50:56摩羯座
日期:2015-01-14 22:28:15巳蛇
日期:2015-01-23 20:39:272015年辞旧岁徽章
日期:2015-03-03 16:54:1515-16赛季CBA联赛之青岛
日期:2016-03-13 23:37:1915-16赛季CBA联赛之深圳
日期:2016-03-29 18:52:38
8 [报告]
发表于 2014-05-23 21:52 |只看该作者
Systme.map是了GCC导出的所有符号(包括局部的符号,类型为t;和全局的符号T,类型为T),全局符号可以被其它.o文件引用,由链接器ld进行链接。KO的链接不是由ld程序做的,而是内核里头的链接器去链接的。内核里的模块链接器只认EXPORT_SYMBOL_XX的符号,我们称为导出的符号。

你如果想解决问题,请按我给你的建议去做。如果你想搞清楚,就百度一下内核模块的装载过程。
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP