linux内核设计的艺术--加载内核代码

来源:互联网 发布:c语言模块化书籍 编辑:程序博客网 时间:2024/05/22 02:26

在BIOS触发0x19中断将磁盘的第一个扇区(512B)加载到内存中后,计算机才真正开始执行磁盘上的程序。而这512B的程序就是bootsect.s,此时处理器还处于实模式内存寻址的最大范围是1M(0x0000-0xFFFF),接下来我们看看在bootsect.s的第一批代码中做了些什么?

</pre><pre name="code" class="cpp">SYSSIZE = 0x3000                        //内核程序的大小SETUPLEN = 4//要加载的setup程序长度单位为扇区数BOOTSEG  = 0x07c0//启动扇区被BIOS加载的位置,也就是现在所在的位置INITSEG  = 0x9000//bootsect.s即将移动到的位置SETUPSEG = 0x9020//setup程序要被加载的开始位置SYSSEG   = 0x1000//kernel加载的起始位置ENDSEG   = SYSSEG + SYSSIZE//kernel的结束位置ROOT_DEV = 0x306                        //根文件系统的设备号


上述代码声明了给一系列变量赋值,用于内存规划

</pre><pre name="code" class="cpp">entry startstart:movax,#BOOTSEG             //movds,ax                   //movax,#INITSEG             //这段代码是将bootsect的代码从0x07C0moves,ax                   //复制到0x9020处movcx,#256                 //subsi,si                   //subdi,di                   //rep                             //        movw                            //

</pre>因为在后面的程序中,bootsect之前所在的位置会被其他程序覆盖,所以需要将bootsect程序的位置移动至0x90200处<p></p><p></p><p>复制完成之后,紧接着执行</p><p></p><pre code_snippet_id="403621" snippet_file_name="blog_20140623_7_6144482" name="code" class="cpp">jmpigo,INITSEGgo:movax,csmovds,ax


这句指令的意思是,跳转到新复制的bootsect处的go继续执行

这个时候,开始加载setup(setup.s)程序到内存中了

还是老样子,加载setup,只不过这次通过寄存器指定了一系列信息方便中断服务程序访问磁盘


load_setup:movdx,#0x0000//指定磁头为第0个movcx,#0x0002//指定在第2个扇区,第0个磁道movbx,#0x0200//setup在磁盘中的物理地址movax,#0x0200+SETUPLEN//指定结束的位置int0x13//中断读取磁盘jncok_load_setup//加载完成,执行ok_load_setupmovdx,#0x0000movax,#0x0000//重置磁盘int0x13jload_setup


然后调用read_it加载system也就是kernel模块了

movax,#SYSSEG      //指定system模块加载在内存中的位置moves,axcallread_itcallkill_motor


到了这一步,bootsect的工作也就算完成了,这时候,内核的代码已经加载到了内存中,但是在离直接执行内核程序的时候还有一段路要走,下一篇将介绍如何为内核代码执行做准备

0 0
原创粉丝点击