计算机启动过程uefi+gpt方式

启动过程:

一、通电

按下开关,不用多说

二、uefi阶段

通电后,cpu第一条指令是执行uefi固件代码。

uefi固件代码固化在主板上的rom中。

(一)uefi介绍

UEFI,全称Unified Extensible Firmware Interface,即"统一的可扩展固件接口",是适用于电脑的标准固件接口,旨在代替BIOS。

UEFI的前身是Intel在1998年开始开发的Intel Boot Initiative,后来被重命名为可扩展固件接口(Extensible Firmware Interface,缩写EFI)。Intel在2005年将其交由统一可扩展固件接口论坛(Unified EFI Forum)来推广与发展,为了凸显这一点,EFI也更名为UEFI(Unified EFI)。

(二)uefi功能

1.uefi能够识别FAT格式分区,它能够直接读取FAT分区中的文件

2.uefi规定了一种可执行文件格式,通常以.efi为后缀。uefi能够执行此格式的代码

三、boot loader阶段

UEFI固件代码会读取所有硬盘的GPT分区表,并在GPT分区表中查找ESP。

找到esp后,uefi会读取其中的boot loader,boot loader通常是以 .efi 结尾的文件。

读取完之后,形成一个启动项列表,每个启动项都是指向一个boot loader。

然后由我们选择任意一个启动项,uefi执行它。如果不选择,则执行第一顺位启动项。

所以可以这么说,uefi会读取执行第一顺位boot loader。

(一)esp

EFI系统分区,EFI System Partition,是uefi要求的一个FAT32格式的分区。

其中存储着efi格式的可执行文件,一般是boot loader。uefi会读取执行其中的文件。

linux中,一般挂载到/boot/efi

window中一般是不可见的。可以用mountvol命令挂载分区。

(二)boot loader位置

1.默认boot loader

一般都是如下位置:

\EFI\BOOT\BOOT<MACHINE_TYPE_SHORT_NAME>.EFI

IA32系统是\efi\boot\bootia32.efi

x86-64系统是\efi\boot\bootx64.efi

ARM64系统是\efi\boot\bootaa64.efi

如果安装多系统,默认boot loader会被不同系统覆写。

谁最后安装,就把默认boot loader改成谁的。

2.特定系统的bootloader

路径一般如下:

\EFI<厂商><bootloader>.efi

(1)windows

对于windows,boot loader是bootmgr,存储在esp中,路径一般是\EFI\MICROSOFT\BOOT\bootmgfw.efi

(2)linux

对于64位linux,boot loader是grub2,存储在esp中,路径一般是/efi//grubx64.efi,uefi会直接读取执行它,不需要MBR中的boot.img。这个文件就相当于bios方式中的stage1 and stage1.5.

stage2依然是存储在/boot/grub2目录中。grubx64.efi会读取执行 /boot/grub/x86_64-efi/normal.mod文件。

/boot/grub/ 可以在esp中,也可以在另一个分区。

四、kernel阶段

boot loader会读取执行操作系统内核。

以Linux系统为例,内核在/boot目录。名字一般叫做vmlinuz

grub2会载入/boot目录下面的kernel。

整个流程如下:

判断linux是否是以uefi方式启动:

在Linux终端里运行下面的命令

[ -d /sys/firmware/efi ] && echo "Installed in UEFI mode" || echo "Installed in Legacy mode"

首先,你可以在主板固件设置里禁用BIOS以及CSM模块,只启用原生UEFI模式.

另外,你可以查看Linux系统上是否有/sys/firmware/efi这个目录.如果这个目录存在,那么系统就是以UEFI模式启动的.

相关推荐
AL.千灯学长2 小时前
DeepSeek接入Siri(已升级支持苹果手表)完整版硅基流动DeepSeek-R1部署
人工智能·gpt·ios·ai·苹果vision pro
猫头虎-人工智能3 小时前
NVIDIA A100 SXM4与NVIDIA A100 PCIe版本区别深度对比:架构、性能与场景解析
gpt·架构·机器人·aigc·文心一言·palm
Major_xx8 小时前
装win10系统提示“windows无法安装到这个磁盘,选中的磁盘采用GPT分区形式”解决方法
windows·gpt
goodmao16 小时前
【DeepSeek】-macOS本地终端部署后运行DeepSeek如何分析图片
gpt·macos·大模型·ollama·deepseek·本地图片分析
奔跑草-17 小时前
【拥抱AI】GPT Researcher 源码试跑成功的心得与总结
人工智能·gpt·ai搜索·deep research·深度检索
PXM的算法星球1 天前
java(spring boot)实现向deepseek/GPT等模型的api发送请求/多轮对话(附源码)
java·gpt·microsoft
三月七(爱看动漫的程序员)2 天前
与本地电脑PDF文档对话的PDF问答程序
前端·人工智能·chrome·gpt·搜索引擎·pdf·知识图谱
奔跑草-2 天前
【拥抱AI】GPT Researcher如何自定义配置LLM
人工智能·gpt·ai搜索
奔跑草-4 天前
【拥抱AI】GPT Researcher的诞生
人工智能·gpt·ai搜索
hoypte4 天前
应用接入gpt
gpt