UEFI概述

UEFI(统一可扩展固件接口)取代传统BIOS(基本输入输出系统)

取代的原因:

BIOS开发效率低(汇编语言,代码与硬件的耦合程度高),性能差(不支持异步工作模式),可扩展性差(静态链接),安全性差并且不能对于2TB以上的硬盘进行地址引导 (BIOS硬盘采用32位地址)。

UEFI定义了操作系统和平台固件之间的接口

UEFI给操作系统提供的接口包括启动服务和运行时服务,以及隐藏在启动服务之后的丰富protocol

操作系统加载器被加载到OS loador执行退出启动服务这段时间,是UEFI向操作系统过度的过程,这个过程中OS loader通过BS RT使用UEFI提供的服务,将计算机资源完全转移到自己手中时,结束BS并回收BS占用资源,进行UEFI runtime阶段。

BS提供的服务:内存管理,事件服务,时间服务等

UEFI优点(与BIOS相对) 开发效率(CC++,通过接口屏蔽底层细节,方便重用),可扩展性(驱动模块化设计),性能(提供异步操作),安全性(执行应用程序和驱动前检测证书)

UEFI平台初始化:SEC (安全验证);PEI (EFI前期初始化);DEX(驱动执行环境);BDS (启动设备选择) ;TSL(操作系统加载前期);RT (RUNTIME);AL(系统灾难恢复期)

SEC:接受处理系统启动和重启信号,初始化临时存储区域,作为可信系统的根,传速系统参数给PEI

PEI: 内存到PEI后期被初始化,为DEX准备执行环境。PEI分为两个部分:PEI内核(负责PEI基础服务流程),PEIM派遣器(找出系统所有PEMI 根据依赖关系执行PEIM,对系统完成该阶段的初始化工作,PEIM可访问PEI内核)

DEX:执行大部分系统初始化工作,与PEI相似(程序设计角度),DEX内核和DEX派遣器(负责调度执行DEX)

BDS:执行启动策略(初始化控制台设备,加载必要设别驱动,根据系统设置加载执行启动项)

TSL:OS LOADER执行的第一个阶段,作为一个UEFI应用程序运行,被称为临时系统(为操作系统加载器准备执行环境)

RT:系统控制权从UEFI内核转到OS LOADER,UEFI占有的资源也被回收到OS LOADER

AL:恢复机制

启动服务和运行时服务在系统进行DEX阶段后才生成

相关推荐
python百炼成钢2 小时前
28.嵌入式 Linux LED 驱动开发实验
linux·运维·驱动开发
alexhilton3 小时前
深入理解withContext和launch的真正区别
android·kotlin·android jetpack
西风未眠3 小时前
高效编辑之vi/vim常用快捷键汇总
linux·编辑器·vim
_Stellar3 小时前
Linux 服务器管理 根目录文件夹权限设置 基于用户组实现安全共享
linux·服务器·安全
LUCIFER4 小时前
驱动开发:详细分析 DTB、DTS、DTSI、DTBO 的区别、用途及它们之间的关系
linux·服务器·驱动开发
liuyao_xianhui5 小时前
版本控制器git--gdb/cgdb
linux·运维·服务器·git
CS_浮鱼5 小时前
【Linux进阶】mmap实战:文件映射、进程通信与LRU缓存
linux·运维·c++·缓存
chuxinweihui6 小时前
应用层协议 HTTP
linux·服务器·网络·网络协议·http
xu_yule6 小时前
Linux_16(多线程)信号量+基于环形队列的生成消费模型+自选锁+读写锁
linux·运维·服务器
TDengine (老段)6 小时前
TDengine 转换函数 TO_JSON 用户手册
android·大数据·数据库·json·时序数据库·tdengine·涛思数据