关闭

BIOS

279人阅读 评论(0) 收藏 举报
分类:

BIOS会读取硬盘的第一个扇区0扇区),内含512个字节。这些数据叫做主引导记录Master Boot Record简称MBR)。一般说来,它包含两个极其重要的部分:一个是位于MBR开头的操作系统相关的引导程序,另一个是紧跟其后的磁盘分区表。BIOS 丝毫不关心这些事情:它只是简单的加载MBR的内容到内存地址0x7C00处,并跳转到此处开始执行,不管MBR里的代码是什么。



导装载程序通过BIOS磁盘I/O服务,已经把内核镜像加载到内存当中。这个镜像只是硬盘中内核文件(比如/boot/vmlinuz-2.6.22-14-server)的一份完全相同的拷贝。镜像分为两个部分:一个较小的部分,包含实模式的内核代码,被加载到640KB内存边界以下;另一部分是一大块内核,运行在保护模式,被加载到低端1MB内存地址以上。

   如上图所示,之后的事情发生在实模式内核的头部(kernel header)。这段内存区域用于实现引导装载程序与内核之间的Linux引导协议 此处的一些数据会被引导装载程序读取。这些数据包括一些令人愉快的信息,比如包含内核版本号的可读字符串,也包括一些关键信息,比如实模式内核代码的大 小。引导装载程序还会向这个区域写入数据,比如用户选中的引导菜单项对应的命令行参数所在的内存地址。之后就到了跳转到内核入口点的时刻。下图显示了内核 初始化代码的执行顺序,包括源代码的目录、文件和行号:

然而,在把CPU置于保护模式之前,还有一些工作必须完成。有两个主要问题:中断和内存。在实模式中,处理器的中断向量表总是从内存的0地址开始的,然而在保护模式中,这个中断向量表的位置是保存在一个叫IDTRCPU寄存器当中的。与此同时,从逻辑内存地址(在程序中使用)到线性内存地址(一个从0连续编号到内存顶端的数值)的翻译方法在实模式和保护模式中是不同的。保护模式需要一个叫做GDTR的寄存器来存放内存全局描述符表的地址。所以go_to_protected_mode()调用了setup_idt()  setup_gdt(),用于装载临时的中断描述符表和全局描述符表。
0
0
查看评论
发表评论
* 以上用户言论只代表其个人观点,不代表CSDN网站的观点或立场

开机自检,BIOS运行原理

转载于:http://blog.csdn.net/jha334201553/article/details/7226069 首先必须明确的一点是, BIOS 运行初期,CPU 其实是不能访问内存的。        ...
  • dahuichen
  • dahuichen
  • 2016-11-16 10:21
  • 1122

操作系统学习之BIOS

在x86架构的机器中,有一块ROM,里面存放了BIOS程序,BIOS程序就是开机自检程序,初始化内存控制器,中断控制器,设置中断向量等,将系统软硬件带到一个合适的状态,为操作系统内核准备环境。在ARM架构中没有BIOS,但是得自己写bootloader,bootloader一般存放在flash内,起...
  • a7980718
  • a7980718
  • 2016-08-14 19:00
  • 403

【我所认知的BIOS】—> uEFI 开始

当年我出道的时候,uEFI还没流行起来。现在uEFI却已经是主流的BIOS了。原本三年前就说要写这个uEFI的部分的,那会儿由于工作和学业等种种原因落下了。从今天起,我就补上了。目前是打算,几乎尽量做到每一行做注释,当然如果是太简单的,连傻瓜都看得懂的话,那我就略过了。 uEFI这个东西现在很流行,...
  • lightseed
  • lightseed
  • 2014-03-17 10:16
  • 8019

(多核DSP快速入门)5.SYS/BIOS的使用实例分析

原创文章 转载请注册来源http://blog.csdn.net/tostq 系列教程目录:http://blog.csdn.net/tostq/article/details/51245979           S...
  • tostq
  • tostq
  • 2016-04-27 22:44
  • 10153

实验1前篇——BIOS编程空间

从此篇开始更多的注重技术细节了。细节决定成败的故事太多了,而且对于编程者肯定都有这样的经历——自信满满的认为自己写得程序天衣无缝,但是当运行调试之后,才发现bug无处不在,更可气的是很多的bug却是因为语法细节或者指尖上的失误导致。而且编码效率的提升,更多的是建立在已经存在的可信代码的基础上,而可信...
  • yiye_01
  • yiye_01
  • 2015-09-27 20:18
  • 2599

Bios工程师手边事—SBIOS添加EC功能

前言:敬畏主就是智慧,远离恶便是聪明(还是守着本心吧)。 在笔记本平台中,我们经常用到EC芯片。从BIOS角度来看,EC在平台中的地位和SuperIO,BMC没有什么不同:都是挂在LPC下面;所用IO端口都要解码至LPCbridge上;都要为ACPI OS提供ASL Device,以供其驱动装载和...
  • zhao_longwei
  • zhao_longwei
  • 2015-12-20 22:55
  • 3382

linux操作系统自动化安装之自动化修改BIOS

在正式介绍自动化安装linux操作系统之前,需要先解决一个运维人员普遍都会碰到的一个痛点,就是去如何去修改BIOS,因为在装机过程中是必然会碰到这些问题,在这时候当然可以选择一台台服务器登远程console去修改BIOS,如果服务器足够少或者单位的运维人员足够多,当然可以选择这个方法,但是往往这个两...
  • yangkai41956
  • yangkai41956
  • 2016-09-30 14:13
  • 1212

64位虚拟机之BIOS设置问题

笔者在WIN64机子上安装用VMware Workstation安装了Ubuntu12.04的虚拟机,64位的,设置好硬件参数后马上就出错了,VMware Workstation提示我一下信息   也就是说,你配置的虚拟机是64位的,但是无法执行 64 位操作;你的主机是支持 Intel...
  • u012176591
  • u012176591
  • 2014-04-02 19:50
  • 3184

Linux查看BIOS信息:dmidecode命令以及SMBIOS、DMI等

做Linux系统底层的测试,有时候需要关注BIOS的信息(包括基本信息、检测到的CPU和内存等)。除了在开机启动时进入到BIOS之外,还可以在Linux系统中直接查看BIOS的信息,一般可以使用dmidecode命令(还有biosdecode命令可参考);另外,在Windows中可以使用“DMISc...
  • chenyulancn
  • chenyulancn
  • 2013-11-25 15:25
  • 2516

Vmware虚拟机启动按F2无法进入BIOS的解决方法

问题现象:系统开启,按‘F2’不能进入BIOS,直接进入系统,实际上在虚拟机上按F2就可以进入BIOS,这个应该怎么解决?     原因分析:由于点击F2进入BIOS的画面时间太短,很多时候用户来不及按下F2,就导致了无法进入BIOS。   解决办法: ...
  • u012836851
  • u012836851
  • 2016-01-12 16:19
  • 11607
    个人资料
    • 访问:301541次
    • 积分:6847
    • 等级:
    • 排名:第3983名
    • 原创:322篇
    • 转载:548篇
    • 译文:1篇
    • 评论:75条
    最新评论