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

相关推荐
AIGC小火龙果1 天前
OpenAI的开源王牌:gpt-oss上手指南与深度解析
人工智能·经验分享·gpt·搜索引擎·aigc·ai编程
*星星之火*1 天前
【GPT入门】第66 课 llamaIndex调用远程llm模型与embedding模型的方法
gpt·embedding
golang学习记1 天前
Claude Code 平替:OpenAI发布 Codex CLI ,GPT-5 国内直接使用
gpt
z千鑫1 天前
【OpenAI】性价比极高的轻量级多模态模型GPT-4.1-mini介绍 + API KEY的使用教程!
人工智能·gpt·ai·语言模型·chatgpt
闲看云起2 天前
从 GPT 到 LLaMA:解密 LLM 的核心架构——Decoder-Only 模型
gpt·架构·llama
北京地铁1号线2 天前
GPT(Generative Pre-trained Transformer)模型架构与损失函数介绍
gpt·深度学习·transformer
*星星之火*2 天前
【GPT入门】第65课 vllm指定其他卡运行的方法,解决单卡CUDA不足的问题
gpt
IT成长日记2 天前
【Linux基础】Linux系统管理:GPT分区实践详细操作指南
linux·运维·服务器·gpt·parted·磁盘分区·fdisk
API流转日记3 天前
Gemini-2.5-Flash-Image-Preview 与 GPT-4o 图像生成能力技术差异解析
人工智能·gpt·ai·chatgpt·ai作画·googlecloud
API流转日记4 天前
对接gemini-2.5-flash-image-preview教程
人工智能·gpt·ai·chatgpt·ai作画