看板 LinuxDev 關於我們 聯絡資訊
※ 引述《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://www.ptt.cc/bbs/LinuxDev/M.1455681225.A.A51.html
wayne8145: 謝謝leo大詳細的解釋 02/17 12:57
wayne8145: 現在compile是過了...但runtime時噴dereference null p 02/17 12:58
wayne8145: ointer 02/17 12:58
wayne8145: 問題應該是我在Module assign函數指標了,但兩個是不同 02/17 13:11
wayne8145: process,B看不到A的變數,是否要用到shared memory讓B 02/17 13:12
wayne8145: 看到跟A相同的變數才行 02/17 13:12
wayne8145: 小弟資質駑鈍>< 02/17 13:13
leolarrel: 不對,在kernel裡面,所有的code包然事後插入的module,都 02/17 13:27
leolarrel: 處於同一個process 02/17 13:28
wayne8145: leo大這句【然後你的module 啟動的時候把你的函式記憶 02/17 14:58
wayne8145: 體位置塞到這個"函式指標"變數裡面】module要怎麼去得 02/17 14:59
wayne8145: 到主體code的‘’函式指標變數‘’ 02/17 14:59
wayne8145: 因為AB是分開編譯的,所以是我哪邊有誤會嗎@@ 02/17 15:28
leolarrel: 你C語言不同C檔案雖然不同時間編譯依樣可以共享全域變 02/18 11:18
leolarrel: 數對吧,例如libc裡面的errno變數就是經典的例子,kernel 02/18 11:20
leolarrel: 跟module一定是同樣的行程,所以kernel code裡extern出 02/18 11:21
leolarrel: 來的變數或函式,module一定可以存取 02/18 11:21
cobrasgo: wayne我想你很多基礎觀念都還沒搞懂 02/19 18:49
wayne8145: Linux kernel確實還是新手QQ 02/23 01:16
wayne8145: 我最後有解決了,不過方法有點不太一樣,還是感謝leo大 02/23 01:17