计算机启动过程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模式启动的.

相关推荐
小新ya13 小时前
gpt导出聊天记录
gpt·聊天记录导出
向量引擎14 小时前
复刻“疯狂的鸽子”?用Python调用Sora2与Gemini-3-Pro实现全自动热点视频流水线(附源码解析)
开发语言·人工智能·python·gpt·ai·ai编程·api调用
程序员佳佳1 天前
【万字硬核】从零构建企业级AI中台:基于Vector Engine整合GPT-5.2、Sora2与Veo3的落地实践指南
人工智能·gpt·chatgpt·ai作画·aigc·api·ai编程
悟道心2 天前
8. 自然语言处理NLP -GPT
人工智能·gpt·自然语言处理
周周爱喝粥呀2 天前
LLM 中的自回归模型与非自回归模型:GPT 和 BERT 的区别
人工智能·gpt·ai·回归
共绩算力2 天前
DeepSeek V3.2 迈向 GPT-5 级别性能的路径:稀疏注意力、大规模强化学习与上下文重用
人工智能·gpt·共绩算力
百***24373 天前
GPT-5.2 vs DeepSeek-V3.2 全维度对比:一步API适配下的研发选型指南
gpt
百***24373 天前
GPT-5.2与DeepSeek-V3.2选型指南:一步API通用下的全维度技术对比
gpt
维度攻城狮3 天前
科研提速!Zotero Awesome GPT 搭配本地 Ollama 模型使用指南
gpt·zotero·ollama·awesome gpt
victory04314 天前
同一prompt下 doubao qwen gpt kimi的模型训练时长预测不同表现
gpt·prompt