?? x277.html
字號:
<HTML
><HEAD
><TITLE
>Hello World (part 3): 關于 __init and __exit宏</TITLE
><META
NAME="GENERATOR"
CONTENT="Modular DocBook HTML Stylesheet Version 1.7"><LINK
REL="HOME"
TITLE="The Linux Kernel Module Programming Guide"
HREF="index.html"><LINK
REL="UP"
TITLE="Hello World"
HREF="c143.html"><LINK
REL="PREVIOUS"
TITLE="Hello World (part 2)"
HREF="hello2.html"><LINK
REL="NEXT"
TITLE="Hello World (part 4): Licensing and Module Documentation"
HREF="x317.html"></HEAD
><BODY
CLASS="SECT1"
BGCOLOR="#FFFFFF"
TEXT="#000000"
LINK="#0000FF"
VLINK="#840084"
ALINK="#0000FF"
><DIV
CLASS="NAVHEADER"
><TABLE
SUMMARY="Header navigation table"
WIDTH="100%"
BORDER="0"
CELLPADDING="0"
CELLSPACING="0"
><TR
><TH
COLSPAN="3"
ALIGN="center"
>Linux內核驅動模塊編程指南 (內核版本2.2, 2.4)</TH
></TR
><TR
><TD
WIDTH="10%"
ALIGN="left"
VALIGN="bottom"
><A
HREF="hello2.html"
ACCESSKEY="P"
>返回</A
></TD
><TD
WIDTH="80%"
ALIGN="center"
VALIGN="bottom"
>第二章. Hello World</TD
><TD
WIDTH="10%"
ALIGN="right"
VALIGN="bottom"
><A
HREF="x317.html"
ACCESSKEY="N"
>繼續</A
></TD
></TR
></TABLE
><HR
ALIGN="LEFT"
WIDTH="100%"></DIV
><DIV
CLASS="SECT1"
><H1
CLASS="SECT1"
><A
NAME="AEN277"
></A
>2.4. Hello World (part 3): 關于 <TT
CLASS="LITERAL"
>__init</TT
> 和 <TT
CLASS="LITERAL"
>__exit</TT
> 宏</H1
><P
>這里展示了內核2.2以后引入的一個新特性。注意在負責“初始化”和“清理收尾”的函數定義處的變化。宏 <TT
CLASS="FUNCTION"
>__init</TT
>的使用會在初始化完成后丟棄該函數并收回所占內存,如果該模塊被編譯進內核,而不是動態加載。
</P
><P
>宏 <TT
CLASS="FUNCTION"
>__initdata</TT
> 同 <TT
CLASS="FUNCTION"
>__init</TT
> 類似,只不過對變量有效。</P
><P
>宏 <TT
CLASS="FUNCTION"
>__exit</TT
> 將忽略“清理收尾”的函數如果該模塊被編譯進內核。同宏<TT
CLASS="FUNCTION"
>__init</TT
>一樣,對動態加載模塊是無效的。這很容易理解。編譯進內核的模塊是沒有清理收尾工作的, 而動態加載的卻需要自己完成這些工作。</P
><P
>這些宏在頭文件 <TT
CLASS="FILENAME"
>linux/init.h</TT
> 定義,用來釋放內核占用的內存。當你在啟動時看到這樣的 <TT
CLASS="LITERAL"
>Freeing unused kernel memory: 236k freed</TT
>內核輸出,上面的那些正是內核所釋放的。
</P
><DIV
CLASS="EXAMPLE"
><A
NAME="AEN307"
></A
><P
><B
>Example 2-5. hello-3.c</B
></P
><TABLE
BORDER="0"
BGCOLOR="#E0E0E0"
WIDTH="100%"
><TR
><TD
><FONT
COLOR="#000000"
><PRE
CLASS="PROGRAMLISTING"
>/* hello-3.c - Illustrating the __init, __initdata and __exit macros.
*/
#include <linux/module.h> /* Needed by all modules */
#include <linux/kernel.h> /* Needed for KERN_ALERT */
#include <linux/init.h> /* Needed for the macros */
static int hello3_data __initdata = 3;
static int __init hello_3_init(void)
{
printk(KERN_ALERT "Hello, world %d\n", hello3_data);
return 0;
}
static void __exit hello_3_exit(void)
{
printk(KERN_ALERT "Goodbye, world 3\n");
}
module_init(hello_3_init);
module_exit(hello_3_exit);</PRE
></FONT
></TD
></TR
></TABLE
></DIV
><P
>附帶說一句,你會發現宏<TT
CLASS="FUNCTION"
>__initfunction()</TT
>在為2.2版本內核編寫的模塊中出現。</P
><TABLE
BORDER="1"
BGCOLOR="#E0E0E0"
WIDTH="100%"
><TR
><TD
><FONT
COLOR="#000000"
><PRE
CLASS="SCREEN"
> __initfunction(int init_module(void))
{
printk(KERN_ALERT "Hi there.\n");
return 0;
}</PRE
></FONT
></TD
></TR
></TABLE
><P
>該宏起到和宏 <TT
CLASS="FUNCTION"
>__init</TT
>類似的作用,但因為推薦使用宏<TT
CLASS="FUNCTION"
>__init</TT
>目前已不推薦使用。 我提到它只因為你可能在較新的內核中遇到。像在內核2.4.18中,
總共有38處 <TT
CLASS="FUNCTION"
>__initfunction()</TT
>的引用,在2.4.20中,有37處。但是,不要在你的代碼中使用。</P
></DIV
><DIV
CLASS="NAVFOOTER"
><HR
ALIGN="LEFT"
WIDTH="100%"><TABLE
SUMMARY="Footer navigation table"
WIDTH="100%"
BORDER="0"
CELLPADDING="0"
CELLSPACING="0"
><TR
><TD
WIDTH="33%"
ALIGN="left"
VALIGN="top"
><A
HREF="hello2.html"
ACCESSKEY="P"
>返回</A
></TD
><TD
WIDTH="34%"
ALIGN="center"
VALIGN="top"
><A
HREF="index.html"
ACCESSKEY="H"
>回到首頁</A
></TD
><TD
WIDTH="33%"
ALIGN="right"
VALIGN="top"
><A
HREF="x317.html"
ACCESSKEY="N"
>繼續</A
></TD
></TR
><TR
><TD
WIDTH="33%"
ALIGN="left"
VALIGN="top"
>Hello World (part 2)</TD
><TD
WIDTH="34%"
ALIGN="center"
VALIGN="top"
><A
HREF="c143.html"
ACCESSKEY="U"
>回到本章開始</A
></TD
><TD
WIDTH="33%"
ALIGN="right"
VALIGN="top"
>Hello World (part 4): 內核模塊證書和內核模塊文檔說明</TD
></TR
></TABLE
></DIV
></BODY
></HTML
>
?? 快捷鍵說明
復制代碼
Ctrl + C
搜索代碼
Ctrl + F
全屏模式
F11
切換主題
Ctrl + Shift + D
顯示快捷鍵
?
增大字號
Ctrl + =
減小字號
Ctrl + -