简析linux内核的执行流程_内核代码中怎么触发命令,2024年最新金九银十

先自我介绍一下,小编浙江大学毕业,去过华为、字节跳动等大厂,目前阿里P7

深知大多数程序员,想要提升技能,往往是自己摸索成长,但自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!

因此收集整理了一份《2024年最新Linux运维全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友。
img
img
img
img
img

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,涵盖了95%以上运维知识点,真正体系化!

由于文件比较多,这里只是将部分目录截图出来,全套包含大厂面经、学习笔记、源码讲义、实战项目、大纲路线、讲解视频,并且后续会持续更新

如果你需要这些资料,可以添加V获取:vip1024b (备注运维)
img

正文

开启时间设置**(在main.c131行,time_init()定义于main.c函数**

76startup_time**)**

系统开始激活进程0(**在main.c131行,**sched_init()定义在kernel/

sched.c****函数中,该函数实现进程相关事务设置

依据时钟中断设置,系统调用服务程序挂接。系统调用函数是对用户程序的最基本支持,利用的是

进程相关事务初始化设置              系统调用软中断,详细见下面讲

的。)

时钟中断设置

系统调用服务程序挂接

初始化缓冲区管理结构**(在main.c133行,buffer_init(buffer_memory_end)定义fs/buffer.c)**

初始化硬、软盘**(main.c134135行,hd_initfloppy_init定义kernel/blk_drv/hd.ckernel/blk_drv/floppy.c****)**

开中断                              main.c136行,sti())

第二步:以进程0为母本创建进程1,使进程1不仅仅具备进程0所拥有的能力,而且还能以文件的形式与外设进行数据交互。流程是:

操作系统为进程0创建进程1做准备  **main.c137****行,**move_to_

user_mode()定义在include/asm/system.h**,实现从**

内核态到用户态。进程0正式开始执行,而后

执行main.c138行的“if(!fork())”,开始创建

在进程槽中为进程1申请一个空闲位置并获取进程号

进程1,此时将执行unisted.h中的syscall0宏函数

,得到一个编号,对于fork函数,其值是2,具体

在这个程序中的第62行有定义,然后执行软中断

复制进程0的信息之前,先将一些数据压栈

,进入系统调用阶段,跳到内核态,执行kernel/system_call.s中的代码,将一些寄存器的值压栈后,通过刚才在unisted.h中给eax****赋值

初步设置进程1管理结构         2偏移值在系统调用****sys_call_table 中找到sys_fork函数,跳到该函数执行。进****入后首先申请一个空闲位置并获取进程号。

这同样在system_call.s函数中的****sys_fork

进程0创建进程1的过程中发生时钟中断     中的****_find_copy_

process,再跳到该函数的定义处kernel/

fork.c中,后返回到sys_fork****中,在

从中断返回         复制进程信息前,再将一些数据压栈,

此时有一个寄存器的值和前面的不一样,

**那就是eax,此时是1,它从****task[64]**

得到的。之后执行copy_process,跳到

调整进程1的管理结构       定义处kernel/fork.c中,设置进程1

管理结构。假如此时发生时钟中断,系统

会响应并执行kernel/system_call.s函数

中的timer_interrupt定义处,先压栈后

设置进程1的线性地址空间及物理页面              进入****kernel/sched.c

do_timer函数,别忘了此时仍在进程

0****执行,然后便发现时间片还没完,所以

跳出,并返回到ret_from_sys_call。这是

继续调整进程1的管理结构          kernel/system_call.s中定义的,

接着直接将刚才的压栈数据出栈,继续完成

刚才创建进程1的任务,即在fork.c中继续

调整进程1的管理结构,同时设置进程

进程0准备切换到进程1    1****的线性地址空间及物理页面,直到

**执行到这条语句“**p->state=TASK_

RUNNING**;return last_pid;”,标志着**

系统切换到进程1执行       进程1创建完成。后跳出****copy_process.c

函数,返回到system_call.s,将压栈的

进程1开始执行       的寄存器值出栈,此时eax1。后中断返回

,进程由从内核态变为用户态,即到了unisted.h的“if(_res>=0)”这条指令中,

_res的值就是eax****的值,一判断成立,就返

进程1开始以数据块的形式操作硬盘       回该值。最后回到了****main.c

的“if(!fork())”中,一判断不成立,跳出执****行下一条指令“for(;;)pause();”,同理

Pause函数也和fork****函数一样,这里就不

将找到的缓冲块与请求项挂接       讲了,进入****sys_pause()后将进程0

置为可中断等待状态,并调用在****kernel

**/sched.c定义的schedule()**函数切换进程。

进程切换中断返回后执行了第一条语句

将请求项与硬盘处理函数挂接       是“if(_res>=0)”,一判断,

刚存的eax值为0,返回到“if(!fork())

判断为真,执行init()函数,这在****main.c

定义。进入init.c后其程序执行流程见附录,

进行硬盘读盘前的工作准备     各个程序执行目的正如左边写的一

样。

给硬盘下达读盘命令

进程1由于等待读盘操作挂起

系统切换到进程0执行

进程0执行过程中发生硬盘中断

硬盘中断服务程序响应后,进程0继续执行

再次响应硬盘中断,并唤醒进程1

读盘操作完成后进程1继续执行

进程1继续设置硬盘管理结构

进程1获取软盘超级块,为加载根文件系统做准备

进程1备份超级块数据

