简析linux内核的内核执行流程

上传人:人*** 文档编号:563789206 上传时间:2022-12-12 格式:DOC 页数:16 大小:81KB
返回 下载 相关 举报
简析linux内核的内核执行流程_第1页
第1页 / 共16页
简析linux内核的内核执行流程_第2页
第2页 / 共16页
简析linux内核的内核执行流程_第3页
第3页 / 共16页
简析linux内核的内核执行流程_第4页
第4页 / 共16页
简析linux内核的内核执行流程_第5页
第5页 / 共16页
点击查看更多>>
资源描述

《简析linux内核的内核执行流程》由会员分享,可在线阅读,更多相关《简析linux内核的内核执行流程(16页珍藏版)》请在金锄头文库上搜索。

1、简析linux内核的执行流程-从bootsect.s到main.c(内核版本0.11)Linux启动的第一阶段(从开机到main.c)3个任务:A、启动BIOS,准备实模式下的中断向量表和中断服务程序。B、从启动盘加载操作系统程序到内存。C、为执行32的main函数做过渡准备。内存变化如下: 、0xFE000到0xFFFFF是BIOS启动块,其中上电后第一条指令在0xFFFF0。 、而后0x00000到0x003FF总共1KB存放中断向量表,而接下去的地址到0x004FF共256B存放BIOS数据,从0x0E05B开始的约8KB的内存中存放中断服务程序。 、利用BIOS中断0x19h把硬盘的第

2、一扇区bootsect.s的代码加载到内存中,即0x07c00处,后转到该处执行。 、将bootsect.s的代码复制到0x90000处。 、利用中断0x13h将setup.s程序加载到内存0x90200处。 、再将剩余的约240个扇区的内容加载到0x100000x2EFFF处。 、开始转到setup.s处执行,第一件事就利用BIOS提供的中断服务程序从设备上获取内核运行的所需系统数据并存在0x90000的地址处,这时将原来bootsect.s的代码覆盖得只剩2Byte的空间。 、关中断并将系统代码复制到0x00000处,将原来放在这里的中断向量表与BIOS数据区覆盖掉,地址范围是0x0000

3、00x1EFFF。同时制作两表与两寄存器。 开地址线A20,寻址空间达到4GB,后对8259重新编程,改变中断号。 、转到head.s(大小是25K+184B)执行,执行该程序完后是这样的:0x000000x04FFF:页目录与4个页表,每一项是4KB,共20KB;0x050000x05400:共1KB的空间是软盘缓冲区;0x054010x054b8:共184B没用;0x054b90x05cb8:共2KB的空间存中断描述符表;0x05cb90x064b8:共2KB的空间存全局描述符表;之后就是main函数的代码了!第二阶段、从main.c函数到系统准备完毕阶段。第一步:创建进程0,并让进程0具

4、备在32位保护模式下载主机中的运算能力。流程是:复制根设备和硬盘参数表 (main.c中的102、110、111行) 物理内存规划格局(main.c的112行126行,其中有 rd_init函数定义在kernel/ramdisk.c中,此函数用于虚拟盘初始化;而mem_init函数是用于内存管理结构初始化,定义在mem/memory.c中,该函数页面使用 虚拟盘设置与初始化次数均设置成100,然后再依据主内存的起始位置和终止位置将处于主内存的所有页面的使用次数全部清零,系统以后把使用次数为0的页面视为空闲页面。)内存管理结构mem_map初始化 异常处理类中断服务程序挂接(在main.c的12

5、7行,trap()函数定义 kernel/trap.c,目的是将各种中断与中断描述符表挂接。)初始化块设备与字符设备请求项结构(在main.c的128、129行,blk_dev_init()定义在kernel/blk_dev/ll_rw_blk.c,chr_dev_init()定义在kernel/chr_dev/tty_io.c)将串口与显示器外设的中断服务程序挂接(在main.c的130行, tty_init()定义在kernel/chr_dev/tty_io.c)开启时间设置(在main.c的131行,time_init()定义于main.c函数 76行startup_time)系统开始激

