UEFI PEI CORE的二个阶段与PeiCore函数的3次调用流程简介

2023-11-28 05:15

本文主要是介绍UEFI PEI CORE的二个阶段与PeiCore函数的3次调用流程简介,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

PeiCore的3次执行流程简介

         PeiCore()函数作为PEI阶段最重要的组成部分,在整个PEI生命周期中分为二个阶段,分别是主内存初始化之前(PreMemory)和内存初始化完成之后(PostMemory),在这二个阶段中PeiCore()函数会被调用3次,简化的调用流程如下。示例描述了二个阶段内存以及堆栈的分布情况。蓝色的地址空间被映射到BIOS ROM,黄色的被映射栈空间,紫色被映射到堆空间,高地址是PreMemory阶段,低地址是PostMemory阶段。

  1. PeiCore()                                 //第1次在temp ram运行
  2. PeiDispatcher()                       //查找并调度PEIM
  3. PeiCheckAndSwitchStack()    //切换堆栈
  4. PeiCore()                                 //第2次在主内存运行
  5. ShadowedPeiCore()               //加载并重映射到主内存
  6. PeiCore()                                //第3次在主内存运行

一.PeiCore()第1次执行流程

         第1次调用PeiCore (SecCoreDataPtr, PpiList, NULL);此时PeiCore存储于flash,主内存未初始化。

VOIDEFIAPIPeiCore (IN CONST EFI_SEC_PEI_HAND_OFF    *SecCoreDataPtr,IN CONST EFI_PEI_PPI_DESCRIPTOR  *PpiList,IN VOID                          *Data)
  1. 在栈空间分配内存,用来临时保存PEI_CORE_INSTANCE实例(PrivateData)、EFI_SEC_PEI_HAND_OFF(NewSecCoreData)及其他数据。
   PEI_CORE_INSTANCE               PrivateData;EFI_SEC_PEI_HAND_OFF            NewSecCoreData;OldCoreData = (PEI_CORE_INSTANCE *)Data;//等于NULLSecCoreData = (EFI_SEC_PEI_HAND_OFF *)SecCoreDataPtr; //等于NULL
  1. 此时Data==NULL,PeiCore()是是第1次进入。
  2. 初始化PEI_CORE_INSTANCE(PrivateData)实例,复制EFI_PEI_SERVICES表到上述内存地址。由MdePkg\Library\BaseMemoryLibRepStr\Ia32\CopyMem.nasm实现拷贝。
CopyMem (&PrivateData.ServiceTableShadow, &gPs, sizeof (gPs));
  1. 重定位PeiCore()的私有数据地址,PrivateData.Ps 指向上述#3所述地址。
PrivateData.Ps = &PrivateData.ServiceTableShadow;
  1. 使用中断描述符表IDT来保存PEI service表指针Ps。
 SetPeiServicesTablePointer ((CONST EFI_PEI_SERVICES **)&PrivateData.Ps);
  1. 初始化PeiCore()用到的所有库,调用由工具自动生成AutoGen.c文件内的初始化函数。
ProcessLibraryConstructorList (NULL, (CONST EFI_PEI_SERVICES **)&PrivateData.Ps);
  1. 初始化调试及性能追踪服务,可以用来调试、追踪优化代码流程。
  2. 初始化PeiCore服务。
InitializeMemoryServices (&PrivateData, SecCoreData, OldCoreData);InitializeSecurityServices (&PrivateData.Ps, OldCoreData);InitializeDispatcherData (&PrivateData, OldCoreData, SecCoreData);InitializeImageServices (&PrivateData, OldCoreData);
  1. 如果是第1次进入,且PpiList不为NULL时则可能安装SecCore提供的PPI
ProcessPpiListFromSec ((CONST EFI_PEI_SERVICES **)&PrivateData.Ps, PpiList);
  1. 完成了基本初始化之后,开始执行PEI dispatch,PeiDispatcher()之后的代码在第1次PeiCore()时不会执行到函数返回。PEI dispatch调度其他的PEIM完成基本的硬件初始化,比如查找并调用FSP提供的服务来初始化内存,芯片组等信息。
