goingstudy 发表于 2014-05-23 17:11

start_info_page: Unknown symbol _text (err 0)

一个内核模块编译时有个warning,可以生成模块,但是加载时不能加载,出错:
start_info_page: Unknown symbol _text (err 0)

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

extern int _text;

static int start_info_page_init(void)
{
        struct xenstore_domain_interface * xenstore;
        printk(KERN_DEBUG "start_info_page_address: %p\n", xen_start_info);
//        printk(KERN_DEBUG "pseudo_physical_memory: %lu\n", machine_to_phys_mapping);
        xenstore = (struct xenstore_domain_interface *)((machine_to_phys_mapping << 12) + ((unsigned long) &_text));
        printk(KERN_DEBUG "xen store mfn: %p\n", xenstore);
        return 0;
}

static void start_info_page_exit(void)
{
        printk(KERN_DEBUG "exit\n");
}

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

humjb_1983 发表于 2014-05-23 19:52

_text在哪定义的?

goingstudy 发表于 2014-05-23 19:54

回复 2# humjb_1983
在内核的链接脚本里头吧

   

goingstudy 发表于 2014-05-23 19:55

忘了说了,上面的是在Xen中的dom0做的

Tinnal 发表于 2014-05-23 20:09

_text都没有导出,肯定不行呀。你能用的方式有:
1. 把你的KO编译进内核。
2. 在内核里通过EXPORT_SYMBOL_GPL把_text符号导出来。
3. 通过kallsyms_lookup_name从内核里头把符号地址取出来。

OVER

goingstudy 发表于 2014-05-23 20:51

回复 5# Tinnal
但是_text这个符号我在System.map中可以找到啊,Systme.map中有的符号不是都已经导出了吗?

   

Tinnal 发表于 2014-05-23 21:52

Systme.map是了GCC导出的所有符号(包括局部的符号,类型为t;和全局的符号T,类型为T),全局符号可以被其它.o文件引用,由链接器ld进行链接。KO的链接不是由ld程序做的,而是内核里头的链接器去链接的。内核里的模块链接器只认EXPORT_SYMBOL_XX的符号,我们称为导出的符号。

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

Tinnal 发表于 2014-05-23 21:52

Systme.map是了GCC导出的所有符号(包括局部的符号,类型为t;和全局的符号T,类型为T),全局符号可以被其它.o文件引用,由链接器ld进行链接。KO的链接不是由ld程序做的,而是内核里头的链接器去链接的。内核里的模块链接器只认EXPORT_SYMBOL_XX的符号,我们称为导出的符号。

你如果想解决问题,请按我给你的建议去做。如果你想搞清楚,就百度一下内核模块的装载过程。
页: [1]
查看完整版本: start_info_page: Unknown symbol _text (err 0)