热门标签 | HotTags
当前位置:  开发笔记 > 后端 > 正文

从开机到进入操作系统的引导过程详解

最近学习了计算机组成原理,老师问了一个问题“计算机如何执行第一条指令?”又看了一本书《30天自制操作系统》,因此在这好好总结一下计算机开机以后的整个引导过程。

最近学习了 计算机组成原理,老师 问了一个问题“计算机如何执行第一条指令?”

又看了一本书《30天自制操作系统》,因此在这好好总结一下计算机开机以后的整个引导过程。



Part 1. 引导过程详解

① 第一步,开机直接访问BIOS ROM0xFFFF0

        开机以后,CS寄存器置为0xFFFFIP寄存器置为0x0000。这样一来,CPU就会要求访问地址为0xFFFF0的这个地方。这个地址实际上不是内存的地址,它被 地址控制器(实际上是南桥北桥)映射到 BIOS ROM里,而这个地址的ROM中存放着一条跳转指令。

        参考:http://bbs.csdn.net/topics/370117602

        http://blog.csdn.net/mxdlove00/article/details/8821377

② 第二步,访问BIOS ROM中的初始化程序。

    0xFFFF0中这条跳转指令,跳转至BIOS ROM的某个地址。从这开始是一段初始化程序,把这段程序复制到内存中执行。

  作用:一方面 初始化硬件(如内存等);另一方面 从硬盘加载引导程序(具体方法是 从000扇区开始寻找,如果扇区最后是”55 AA”,则说明找到该引导程序,否则继续寻找下一扇区,直到找到引导程序),找到引导(boot)程序之后 复制到内存的 0x07c00——0x7dff(复制到该地址的原因参看 http://blog.csdn.net/mxdlove00/article/details/8811060 )中,然后跳到该地址执行引导程序。

        参考: 《30天自制操作系统》

        http://bbs.csdn.net/topics/370117602

        到此为止,一切都是硬件自动完成的,是不可改变的。

        从下面开始,执行的程序可以由程序员自由控制了。

③ 第三步,引导程序开始执行。

        引导程序把操作系统硬盘读入到内存中,并跳到内存操作系统开始地址

        多说一点,在《30天自制操作系统》中是这么做的,把软盘中10个柱面的内容都读到内存中,推算(软盘在内存的开始地址+操作系统在软盘中的相对地址=操作系统在内存中的地址)出操作系统的开始地址,然后跳到该地址。

        参考:《30天自制操作系统》

④ 第四步,开始执行操作系统程序。

        开始执行操作系统程序。


Part 2. 引导程序示意图

 

        ① 开机访问0xFFFF0地址

        ② 跳转到BIOS ROM的初始化程序

        ③ 把BIOS ROM中的初始化程序复制到内存中执行

        ④ 初始化程序 首先初始化硬件,然后在硬盘中找到 引导程序。

        ⑤ 将引导程序复制到 内存的 0x07c00,并执行

        ⑥ 引导程序 将硬盘的内容复制到内存中。

        ⑦ 跳到内存中操作系统的开始地址,

        ⑧ 开始执行操作系统。


推荐阅读
  • 使用cpphttplib构建HTTP服务器以处理带有查询参数的URL请求 ... [详细]
  • 作为140字符的开创者,Twitter看似简单却异常复杂。其简洁之处在于仅用140个字符就能实现信息的高效传播,甚至在多次全球性事件中超越传统媒体的速度。然而,为了支持2亿用户的高效使用,其背后的技术架构和系统设计则极为复杂,涉及高并发处理、数据存储和实时传输等多个技术挑战。 ... [详细]
  • Python作为当今IT领域中最受欢迎且高效的语言之一,其框架能够显著加速Web应用程序的开发过程。本文推荐并对比了十大顶级Python Web开发框架,其中CubicWeb以其卓越的代码重用性和模块化设计脱颖而出,为开发者提供了强大的支持。 ... [详细]
  • Spring框架入门指南:专为新手打造的详细学习笔记
    Spring框架是Java Web开发中广泛应用的轻量级应用框架,以其卓越的功能和出色的性能赢得了广大开发者的青睐。本文为初学者提供了详尽的学习指南,涵盖基础概念、核心组件及实际应用案例,帮助新手快速掌握Spring框架的核心技术与实践技巧。 ... [详细]
  • 从Google Jam落选后,意外收获了一颗“桔子”,重新整理行囊再出发 ... [详细]
  • 本文详细介绍了如何在Linux系统中搭建51单片机的开发与编程环境,重点讲解了使用Makefile进行项目管理的方法。首先,文章指导读者安装SDCC(Small Device C Compiler),这是一个专为小型设备设计的C语言编译器,适合用于51单片机的开发。随后,通过具体的实例演示了如何配置Makefile文件,以实现代码的自动化编译与链接过程,从而提高开发效率。此外,还提供了常见问题的解决方案及优化建议,帮助开发者快速上手并解决实际开发中可能遇到的技术难题。 ... [详细]
  • Java中高级工程师面试必备:JVM核心知识点全面解析
    对于软件开发人员而言,随着技术框架的不断演进和成熟,许多高级功能已经被高度封装,使得初级开发者只需掌握基本用法即可迅速完成项目。然而,对于中高级工程师而言,深入了解Java虚拟机(JVM)的核心知识点是必不可少的。这不仅有助于优化性能和解决复杂问题,还能在面试中脱颖而出。本文将全面解析JVM的关键概念和技术细节,帮助读者全面提升技术水平。 ... [详细]
  • 深入解析Tomcat:开发者的实用指南
    深入解析Tomcat:开发者的实用指南 ... [详细]
  • 在当前各种算法实现和开源软件包层出不穷的背景下,算法对程序员的重要性是否有所减弱?回顾历史,早期程序员必须熟练掌握算法并频繁自行编写。然而,随着技术的发展,算法逐渐成为一种“商品”,现代开发者更多依赖现成的库和商业算法解决方案。有观点认为,机器学习领域中,许多算法已经被高度封装,不再需要深入理解其背后的数学原理。然而,这种趋势也引发了关于技术深度与广度平衡的讨论,强调了基础理论知识在应对复杂问题时的不可替代性。 ... [详细]
  • 深入解析Java虚拟机内存模型(JMM)及其核心机制
    为了深入理解Java内存模型(JMM),首先需要对计算机硬件体系有全面的认识,尤其是CPU与主存之间的多级缓存架构。这些硬件特性直接影响了JMM的设计和实现,确保在多线程环境下数据的一致性和可见性。 ... [详细]
  • Java新手求助:如何优雅地向心仪女生索要QQ联系方式(附代码示例与技巧)
    在端午节后的闲暇时光中,我无意间在技术社区里发现了一篇关于如何巧妙地向心仪女生索取QQ联系方式的文章,顿时感到精神焕发。这篇文章详细介绍了源自《啊哈!算法》的方法,不仅图文并茂,还提供了实用的代码示例和技巧,非常适合 Java 新手学习和参考。 ... [详细]
  • 开发心得:深入探讨Servlet、Dubbo与MyBatis中的责任链模式应用
    开发心得:深入探讨Servlet、Dubbo与MyBatis中的责任链模式应用 ... [详细]
  • 从无到有,构建个人专属的操作系统解决方案
    操作系统(OS)被誉为程序员的三大浪漫之一,常被比喻为计算机的灵魂、大脑、内核和基石,其重要性不言而喻。本文将详细介绍如何从零开始构建个人专属的操作系统解决方案,涵盖从需求分析到系统设计、开发与测试的全过程,帮助读者深入理解操作系统的本质与实现方法。 ... [详细]
  • 深入解析:JavaScript中的表达式与语句有何不同
    深入解析:JavaScript中的表达式与语句有何不同 ... [详细]
  • 对于前端开发新手而言,理解JavaScript模块加载机制常常是一个挑战。本文将深入解析Node.js中的`require`方法及其与RequireJS之间的区别,并探讨它们在不同场景下的应用。通过对比这两种模块加载方式,读者可以更好地掌握如何在项目中选择合适的模块管理工具。此外,文章还提供了实际示例,帮助读者加深对模块化编程的理解。 ... [详细]
author-avatar
YuSJ-AZZ_480
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有