前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >操作系统学习之BIOS

操作系统学习之BIOS

作者头像
用户4415180
发布2022-06-23 14:11:21
9070
发布2022-06-23 14:11:21
举报
文章被收录于专栏:高并发

      在x86架构的机器中,有一块ROM,里面存放了BIOS程序,BIOS程序就是开机自检程序,初始化内存控制器,中断控制器,设置中断向量等,将系统软硬件带到一个合适的状态,为操作系统内核准备环境。在ARM架构中没有BIOS,但是得自己写bootloader,bootloader一般存放在flash内,起始地址一般为0x00000000。下面看一下x86架构启动方式。

     8086是16位机器,在上电复位时,代码段寄存器CS初始化为0xF000,IP寄存器初始化为0xFFF0,所以执行的第一条指令地址在0xFFFF0处(段基址左移4位+IP),在此处存的指令是一个跳转指令,会跳转到存放BIOS第一条指令处,然后开始执行BIOS程序。

    80386及以上机器都是32位机器,为了使系统内存连续,第一条指令存放的地址不再是0xFFFF0,而是0xFFFFFFF0,我们知道386机器分为保护模式和实模式,实模式下只能访问1MB内存,保护模式下开启A20才能访问0-4GB整个地址空间,而第一条指令地址远远超过了1MB,那是怎么实现的呢?是硬件实现的,在复位启动时,会强制地址总线A20-A31置1,这样在访存的时候会读取,0xFFFFFFF0处的内容。所以跳转指令会放在此处。BIOS做完自检和初始化后,会选择一个启动设备(硬盘,软盘,u盘,光盘),并且读取该设备第一扇区(512字节)的内容到内存一个特定地址0x7C00,然后会跳转到这个地址继续执行,一般这个地址存放的是操作系统的bootloader。至此BIOS的工作完成,开始交给操作系统的boot程序。

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2016-08-14,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档