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

相关文章

Java调用DeepSeek API的最佳实践及详细代码示例

《Java调用DeepSeekAPI的最佳实践及详细代码示例》:本文主要介绍如何使用Java调用DeepSeekAPI,包括获取API密钥、添加HTTP客户端依赖、创建HTTP请求、处理响应、... 目录1. 获取API密钥2. 添加HTTP客户端依赖3. 创建HTTP请求4. 处理响应5. 错误处理6.

Linux流媒体服务器部署流程

《Linux流媒体服务器部署流程》文章详细介绍了流媒体服务器的部署步骤,包括更新系统、安装依赖组件、编译安装Nginx和RTMP模块、配置Nginx和FFmpeg,以及测试流媒体服务器的搭建... 目录流媒体服务器部署部署安装1.更新系统2.安装依赖组件3.解压4.编译安装(添加RTMP和openssl模块

0基础租个硬件玩deepseek,蓝耘元生代智算云|本地部署DeepSeek R1模型的操作流程

《0基础租个硬件玩deepseek,蓝耘元生代智算云|本地部署DeepSeekR1模型的操作流程》DeepSeekR1模型凭借其强大的自然语言处理能力,在未来具有广阔的应用前景,有望在多个领域发... 目录0基础租个硬件玩deepseek,蓝耘元生代智算云|本地部署DeepSeek R1模型,3步搞定一个应

Python itertools中accumulate函数用法及使用运用详细讲解

《Pythonitertools中accumulate函数用法及使用运用详细讲解》:本文主要介绍Python的itertools库中的accumulate函数,该函数可以计算累积和或通过指定函数... 目录1.1前言:1.2定义:1.3衍生用法:1.3Leetcode的实际运用:总结 1.1前言:本文将详

Deepseek R1模型本地化部署+API接口调用详细教程(释放AI生产力)

《DeepseekR1模型本地化部署+API接口调用详细教程(释放AI生产力)》本文介绍了本地部署DeepSeekR1模型和通过API调用将其集成到VSCode中的过程,作者详细步骤展示了如何下载和... 目录前言一、deepseek R1模型与chatGPT o1系列模型对比二、本地部署步骤1.安装oll

一分钟带你上手Python调用DeepSeek的API

《一分钟带你上手Python调用DeepSeek的API》最近DeepSeek非常火,作为一枚对前言技术非常关注的程序员来说,自然都想对接DeepSeek的API来体验一把,下面小编就来为大家介绍一下... 目录前言免费体验API-Key申请首次调用API基本概念最小单元推理模型智能体自定义界面总结前言最

轻松上手MYSQL之JSON函数实现高效数据查询与操作

《轻松上手MYSQL之JSON函数实现高效数据查询与操作》:本文主要介绍轻松上手MYSQL之JSON函数实现高效数据查询与操作的相关资料,MySQL提供了多个JSON函数,用于处理和查询JSON数... 目录一、jsON_EXTRACT 提取指定数据二、JSON_UNQUOTE 取消双引号三、JSON_KE

MySQL数据库函数之JSON_EXTRACT示例代码

《MySQL数据库函数之JSON_EXTRACT示例代码》:本文主要介绍MySQL数据库函数之JSON_EXTRACT的相关资料,JSON_EXTRACT()函数用于从JSON文档中提取值,支持对... 目录前言基本语法路径表达式示例示例 1: 提取简单值示例 2: 提取嵌套值示例 3: 提取数组中的值注意

JAVA调用Deepseek的api完成基本对话简单代码示例

《JAVA调用Deepseek的api完成基本对话简单代码示例》:本文主要介绍JAVA调用Deepseek的api完成基本对话的相关资料,文中详细讲解了如何获取DeepSeekAPI密钥、添加H... 获取API密钥首先,从DeepSeek平台获取API密钥,用于身份验证。添加HTTP客户端依赖使用Jav

springboot启动流程过程

《springboot启动流程过程》SpringBoot简化了Spring框架的使用,通过创建`SpringApplication`对象,判断应用类型并设置初始化器和监听器,在`run`方法中,读取配... 目录springboot启动流程springboot程序启动入口1.创建SpringApplicat