1.1內核模塊的編譯文件
一個內核模塊不是一個可以獨立執行的文件,而是需要在運行時刻連接入內核的目標文
件。所以,它們需要用-c選項進行編譯。而且,所有的內核模塊都必須包含特定的標志:
? __KERNEL__——這個標志告訴頭文件此代碼將在內核模塊中運行,而不是作為用戶進
程。
? MODULE——這個標志告訴頭文件要給出適當的內核模塊的定義。
? Linux——從技術上講,這個標志不是必要的。但是,假如你希望寫一個比較正規的
內核模塊,在多個操作系統上編譯,這個標志將會使你感到方便。它可以答應你在獨立
於操作系統的部分進行常規的編譯。
還有其它的一些可被選擇包含標志,取決於編譯模塊是的選項。假如你不能明確內核怎
樣被編譯,可以在in/usr/include/linux/config.h中查到。
? __SMP__——對稱多線程。在內核被編譯成支持對稱多線程(盡管在一台處理機上運行)
是必須定義。假如是這樣,還需要做一些別的事情(參見第12章)。
? CONFIG_MODVERSIONS——假如CONFIG_MODVERSIONS被激活,你需要在編譯
是定義它並且包含文件/usr/include/linux/modversions.h。這可以有代碼自動完成。
ex Makefile
# Makefile for a basic kernel module
CC=gcc
MODCFLAGS := -Wall -DMODULE -D__KERNEL__ -DLINUX
hello.o: hello.c /usr/include/linux/version.h
$(CC) $(MODCFLAGS) -c hello.c
echo insmod hello.o to turn it on
echo rmmod hello to turn if off
echo
echo X and kernel programming do not mix.
echo Do the insmod and rmmod from outside
所以,並不是剩下的事情就是root(你沒有把它編譯成root,而是在邊緣(注1.1)。對
嗎?),然後就在你的核心內容裡插入或移出hello。當你這樣做的時候,要注重到你的新模
塊在/proc/modules裡。
而且,編譯文件不推薦從X下插入的原因是內核有一條需要用printk打印的消息,它
把它送給了控制台。假如你不使用X,它就送到了你使用的虛擬終端(你用Alt-F選擇的
哪個)並且你可以看到。相反的,假如你使用了X,就有兩種可能性。假如用xterm –C打
開了一個控制台,輸出將被送到哪裡。假如沒有,輸出將被送到虛擬終端7——被X“覆蓋”
的那個。
假如你的內核變得不穩定,你可以在沒有X的情況下得到調試消息。在X外,printk
可以直接從內核中輸出到控制台。而假如在X裡,printk輸出到一個用戶態的進程(xterm
–C)。當進程接收到CPU時間,它會將其送到X服務器進程。然後,當X服務器進程接收
到CPU時間,它將會顯示,但是一個不穩定的內核意味著系統將會崩潰或重起,所以你不
希望顯示錯誤的消息,然後可能被解釋給你什麼發生了錯誤,但是超出了正確的時間。