linux內核之模塊參數及導出符號
1. 模塊參數
用 「mole_param (參數名,參數類型,參數讀 / 寫許可權) 」 為模塊定義一個參數,例如下列代碼定義了 1 個整型參數和 1 個字元指針參數:
1 static char *book_name = "dissecting Linux Device Driver";
2 mole_param(book_name, charp, S_IRUGO);
3 static int book_num = 4000;
4 mole_param(book_num, int, S_IRUGO);
在裝載內核模塊時,用戶可以向模塊傳遞參數,形式為 「insmode 模塊名 參數名 = 參數值,如果不傳遞,參數將使用模塊內定義的預設值。參數類型可以是 byte 、 short 、 ushort 、 int 、 uint 、 long 、 ulong 、 charp (字元指針)、 bool 或 invbool (布爾的反),在模塊被編譯時會將 mole_param 中聲明的類型與變數定義的類型進行比較,判斷是否一致。模塊被載入後,在 /sys/mole/ 目錄下將出現以此模塊名命名的目錄。在此模塊的目錄下還將出現 parameters 目錄,其中包含一系列以參數名命名的文件節點,這些文件的許可權值就是傳入mole_param ()的 「參數讀 / 寫許可權」 ,而文件的內容為參數的值。
insmod命令載入模塊後,通過查看 「/var/log/messages」 日誌文件可以看到內核的輸出:
# tail -n 2 /var/log/messages
tail -n 2表示輸入文件的最後2行
2. 導出符號
Linux 的 「/proc/kallsyms」 文件對應著內核符號表,它記錄了符號以及符號所在的內存地址。模塊可以使用如下宏導出符號到內核符號表中:
EXPORT_SYMBOL( 符號名 );
EXPORT_SYMBOL_GPL( 符號名 );
導出的符號可以被其他模塊使用,只需使用前聲明一下即可。 EXPORT_SYMBOL_GPL ()只適用於包含 GPL許可權的模塊。
如果符號名是「e_symbol」,從 「/proc/kallsyms」 文件中找出 e_symbol 的相關信息:
# grep e_symbol /proc/kallsyms
8000af1c t e_symbol [export_symb]
⑵ linux的內核模塊都在哪裡放著啊
一個完整的Linux內核一般由5部分組成,它們分別是內存管理、進程管理、進程間通信、虛擬文件系統和網路介面。1、內存管理內存管理主要完成的是如何合理有效地管理整個系統的物理內存,同時快速響應內核各個子系統對內存分配的請求。Linux內存管理支持虛擬內存,而多餘出的這部分內存就是通過磁碟申請得到的,平時系統只把當前運行的程序塊保留在內存中,其他程序塊則保留在磁碟中。在內存緊缺時,內存管理負責在磁碟和內存間交換程序塊。2、進程管理進程管理主要控制系統進程對CPU的訪問。當需要某個進程運行時,由進程調度器根據基於優先順序的調度演算法啟動新的進程。:Linux支持多任務運行,那麼如何在一個單CPU上支持多任務呢?這個工作就是由進程調度管理來實現的。在系統運行時,每個進程都會分得一定的時間片,然後進程調度器根據時間片的不同,選擇每個進程依次運行,例如當某個進程的時間片用完後,調度器會選擇一個新的進程繼續運行。由於切換的時間和頻率都非常的快,由此用戶感覺是多個程序在同時運行,而實際上,CPU在同一時間內只有一個進程在運行,這一切都是進程調度管理的結果。3、進程間通信進程間通信主要用於控制不同進程之間在用戶空間的同步、數據共享和交換。由於不用的用戶進程擁有不同的進程空間,因此進程間的通信要藉助於內核的中轉來實現。一般情況下,當一個進程等待硬體操作完成時,會被掛起。當硬體操作完成,進程被恢復執行,而協調這個過程的就是進程間的通信機制。4、虛擬文件系統Linux內核中的虛擬文件系統用一個通用的文件模型表示了各種不同的文件系統,這個文件模型屏蔽了很多具體文件系統的差異,使Linux內核支持很多不同的文件系統,這個文件系統可以分為邏輯文件系統和設備驅動程序:邏輯文件系統指Linux所支持的文件系統,例如ext2、ext3和fat等;設備驅動程序指為每一種硬體控制器所編寫的設備驅動程序模塊。5、網路介面網路介面提供了對各種網路標準的實現和各種網路硬體的支持。網路介面一般分為網路協議和網路驅動程序。網路協議部分負責實現每一種可能的網路傳輸協議。網路設備驅動程序則主要負責與硬體設備進行通信,每一種可能的網路硬體設備都有相應的設備驅動程序。
⑶ OpenWrt教程-如何在OpenWrt系統中添加一個Linux內核模塊
linux內核支持動態載入模塊,內核模塊以.ko為後綴,在Linux系統中,內核模塊放在/lib/molex/x.x.x目錄中,其中x.x.x為linux版本號
載入模塊
insmod xxx.ko
如果帶參數 insmod xxx.ko a=1
卸載模塊
rmmod xxx.ko
支持的數據類型
bool :布爾類型
invbool:顛倒了值的bool類型;
charp :字元指針類型,內存為用戶提供的字元串分配;
int :整型
long :長整型
short :短整型
uint :無符號整型
ulong :無符號長整型
ushort :無符號短整型
內核模塊源碼Makefile編寫格式和linux源碼的格式一樣
在OpenWrt系統中,內核模物芹指塊編譯和應用層的package編譯類似
make package/模塊名/compile V=s
比如:
make package/hello_kernel/compile V=s
編譯完成後會生成.ko文件,目首正錄文件在build_dir中,但和應用層的build目錄有點區別,內核模塊的package放在linux目錄,如(X86平台):
build_dir/target-x86_64_musl/linux-x86_64/
將編譯完成的ko文罩配件傳輸到OpenWrt系統中,注意編譯平台和開發板平台的系統架構要一致。
⑷ 請問 Linux內核模塊多文件編譯的問題是如何解決的呢
是編譯多個模塊還是編譯單個模塊?
多個模塊的話在該目錄下面寫一個Makefile,內容為回
-------------------------------------------------------------------------
obj-m := {模塊1名字答}.o {模塊2名字}.o ...
all:
make -C /lib/moles/2.6.32/build/ M=$(PWD) moles
clean:
make -C /lib/moles/2.6.32/build/ M=$(PWD) clean
--------------------------------------------------------------------------
單個模塊,依賴多個文件的話使用傳統寫法即可。
⑸ linux包含哪些模塊
主要是內核(kernel),可行使如下功能:
system call interface;
process control;
memory management;
file system management;
device drivers
⑹ 如何編寫一個簡單的 Linux 內核模塊
編寫helloworld.c及其對應的Makefile。
helloworld.c:
#include <linux/mole.h>#include <linux/kernel.h>int init_hello_mole(void)
{
printk("***************Start***************\n");
printk("Hello World! Start of hello world mole!\n"); return 0;
}void exit_hello_mole(void)
{
printk("***************End***************\n");
printk("Hello World! End of hello world mole!\n");
}
MODULE_LICENSE("Dual BSD/GPL");
mole_init(init_hello_mole);
mole_exit(exit_hello_mole);
Makefile:
# To build moles outside of the kernel tree, we run "make"# in the kernel source tree; the Makefile these then includes this# Makefile once again.# This conditional selects whether we are being included from the# kernel Makefile or not.# called from kernel build system: just declare what our moles areobj-m := helloworld.oCROSS_COMPILE =
CC = gcc # Assume the source tree is where the running kernel was built
# You should set KERNELDIR in the environment if it's elsewhere
KERNELDIR ?= /usr/src/linux-headers-$(shell uname -r) # The current directory is passed to sub-makes as argument
PWD := $(shell pwd)all: molesmoles:
$(MAKE) -C $(KERNELDIR) M=$(PWD) molesclean:
rm -rf *.o *~ core .depend *.symvers .*.cmd *.ko *.mod.c .tmp_versions $(TARGET)
在Makefile中,在obj-m := helloworld.o這句中,.o的文件名要與編譯的.c文件名一致。
KERNELDIR ?= /usr/src/linux-headers-$(shell uname -r)指示當前linux系統內核的源碼位置。
⑺ linux內核模塊頭文件找不到
找不到就沒辦法了
你試試 #find / -name "mole.h" 看看系統中有沒有?如果沒有,最好的辦法是完全安裝fedora6的所有軟體
⑻ linux內核模塊編譯-通過Makefile重命名.ko文件名和模塊名
假設模塊的源文件為hello.c,源碼如下:
使用該文件編譯內核模塊。
正常情況下,Makefile文件內容如下:
執行 make 命令,生成hello.ko文件。
執行 sudo insmod hello.ko 命令,安裝該模塊。
執行 lsmod 命令,查看安裝的模塊。就會看到第一行的就是hello模塊。
但是,如果想自定義模塊名稱為 xmole ,而不是默認的 hello ,如何實現呢?方法如下:
在Makefile中重命名obj-m並將obj-m的依賴關系設置為原始模塊(hello)
修改後的Makefile文件內容如下:
將obj-m設置為 xmole .o,並使 xmole .o依賴於 hello .o.
執行 make 命令後,生成 xmole .ko, 而不是 hello .ko,
安裝命令: sudo insmod xmole.ko
查看命令: lsmod ,就會看到被安裝名為 xmole 的模塊。
⑼ linuxko載入在el0
linuxko載入在el0,ko文件是kernel object文件(內核模塊),該文件的意義就是把內核的一些功能移動到內核外邊, 需要的時候插悉啟入內核,不需要時卸載。
二、優點
(1)這樣可以縮小內核體積;
(2)使用方便。陸賣
三、.ko文件一般的用處
(1)作為一個功能模塊,需要使用時,直接插入運行就行。如在imx6上連接模擬攝像頭,先運行模擬攝像頭對應的驅動模塊 camera.ko文睜悉如件,然後對應的工程執行文件運行就行。
⑽ linux操作系統中,載入和刪除內核模塊的命令是什麼
modprobe命令x0dx0aLinux命令:modprobe 。x0dx0a功能說明:自動處理可載入模塊。x0dx0a語法:modprobe [-acdlrtvV][--help][模塊文件][符號名稱 = 符號值]。x0dx0a補充說明:modprobe可載入指定的個別模塊,或是載入一組相依的模塊。modprobe會根據depmod所產生的相依關系,決定要載入哪些模塊。若在載入過程中發生錯誤,在modprobe會卸載整組的模塊。x0dx0ax0dx0a內容x0dx0a1、modprobe 命令是根據depmod -a的輸出/lib/moles/version/moles.dep來載入全部的所需要模塊。x0dx0a2、刪除模塊的命令是:modprobe -r filename。x0dx0a3、系統啟動後,正常工作的模塊都在/proc/moles文件中列出。使用lsmod命令也可顯示相同內容。x0dx0a4、在內核中有一個「Automatic kernel mole loading"功能被編譯到了內核中。當用戶嘗試打開某類型的文件時,內核會根據需要嘗試載入相應的模塊。/etc/moles.conf或 /etc/modprobe.conf文件是一個自動處理內核模塊的控制文件。x0dx0amodprobe命令主要用於在Linux 2.6內核中載入和刪除Linux內核模塊。通過此命令用戶可以輕松地載入和刪除Linux內核模塊,同時使用此命令載入Linux內核模塊時,Linux內核會自動解決內核模塊之間的依賴關系,將相互依賴的模塊自動載入,如下所示:x0dx0a1) 載入RAID1陣列級別模塊:x0dx0a[root@rhel5 boot]# modprobe raid1 x0dx0ax0dx0a2) 顯示已載入的RAID1陣列級別模塊:x0dx0a[root@rhel5 boot]# lsmod |grep raid1 raid1 25153 0 x0dx0ax0dx0a3) 刪除RAID1陣列級別模塊:x0dx0a[root@rhel5 boot]# modprobe -r raid1 x0dx0ax0dx0a4) 顯示RAID1陣列級別模塊:x0dx0a[root@rhel5 boot]# lsmod |grep raid1 x0dx0ax0dx0amodprobe命令在載入模塊時會自動解決依賴的模塊。當載入的模塊需依賴另一個模塊時,系統會自動將此模塊載入。而當用戶使用insmod命令載入模塊時,則不會自動解決相對應的依賴模塊褲肢。x0dx0amodprobe命令中的"-r"參數表示刪除指定模塊,"-c"參數表示顯示/etc/modprobe.conf配置文件的參數,"-C"參數表示指定內核配置文件,"-f"表示覆蓋,"-l"表示顯示模塊的絕對路徑。x0dx0a[root@rhel5 boot]# modprobe -l|grep raid /lib/moles/2.6.18-8.el5/kernel/drivers/md/raid0.ko /lib/moles/2.6.18-8.el5/kernel/drivers/md/raid456.ko /lib/moles/2.6.18-8.el5/kernel/drivers/md/raid1.ko /lib/moles/2.6.18-8.el5/kernel/drivers/md/raid10.ko /胡中世lib/moles/2.6.18-8.el5/kernel/drivers/scsi/megaraid.ko /lib/moles/2.6.18-8.el5/kernel/drivers/scsi/aacraid/aacraid.ko /lib/moles/2.6.18-8.el5/kernel/drivers/scsi/megaraid/megaraid_mbox.ko /lib/moles/2.6.18-8.el5/kernel/drivers/scsi/megaraid/megaraid_mm.ko /lib/moles/2.6.18-8.el5/培肆kernel/drivers/scsi/megaraid/megaraid_sas.ko /lib/moles/2.6.18-8.el5/kernel/drivers/scsi/raid_class.ko x0dx0ax0dx0a以上命令表示顯示系統中所有的編譯模塊,並過濾包含有raid字元串的模塊。