Exec函数对应的系统调用处理过程
张必红原创作品转载请注明出处《Linux内核分析》MOOC课程http://mooc.study.163.com/course/USTC-1000029000
关于系统调用,前两周已经详细说明了,这次就主要讲讲exec函数对应的系统调用的不同之处。还有,exec对应的程序是怎样加载到内存里并且运行的。
Exec对应的中断处理程序
在这里我们首先来说明一下,在linux里,一个程序是如何加载运行的。一般,我们是在shell里执行一条命令,然后就执行了一个程序。那么shell的原理是什么呢?一般shell,都是首先先fork一个子进程,可是,fork的子进程是和父进程执行相同的程序,这不符合我们的要求,所以就需要execlp函数,用子进程来加载执行我们想要执行的程序。这就是shell的基本原理。
那么下面呢,我们就来分析一下exec系统调用。首先,exec会调用sys_execve,然后呢,调用do_execve,再调用do_execve_common,这个函数会把函数参数和系统环境传进来进行相应的处理。然后调用exec_binprm来执行相应的程序。这个函数里面有很多重要的代码。其中,很重要的一点就是会调用search_binary_handler,这个函数会调用各种不同的格式来识别相应的文件,直到识别为止,比如linux中可执行文件为ELF,它就会识别出elf文件。我们可以分析一段这段代码.