##引言## 在国嵌内核驱动进阶班视频里创建proc文件的例程中有 void __exit myproc_exit(void)函数,其中的 __exit和常用的exit有什么区别呢?
首先,函数__exit()直接是一个sys_exit系统调用,而函数exit()则通常是普通函数库中的一个函数。 exit在头文件stdlib.h中声明,而__exit()声明在头文件unistd.h中声明。
##功能作用## exit()作用: 它会先执行一些清除操作,例如调用执行各终止处理程序、关闭所有标准IO等。exit函数是在__exit函数之上的一个封装,其会调用__exit,并在调用之前先刷新流。
__exit()作用: 调用_exit函数时,其会关闭进程所有的文件描述符,清理内存以及其他一些内核清理函数,但不会刷新流(stdin, stdout, stderr ...).
先看__exit()源程序:
<!-- lang: cpp -->
#define _LIBRARY_ //定义符号常量
#include<unistd.h>
volatile void __exit(int exit_code)
{
_asm_("int $0x80"::"a"(_NR_exit),"b"(int exit_code));
}
unistd.h是linux标准头文件。定义了各种符号常数和类型,并声明了各种函数(详见头文件);若定义了_LIBRARY_,则还包括内核系统调用号和内嵌汇编_syscall0()等。
__exit(int exit_code)是内核使用的程序(退出)或终止函数。直接调用系统中断int 0x80,功能号为_NR_exit。参数exit_code退出码。关键字volatile用于告诉编译器gcc该函数不会返回。这样可以让gcc产生 一些更好的代码,更重要的使用这个关键字可以避免产生某些假警告信息。
asm("int $0x80"::"a"(_NR_exit),"b"(int exit_code))用到了嵌入汇编,这里执行的动作就是调用系统中断int 0x80,在调用系统中断之前,将系统调用号_NR_exit放到寄存器eax中,退出码exit_code放到寄存器ebx中。用于关键字 volatile告诉编译器gcc告诉该函数没有返回,所以在嵌入汇编中并没有给出输出寄存器。
##Reference## [1].http://blog.163.com/njut_wangjian/blog/static/1657964252012319101939312/