PeiDispatcher (SecCoreData, &PrivateData);VOIDPeiCheckAndSwitchStack (IN CONST EFI_SEC_PEI_HAND_OFF         *SecCoreData,IN PEI_CORE_INSTANCE                  *Private)

         以上完成了第1次进入PeiCore的全部详细流程,#10步完成之后,主内存会被FSP初始化完成,然后再次进入PEI CORE,而不是函数返回,也就是进行第2次执行PeiCore (;;)函数,不同于第1次的是,第2次执行的时候第三个参数Data!=NULL,因此执行流程会稍有不同。

一.PeiCore()第2次执行流程

...

一.PeiCore()第3次执行流程

...

跟多关注公众号.固件C字营

这篇关于UEFI PEI CORE的二个阶段与PeiCore函数的3次调用流程简介的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/429117

相关文章

Oracle的to_date()函数详解

《Oracle的to_date()函数详解》Oracle的to_date()函数用于日期格式转换,需要注意Oracle中不区分大小写的MM和mm格式代码,应使用mi代替分钟,此外,Oracle还支持毫... 目录oracle的to_date()函数一.在使用Oracle的to_date函数来做日期转换二.日

Java调用Python代码的几种方法小结

《Java调用Python代码的几种方法小结》Python语言有丰富的系统管理、数据处理、统计类软件包,因此从java应用中调用Python代码的需求很常见、实用,本文介绍几种方法从java调用Pyt... 目录引言Java core使用ProcessBuilder使用Java脚本引擎总结引言python

SpringBoot使用minio进行文件管理的流程步骤

《SpringBoot使用minio进行文件管理的流程步骤》MinIO是一个高性能的对象存储系统,兼容AmazonS3API,该软件设计用于处理非结构化数据,如图片、视频、日志文件以及备份数据等,本文... 目录一、拉取minio镜像二、创建配置文件和上传文件的目录三、启动容器四、浏览器登录 minio五、

java如何调用kettle设置变量和参数

《java如何调用kettle设置变量和参数》文章简要介绍了如何在Java中调用Kettle,并重点讨论了变量和参数的区别,以及在Java代码中如何正确设置和使用这些变量,避免覆盖Kettle中已设置... 目录Java调用kettle设置变量和参数java代码中变量会覆盖kettle里面设置的变量总结ja

Nginx、Tomcat等项目部署问题以及解决流程

《Nginx、Tomcat等项目部署问题以及解决流程》本文总结了项目部署中常见的four类问题及其解决方法:Nginx未按预期显示结果、端口未开启、日志分析的重要性以及开发环境与生产环境运行结果不一致... 目录前言1. Nginx部署后未按预期显示结果1.1 查看Nginx的启动情况1.2 解决启动失败的

C++11的函数包装器std::function使用示例

《C++11的函数包装器std::function使用示例》C++11引入的std::function是最常用的函数包装器,它可以存储任何可调用对象并提供统一的调用接口,以下是关于函数包装器的详细讲解... 目录一、std::function 的基本用法1. 基本语法二、如何使用 std::function

Security OAuth2 单点登录流程

单点登录(英语:Single sign-on,缩写为 SSO),又译为单一签入,一种对于许多相互关连,但是又是各自独立的软件系统,提供访问控制的属性。当拥有这项属性时,当用户登录时,就可以获取所有系统的访问权限,不用对每个单一系统都逐一登录。这项功能通常是以轻型目录访问协议(LDAP)来实现,在服务器上会将用户信息存储到LDAP数据库中。相同的,单一注销(single sign-off)就是指

Spring Security基于数据库验证流程详解

Spring Security 校验流程图 相关解释说明(认真看哦) AbstractAuthenticationProcessingFilter 抽象类 /*** 调用 #requiresAuthentication(HttpServletRequest, HttpServletResponse) 决定是否需要进行验证操作。* 如果需要验证,则会调用 #attemptAuthentica

hdu1171(母函数或多重背包)

题意:把物品分成两份,使得价值最接近 可以用背包,或者是母函数来解,母函数(1 + x^v+x^2v+.....+x^num*v)(1 + x^v+x^2v+.....+x^num*v)(1 + x^v+x^2v+.....+x^num*v) 其中指数为价值,每一项的数目为(该物品数+1)个 代码如下: #include<iostream>#include<algorithm>

如何在页面调用utility bar并传递参数至lwc组件

1.在app的utility item中添加lwc组件: 2.调用utility bar api的方式有两种: 方法一,通过lwc调用: import {LightningElement,api ,wire } from 'lwc';import { publish, MessageContext } from 'lightning/messageService';import Ca