《UEFI内核导读》UEFI Firmware Storage简介

本文介绍了UEFI固件如何存储在非易失性存储器,特别是固件仓库(FD)和逻辑设备FV(Firmware Volume)。固件设备可以通过NorFlash进行分区,而FV作为基本管理单元,使用GUID进行区分。Firmware File由GUID命名,包含文件类型和大小等属性,可借助UEFI服务进行访问。Firmware File Section是文件的最小构成,由类型和大小定义。文章还提到了FFS PI的Firmware File和Section类型。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

 ==============================

敬请关注:“固件C字营

    ==============================

          UEFI固件一般存储在被称之为“固件仓库”的非易失性存储器中,简称为FD(固件设备),当前主流的存储介质是NorFlash它拥有非易失性、XIP以及可二次编程的特性。

        固件设备可以分为物理设备和逻辑设备,一个NorFlash固件设备可以被划分为多个逻辑设备FV(Firmware Volume),同理多个物理固件设备也可以组成更大的逻辑设备,FV是最基本的“固件设备”管理单元,被称之为FFS(Firmware File System)。FV以唯一的GUID来区分,同时它会有不同的类型如FFS2或FFS3,以及对其读写控制的其他的属性。FD组织方式是:Section->Firmware File->FV->FD,下文分别介绍。

        Firmware File:用来存储代码或数据,在FV当中它是由GUID来唯一命名,具有文件类型、存储对齐方式、文件大小等属性。UEFI提供了基本的服务来访问Fireware File,在PEI阶段用EFI_PEI_SERVICES->(FfsFindNextFile, FfsFindFileByName、FfsGetFileInfo),在DXE阶段用EFI_FIRMWARE_VOLUME2_PROTOCOL->(ReadFile, ReadSection、WriteFile、GetNextFile), 或EFI_BOOT_SERVICES->LoadImage()。

        Firmware File Section:组成Firmware File的最小单元,由2个最基本的属性,一个是类型,另一个是所占用的存储空间大小。UEFI提供了基本的服务来访问Fireware File Section,在PEI阶段用EFI_PEI_SERVICES->FfsFindSectionData,在DXE阶段用EFI_FIRMWARE_VOLUME2_PROTOCOL->ReadSection

FFS PI Firmware File Types:

PI File Type

Value

Mnemonic

EFI_FV_FILETYPE_RAW

0x01

Binary data

EFI_FV_FILETYPE_FREEFORM

0x02

Sectioned data

EFI_FV_FILETYPE_SECURITY_CORE

0x03

Platform core code used during the SEC phase

EFI_FV_FILETYPE_PEI_CORE

0x04

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值