进程1将根文件系统从软盘拷贝到虚拟盘

进程1开始加载根文件系统

进程1准备加载根文件系统超级块

进程1继续加载根文件系统

进程1准备获取根目录节点

进程1加载根目录节点

进程1结束加载根文件系统的过程

进程1与内核文件表挂接,为打开文件做准备

确定打开操作的起点

获取枝梢i节点—dev目录文件的i节点

确定dev的目录文件i节点为枝梢节点

继续返回枝梢i节点

查找tty0文件的i节点

将tty0设备文件的i节点,返回给sys_open系统调用

分析tty0文件i节点

设置文件管理结构并返回给用户进程

进程复制tty0文件句柄

进程1继续复制tty0文件句柄

第三步:以进程1为母本创建进程2,使进程2在全面具备进程1所拥有的能力和环境的基础上,进一步具备支持”人机交互“的能力,最终实现准备阶段完成。流程如下:

进程1准备创建进程2  与进程0创建进程1一样,创建进程2,复

制进程1的管理结构,复制页表、页目录

项等,创建进程2后即执行到init/main.c

复制进程2的管理结构并进行调整  **176行与186****行,分别是:**if(!(pid

=fork())中子进程即进程2****执行,而父进程(

进程1)执行186行的if(pid>0),父进程

调整进程2管理结构中与文件有关的内容   进入wait函数,等待!

进入wait函数后还做了一些动作:首先

查找自己的子进程,确定是进程2后,判断

进程1执行过程中发生时钟中断  进程2是否处于终止状态或是

僵死状态,一判断不是,就将进程1设置为

**可中断等待状态,继而调用****schedule()**函数

进程1从时钟中断返回   准备切换到进程2执行切换到进程2**。**

进入进程2后开始加载shell程序。首先执

init/main.c180行的“close(0);”,就是

进程1查找它自己的子进程  **解除****filp[20]file_table[64]**的第一项

关系,这是从进程1继承过来的。然后

是“if(open(“etc/rc”,O_RDONLY,0))”,

对进程2的状态进行处理   其中是将进程2的管理结构指针表****filp

**[20]的第一项与file_table[64]**的第一项建立

一个关于资源配置的文件,而后再执行

切换到进程2执行     execve函数,并映射到sys_execve****系统调用。

再调用do_execve函数,目的便是将参数

与环境变量加载到主内存的页面中去,中断

为打开/etc/rc文件做准备  返回,但此时在该函数里已经将EIP

值指向了shell程序的入口地址,所以返回后

执行的是shell的第一条指令,但这时却发现

进程2打开”/etc/rc“配置文件  内存中没有这一条指令的映射,

所以发生“缺页中断”,然后调用****page_fault

函数中的do_no_page

通过压栈为加载shell文件做准备

为参数和环境变量设置做准备

得到shell文件i节点

为加载参数和环境变量做准备

根据i节点,为shell文件进行检测

检测shell文件头

备份文件头并进行分析

对shell文件进行进一步分析

拷贝参数与环境变量

调整进程2的管理结构

继续调整进程2的管理结构

释放进程2继承的页面

最全的Linux教程,Linux从入门到精通

======================

  1. linux从入门到精通(第2版)

  2. Linux系统移植

  3. Linux驱动开发入门与实战

  4. LINUX 系统移植 第2版

  5. Linux开源网络全栈详解 从DPDK到OpenFlow

华为18级工程师呕心沥血撰写3000页Linux学习笔记教程

第一份《Linux从入门到精通》466页

====================

内容简介

====

本书是获得了很多读者好评的Linux经典畅销书**《Linux从入门到精通》的第2版**。本书第1版出版后曾经多次印刷,并被51CTO读书频道评为“最受读者喜爱的原创IT技术图书奖”。本书第﹖版以最新的Ubuntu 12.04为版本,循序渐进地向读者介绍了Linux 的基础应用、系统管理、网络应用、娱乐和办公、程序开发、服务器配置、系统安全等。本书附带1张光盘,内容为本书配套多媒体教学视频。另外,本书还为读者提供了大量的Linux学习资料和Ubuntu安装镜像文件,供读者免费下载。

华为18级工程师呕心沥血撰写3000页Linux学习笔记教程

本书适合广大Linux初中级用户、开源软件爱好者和大专院校的学生阅读,同时也非常适合准备从事Linux平台开发的各类人员。

需要《Linux入门到精通》、《linux系统移植》、《Linux驱动开发入门实战》、《Linux开源网络全栈》电子书籍及教程的工程师朋友们劳烦您转发+评论

网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。

需要这份系统化的资料的朋友,可以添加V获取:vip1024b (备注运维)
img

一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!
。另外,本书还为读者提供了大量的Linux学习资料和Ubuntu安装镜像文件,供读者免费下载。

华为18级工程师呕心沥血撰写3000页Linux学习笔记教程

本书适合广大Linux初中级用户、开源软件爱好者和大专院校的学生阅读,同时也非常适合准备从事Linux平台开发的各类人员。

需要《Linux入门到精通》、《linux系统移植》、《Linux驱动开发入门实战》、《Linux开源网络全栈》电子书籍及教程的工程师朋友们劳烦您转发+评论

网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。

需要这份系统化的资料的朋友,可以添加V获取:vip1024b (备注运维)
[外链图片转存中…(img-XyRT2FkL-1713263287023)]

一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值