浅谈linux启动一个程序

文章仅代表作者想法, 其中细节希望读者探究 。

思考

在操作系统中, 一个程序的运行,不用程序用进程来替代可能更好 , 进程的运行并不可能是自发, 必然由另一个进程引发,当执行一个程序的时候,通过系统调用execve来执行程序程序。那程序流的切换操作系统的内核做了什么?

kernel装载程序

无论是在终端启动或者双击应用运行代码在本质上都是使用do_execve系统调用,通过系统调用进程从用户态转换到内核态,在内核态中检查文件类型,是否超过最大进程数 , kernel是否支持文件格式, 设置好uid , ugid 后将读取二进制文件, 载入目标文件格式 , 修改当前用户态进程ip , sp , cs , ss 等寄存器后痛过force_iret 返回用户态执行目标文件

https://0xax.gitbooks.io/linux-insides/content/SysCall/linux-syscall-4.html

你可能感兴趣的:(unix)