作者leolarrel (真.粽子无双)
看板LinuxDev
标题Re: [问题] "undefined reference to func"
时间Wed Feb 17 11:53:42 2016
※ 引述《wayne8145 (wayne)》之铭言:
: 小弟Linux kernel新手
: 一个loadable module code中的function称为A
: 另一个linux kernel的source code称为B
: 目前的问题是我需要让B呼叫A
: 在B中include A 的header档,在link time发生如题的错误讯息(compile time没错!)
: ----------------
: 因为B与memory management相关
: 故无法将B compile成loadable module
: 因此无法透过module.symvers方式让B reference到A
: 请问有什麽方式能解决此问题呢?
: 若无法了解题意请告知,小弟能叙述更详细,谢谢
stackfollow的解法,就类似C++的虚拟类别or java的Interface押,其主体精神就是
虚拟函式,实作面采用"函式指标"变数这个技巧来完成
在C里面,你先定义一个"函式指标"变数,主体的code使用"函式指标"变数来呼叫函式,
这样就不会编译错误了,然後你的module 启动的时候把你的函式记忆体位置塞到这个
"函式指标"变数里面
危险的地方是,要是你忘记把你的函式记忆体位置塞到这个"函式指标"变数里面,当主体
code呼叫"函式指标"变数时,系统很有可能crash,所以通常在呼叫前,要先检查变数内容
举一反三,如果你有很多个函式,都要进行这样的处理,那麽然就会宣告一个结构把这些
"函式指标"变数群组起来,这就是stackfollow那篇回文的解法,这不就是C++的虚拟类别
吗?
其实linux kernel 的里面驱动程式介面部分几乎都采用这个写法,随便找就有
延伸阅读:
C语言的"函式指标"变数
--
※ 发信站: 批踢踢实业坊(ptt.cc), 来自: 220.228.151.2
※ 文章网址: https://webptt.com/cn.aspx?n=bbs/LinuxDev/M.1455681225.A.A51.html
1F:推 wayne8145: 谢谢leo大详细的解释 02/17 12:57
2F:→ wayne8145: 现在compile是过了...但runtime时喷dereference null p 02/17 12:58
3F:→ wayne8145: ointer 02/17 12:58
4F:推 wayne8145: 问题应该是我在Module assign函数指标了,但两个是不同 02/17 13:11
5F:→ wayne8145: process,B看不到A的变数,是否要用到shared memory让B 02/17 13:12
6F:→ wayne8145: 看到跟A相同的变数才行 02/17 13:12
7F:→ wayne8145: 小弟资质驽钝>< 02/17 13:13
8F:→ leolarrel: 不对,在kernel里面,所有的code包然事後插入的module,都 02/17 13:27
9F:→ leolarrel: 处於同一个process 02/17 13:28
10F:推 wayne8145: leo大这句【然後你的module 启动的时候把你的函式记忆 02/17 14:58
11F:→ wayne8145: 体位置塞到这个"函式指标"变数里面】module要怎麽去得 02/17 14:59
12F:→ wayne8145: 到主体code的‘’函式指标变数‘’ 02/17 14:59
13F:推 wayne8145: 因为AB是分开编译的,所以是我哪边有误会吗@@ 02/17 15:28
14F:→ leolarrel: 你C语言不同C档案虽然不同时间编译依样可以共享全域变 02/18 11:18
15F:→ leolarrel: 数对吧,例如libc里面的errno变数就是经典的例子,kernel 02/18 11:20
16F:→ leolarrel: 跟module一定是同样的行程,所以kernel code里extern出 02/18 11:21
17F:→ leolarrel: 来的变数或函式,module一定可以存取 02/18 11:21
18F:推 cobrasgo: wayne我想你很多基础观念都还没搞懂 02/19 18:49
19F:推 wayne8145: Linux kernel确实还是新手QQ 02/23 01:16
20F:→ wayne8145: 我最後有解决了,不过方法有点不太一样,还是感谢leo大 02/23 01:17