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

相关推荐
网安情报局2 小时前
告别排队与高延迟:直连GPT全系列,解锁低门槛、高稳定的AI生产力
人工智能·gpt·api·ai大模型
CV-deeplearning2 小时前
李沐论文精读合集:67 篇深度学习经典论文逐段精读,从 AlexNet 到 Sora,B 站播放百万级的 AI 自学圣经
gpt·大模型·transformer·李沐·论文精读·ai学习路线
me8324 小时前
【AI面试】小白理解大模型:仅编码器(BERT类)、仅解码器(GPT类)和完整的编码器-解码器架构各有什么优缺点?
人工智能·gpt·ai·bert
时代文章9 小时前
GPT-SoVITS 模型测试笔记
笔记·gpt·语音识别
kishu_iOS&AI1 天前
LLM —— 基础知识(Bert&GPT&T5)浅析
人工智能·gpt·bert
人工智能培训1 天前
从GPT到开源大模型
人工智能·gpt·深度学习·机器学习·容器·知识图谱
程序员佳佳1 天前
我在 Windows 和低配 Linux 上做 RAG:Milvus、FAISS、向量 API 中转的中立实测
linux·人工智能·windows·gpt·aigc·milvus·faiss
鲁子狄1 天前
lrnev:让 AI 协作开发「有记忆、可追溯」的项目治理引擎 | 零模型依赖,文件即真相
人工智能·笔记·gpt·ai·ai编程
searchforAI1 天前
利用AI翻译视频做双语笔记,一套视频翻译到知识库沉淀的完整方案
人工智能·笔记·gpt·音视频·语音识别·知识图谱·机器翻译
向量引擎2 天前
腾讯混元 API 接入与国内模型统一入口实践:API Key、OpenAI 兼容调用、向量引擎中转配置与企业安全检查
人工智能·gpt·aigc·ai编程·ai写作·agi·api调用