6、活进程0(在main.c的131行,sched_init()定义在kernel/ sched.c函数中,该函数实现进程相关事务设置依据时钟中断设置,系统调用服务程序挂接。系统调用函数是对用户程序的最基本支持,利用的是进程相关事务初始化设置系统调用软中断,详细见下面讲 的。)时钟中断设置系统调用服务程序挂接 初始化缓冲区管理结构(在main.c中133行, buffer_init(buffer_memory_end)定义fs/buffer.c) 初始化硬、软盘(main.c中134、135行,hd_init与floppy_init定义于kernel/blk_drv/hd.c和kernel/blk

7、_drv/floppy.c)开中断(main.c中136行,sti()第二步:以进程0为母本创建进程1,使进程1不仅仅具备进程0所拥有的能力,而且还能以文件的形式与外设进行数据交互。流程是:操作系统为进程0创建进程1做准备 main.c中137行,move_to_user_mode()定义在include/asm/system.h,实现从内核态到用户态。进程0正式开始执行,而后执行main.c的138行的“if(!fork()”,开始创建在进程槽中为进程1申请一个空闲位置并获取进程号进程1,此时将执行unisted.h中的syscall0宏函数,得到一个编号,对于fork函数,其值是2,具体在

8、这个程序中的第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

9、中,在从中断返回复制进程信息前,再将一些数据压栈, 此时有一个寄存器的值和前面的不一样,那就是eax,此时是1,它从task64中得到的。之后执行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

10、的管理结构在kernel/system_call.s中定义的,接着直接将刚才的压栈数据出栈,继续完成刚才创建进程1的任务,即在fork.c中继续调整进程1的管理结构,同时设置进程进程0准备切换到进程11的线性地址空间及物理页面,直到执行到这条语句“p-state=TASK_RUNNING;return last_pid;”,标志着系统切换到进程1执行进程1创建完成。后跳出copy_process.c函数,返回到system_call.s,将压栈的进程1开始执行的寄存器值出栈,此时eax是1。后中断返回 ,进程由从内核态变为用户态,即到了unisted.h的“if(_res=0)”这条指令中,_

11、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()函数,这在m

12、ain.c定义。进入init.c后其程序执行流程见附录,进行硬盘读盘前的工作准备各个程序执行目的正如左边写的一样。给硬盘下达读盘命令进程1由于等待读盘操作挂起系统切换到进程0执行进程0执行过程中发生硬盘中断 硬盘中断服务程序响应后,进程0继续执行再次响应硬盘中断,并唤醒进程1 读盘操作完成后进程1继续执行 进程1继续设置硬盘管理结构 进程1获取软盘超级块,为加载根文件系统做准备 进程1备份超级块数据 进程1将根文件系统从软盘拷贝到虚拟盘进程1开始加载根文件系统进程1准备加载根文件系统超级块进程1继续加载根文件系统进程1准备获取根目录节点进程1加载根目录节点进程1结束加载根文件系统的过程进程1与

13、内核文件表挂接,为打开文件做准备确定打开操作的起点获取枝梢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(pid0),父进程调整进程2管理结构中与文件有关的内容 进入wait函数,等待! 进入wait函数后还做了一些动作:首先 查找自己的子进程,确定是进程2后,判断进程1执行过程中发生时钟中断 进程2是否处于终止状态或是 僵死状态,一判断不是,就将进程1设置为 可中断等待状态,继而调用schedule()函数进程1从时钟中断返回 准备切换到进程2执行 切换到进程2。

展开阅读全文
相关资源
相关搜索

当前位置:首页 > 中学教育 > 试题/考题 > 初中试题/考题

电脑版 |金锄头文库版权所有
经营许可证:蜀ICP备13022795号 | 川公网安备 51140202000112号