我一直对计算机怎么工作的非常好奇,想想一些死的硬件怎么加电后就可以为大家提供那么复杂的服务呢?看了《x86汇编从实模式到保护模式》,终于有了些浅显的认识,现在和大家分享下。如果有什么不正确的地方,还望各位指正,谢谢!!
首先计算机加电后会执行内嵌在内存中的ROM-BIOS程序(这个程序一般是检查硬件);然后会在磁盘上的0面0道1扇区(MBR程序,其实我也有点疑惑为什么用LBA写硬盘的时候起始扇区号可以选择0,难道这个LBA的扇区号和硬盘的扇区号不是一一对应的?)上检查是否为有效主引导程序(扇区结尾是否为:0xaa55);如果是,则把这个扇区的全部内容加载到内存中地址为:0x7c00的地方;这个时候就是主引导程序开始运行和加载内核内容了。
详细代码可以参考《x86汇编从实模式到保护模式》李忠老师。下载地址:http://download.csdn.net/detail/yuzhihui_no1/8248445
步骤思考(实模式下的加载器:把一个程序从磁盘上加载到内存中执行):
第一、确定从磁盘哪个扇区中加载,以及加载到内存中的什么地方;
第二、最基本的设置数据段,和堆栈段,代码段一般不用设置(跳转的时候已经设置了);
第三、读取要加载的文件的头文件(