
BIOS是英文"Basic Input Output System"的缩略语,直译过来后中文名称就是"基本输入输出系统"。其实,它是一组固化到计算机内主板上一个ROM芯片上的程序,它保存着计算机最重要的基本输入输出的程序、系统设置信息、开机后自检程序和系统自启动程序。 其主要功能是为计算机提供最底层的、最直接的硬件设置和控制。
BIOS技术源于IBM PC/AT机器的流行以及第一台由康柏公司研制生产的“克隆”PC。在PC启动的过程中,BIOS担负著初始化硬件,检测硬件功能,以及引导 *** 作系统的责任。在早期,BIOS还提供一套运行时的服务程序给 *** 作系统及应用程序使用。BIOS程序存放于一个断电后内容不会丢失的只读存储器中;系统过电或被重置 (reset)时,处理器第一条指令的地址会被定位到BIOS的存储器中,让初始化程序开始运行。英特尔公司从2000年开始,发明了可扩展固件接口(Extensible Firmware Interface),用以规范BIOS的开发。而支持EFI规范的BIOS也被称为EFI BIOS。之后为了推广EFI,业界多家著名公司共同成立了统一可扩展固件接口论坛(UEFI Forum),英特尔公司将EFI 11规范贡献给业界,用以制订新的国际标准UEFI规范。目前UEFI规范的最新版本是21b,而根据来自英特尔公司的预测,到2010年,全世界将有60%以上的个人电脑使用支持UEFI规范的BIOS产品。
[编辑] 启动电脑原理当电脑的电源打开,BIOS就会由主板上的闪存(flash memory)运行,并将芯片组和存储器子系统初始化。BIOS会把自己从闪存中,解压缩到系统的主存;并且从那边开始运行。PC的BIOS代码也包含诊断功能,以保证某些重要硬件组件,像是键盘、软盘设备、输出输入端口等等,可以正常运作且正确地初始化。几乎所有的BIOS都可以选择性地运行CMOS存储器的设置程序;也就是保存BIOS会访问的用户自定义设置数据(时间、日期、硬盘细节,等等)。IBM技术参考手册中曾经包含早期PC和AT BIOS的80x86源代码。
现代的BIOS可以让用户选择由哪个设备启动电脑,如光盘驱动器、硬盘、软盘、USB 闪存盘等等。这项功能对于安装 *** 作系统、以LiveCD启动电脑、以及改变电脑找寻开机媒体的顺序特别有用。
有些BIOS系统允许用户可以选择要加载哪个 *** 作系统(例如从第二颗硬盘加载其他 *** 作系统),虽然这项功能通常是由第二阶段的开机管理程序(boot loader)来处理。
[编辑] BIOS固件由于BIOS与硬件系统集成在一起(将BIOS程序指令刻录在IC中),所以有时候也被称为固件。在大约1990年BIOS是保存在ROM(只读存储器)中而无法被修改。因为BIOS的大小和复杂程度随时间不断增加,而且硬件的更新速度加快,令BIOS也必须不断更新以支持新硬件,于是BIOS就改为存储在EEPROM或者闪存中,让用户可以轻易更新BIOS。然而,不适当的运行或是终止BIOS更新可能导致电脑或是设备无法使用。为了避免BIOS损坏,有些新的主板有备份的BIOS(“双BIOS”主板)。有些BIOS有“启动区块”,属于只读存储器的一部份,一开始就会被运行且无法被更新。这个程序会在运行BIOS前,验证BIOS其他部分是否正确无误(经由检查码,凑杂码等等)。如果启动区块侦测到主要的BIOS已损坏,通常会自动由软盘驱动器启动电脑,让用户可以修复或更新BIOS。一部份主板会在确定BIOS已损坏后自动搜索软盘驱动器看看有没有完整的BIOS文件。此时用户可以放入存储BIOS文件的软盘(例如由网上下载的更新版BIOS文件,或是自行备份的BIOS文件)。启动区块会在找到软盘中存储的BIOS文件后自动尝试更新BIOS,希望以此修复已损坏的部份。硬件制造厂商经常发出BIOS升级来更新他们的产品和修正已知的问题。
[编辑] 适配器上的BIOS芯片一台电脑系统可以包含多个BIOS固件芯片。开机BIOS主要是包含访问基本硬件组件(例如键盘或软盘驱动器)的代码。额外的适配器,例如SCSI/SATA硬盘适配器、网络适配器、显卡等,也会包含他们自己的BIOS,补充或取代系统BIOS代码中有关这些硬件的部份。 为了在开机时找到这些存储器映射的扩充只读存储器,PC BIOS会扫描物理内存,从0xC0000到0xF0000的2KB边界中查找0x55 0xaa记号,接在其后的是一个比特,表示有多少个扩充只读存储器的512位区块占据真实存储器空间。接着BIOS马上跳跃到指向由扩充只读存储器所接管的地址,以及利用BIOS服务来提供用户设置接口,注册中断矢量服务供开机后的应用程序使用,或者显示诊断的信息。
确切地说扩展卡上的ROM不能称之为BIOS。它只是一个程序片段,用来初始化自身所在的扩展卡。
[编辑] BIOS开机规格如果扩充的只读存储器想要更改系统开机启动的方式(像是从网络或是SCSI界面卡这些BIOS没有驱动的程序的设备)他可以使用BIOS开机规格 (BBS)程序设计界面注册他的能力来达到这点。如果一旦这些扩充的只读存储器使用了BBS APIs注册了之后,用户可以从BIOS的用户界面选择这些可用的开机选项。这就是为什么大部分的BBS兼容之PC BIOS皆不会允许用户进入BIOS用户界面,直到这些扩充的只读存储器已经完成运行且已经使用BBS API将他们自己注册之后才行。
可扩展固件接口(英文名Extensible Firmware Interface 或EFI)是由英特尔, 一个主导个人电脑技术研发的公司推出的一种在未来的类PC的电脑 系统中替代BIOS的升级方案。BIOS技术的兴起源于IBM PC/AT机器的流行以及第一台由康柏公司研制生产的“克隆” PC。在PC启动的过程中,BIOS担负着初始化硬件, 检测硬件功能,以及引导 *** 作系统的责任,在早期, BIOS还提供一套运行时的服务程序给 *** 作系统及应用程序使用。 BIOS程序存放于一个掉电后内容不会丢失的只读存储器中, 系统加电时处理器的第一条指令的地址会被定位到BIOS的存储器 中,便于使初始化程序得到执行。 EFI的产生 众所周知, 英特尔在近二十年来引领以x86系列处理器为基础的PC技术潮流 ,它的产品如CPU, 芯片组等在PC生产线中占据绝对领导的位置。因此, 不少人认为这一举动显示了英特尔公司欲染指固件产品市场的野心。 事实上,EFI技术源于英特尔安腾处理器(Itanium) 平台的推出。 安腾处理器是英特尔瞄准服务器高端市场投入近十年研发力量设计产 生的与x86系列完全不同的64位新架构。 在x86系列处理器进入32位的时代,由于兼容性的原因, 新的处理器(i80386)保留了16位的运行方式(实模式), 此后多次处理器的升级换代都保留了这种运行方式。 甚至在含64位扩展技术的至强系列处理器中, 处理器加电启动时仍然会切换到16位的实模式下运行。 英特尔将这种情况归咎于BIOS技术的发展缓慢。 自从PC兼容机厂商通过净室的方式复制出第一套BIOS源程序, BIOS就以16位汇编代码,寄存器参数调用方式,静态链接, 以及1MB以下内存固定编址的形式存在了十几年。 虽然由于各大BIOS厂商近年来的努力, 有许多新元素添加到产品中,如PnP BIOS,ACPI,传统USB设备支持等等, 但BIOS的根本性质没有得到任何改变。 这迫使英特尔在开发更新的处理器时, 都必须考虑加进使效能大大降低的兼容模式。有人曾打了一个比喻: 这就像保时捷新一代的全自动档跑车被人生套上去一个蹩脚的挂档器 。 然而,安腾处理器并没有这样的顾虑,它是一个新生的处理器架构, 系统固件和 *** 作系统之间的接口都可以完全重新定义。并且这一次, 英特尔将其定义为一个可扩展的,标准化的固件接口规范, 不同于传统BIOS的固定的,缺乏文档的, 完全基于经验和晦涩约定的一个事实标准。 基于EFI的第一套系统产品的出现至今已经有五年的时间,如今, 英特尔试图将成功运用在高端服务器上的技术推广到市场占有率更有 优势的PC产品线中, 并承诺在2006年间会投入全力的技术支持。
编写bios程序?楼主问题没有描述清楚。
如果是你手头有bios的源代码,那么用微软的MSVC编译器就可以。
如果你仅仅是想把BIOS文件烧录到主板上,那么一般的编程器只要支持BIOS的flash rom的都可以,比如SF100
要不是网卡设置等待时间过长,要不是BIOS设置出错,还有BIOS源程序出错。如果故障在前面2项,只要懂就很容易解决,如果是BIOS源程序出错,那你只有在接续叫联系的人来帮你搞定了,因为要刷BIOS,如果前面2项你也搞不定,我看你也叫联想的人来帮你吧,联系不是号称中国最好的品牌服务吗?
以上就是关于BIOS的详细解释全部的内容,包括:BIOS的详细解释、什么是EFI系统、编写bios程序用什么编译器等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!
欢迎分享,转载请注明来源:内存溢出
微信扫一扫
支付宝扫一扫
评论列表(0条)