📄 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 + -