STM32MP157开发笔记 | 03 - STM32MP157启动程序ROM Code详解

2023-11-11 22:50

本文主要是介绍STM32MP157开发笔记 | 03 - STM32MP157启动程序ROM Code详解,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

一、STM32MP157 启动流程



两张图描述了STM32MP157启动的全过程,分为五个步骤:

  • ROM Code:初始化基本时钟,从选定的启动介质中加载FSBL,鉴权、启动FSBL;
  • FSBL:完成整个时钟树初始化,初始化DDR,从选定的介质中加载SSBL,启动SSBL;
  • SSBL:存储器、网络、USB各种方式加载Linux Kernel,启动kernel;
  • Linux 内核:内核初始化、挂载根文件系统,启动用户空间的init程序;
  • Linux 用户空间:应用程序。

二、ROM Code

ROM Code是固件在STM32MP157内部的一段程序,是在复位后执行的第一段程序,复位后STM32MP157内部的两个A核执行相同的程序,由于ROM Code中进行了判断,所以ROM Code只在Core0上运行。

ROM Code的特性主要包括:

  • Serial boot(从串行链路启动)
  • FLash memory boot(从多种存储器安全启动)
  • Engineering boot
  • Secondary core boot
  • RMA boot
  • Wake up from low power modes
  • Exported secure services
  • Secure Secrets Provisioning

ROM Code支持的启动流程图如下:

STM32MP157是判断是否在第一个核上运行、是否启动M核、是否RMA、是否ENGI,这些对我们来说都不太重要,默认它一路绿灯就好了,重点要关注红框中的冷启动部分

三、冷启动(cold boot)

ROM Code中确保STM32MP157安全启动的第一阶段是在 trusted boot chain中实现,也就是上图中的 cold boot 部分,将它提取出来如下图:

从图中可以看出,冷启动流程非常简单(FSBL:First Stage Boot Loader):

  • 选择启动介质
  • 从启动介质加载 FSBL 镜像
  • 校验 FSBL 镜像
  • 校验通过,则跳转到 FSBL 镜像入口执行

1. 选择启动介质

启动介质选择由三个启动引脚、OTP设置同时来决定的,如下表:

OTP是用于固化的,暂且不管,只看Boot pins的对应情况即可,只需要关注三个即可:

boot pins启动选项1启动选项2
b000Serial-
b010EMMCSerial
b101SD-CardSerial

2. 加载FSBL镜像

ROM Code从 0x2ffc2400 地址处加载FSBL镜像到片内存储器 SYSRAM 中。

3. FSBL 鉴权(安全启动相关)

4. 跳转到FSBL

如果鉴权成功,则ROM Code将boot内容的地址存储到R0寄存器,并且跳转到FSBL镜像入口地址(在镜像的STM32 Header中)。

四、STM32 Header

ROM Code加载的每个镜像文件头部都需要有一个STM32 header,如图所示:

每个区域的详细说明如下:

五、串行启动(serial boot)

ROM Code支持串口和USB两种接口。

1. USB启动

ROM Code支持从USB OTG 接口启动,可以借助STM32CubeProg软件下载程序。

2. 串口启动

ROM Code支持以下串口:USART2, USART3, UART4, UART5, USART6, UART7, UART8。

六、存储器启动(Flash memory boot)

ROM Code支持以下存储器接口:

  • QUADSPI:串行nor flash、串行nand flash
  • FMC:并行nand flash
  • SDMMC:SD卡、eMMC

本文中重点讲述从SD卡和eMMC启动。

1. 从SD卡启动(默认使用SDMMC1)

SD卡包含两个版本的FSBL,ROM Code会尝试加载运行第一份FSBL镜像,如果失败,则尝试加载第二份FSBL镜像。

ROM Code首先会查找 GPT 分区表(GUID Partition Table),如果找到分区表,它将查找前两个名字为fsbl开头的分区来定位两个FSBL,如果找不到,则会在偏移 LBA34 处和 LBA546 处查找 FSBL1和FSBL2。

2. 从eMMC启动(默认使用SDMMC2)

eMMC内部的分区结构如下;

同样,eMMC中Boot Area 分区包含的两个FSBL用于ROM Code尝试加载。

这篇关于STM32MP157开发笔记 | 03 - STM32MP157启动程序ROM Code详解的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

PHP轻松处理千万行数据的方法详解

《PHP轻松处理千万行数据的方法详解》说到处理大数据集,PHP通常不是第一个想到的语言,但如果你曾经需要处理数百万行数据而不让服务器崩溃或内存耗尽,你就会知道PHP用对了工具有多强大,下面小编就... 目录问题的本质php 中的数据流处理:为什么必不可少生成器:内存高效的迭代方式流量控制:避免系统过载一次性

基于 Cursor 开发 Spring Boot 项目详细攻略

《基于Cursor开发SpringBoot项目详细攻略》Cursor是集成GPT4、Claude3.5等LLM的VSCode类AI编程工具,支持SpringBoot项目开发全流程,涵盖环境配... 目录cursor是什么?基于 Cursor 开发 Spring Boot 项目完整指南1. 环境准备2. 创建

MySQL的JDBC编程详解

《MySQL的JDBC编程详解》:本文主要介绍MySQL的JDBC编程,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录前言一、前置知识1. 引入依赖2. 认识 url二、JDBC 操作流程1. JDBC 的写操作2. JDBC 的读操作总结前言本文介绍了mysq

Redis 的 SUBSCRIBE命令详解

《Redis的SUBSCRIBE命令详解》Redis的SUBSCRIBE命令用于订阅一个或多个频道,以便接收发送到这些频道的消息,本文给大家介绍Redis的SUBSCRIBE命令,感兴趣的朋友跟随... 目录基本语法工作原理示例消息格式相关命令python 示例Redis 的 SUBSCRIBE 命令用于订

python获取指定名字的程序的文件路径的两种方法

《python获取指定名字的程序的文件路径的两种方法》本文主要介绍了python获取指定名字的程序的文件路径的两种方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要... 最近在做项目,需要用到给定一个程序名字就可以自动获取到这个程序在Windows系统下的绝对路径,以下

使用Python批量将.ncm格式的音频文件转换为.mp3格式的实战详解

《使用Python批量将.ncm格式的音频文件转换为.mp3格式的实战详解》本文详细介绍了如何使用Python通过ncmdump工具批量将.ncm音频转换为.mp3的步骤,包括安装、配置ffmpeg环... 目录1. 前言2. 安装 ncmdump3. 实现 .ncm 转 .mp34. 执行过程5. 执行结

Python中 try / except / else / finally 异常处理方法详解

《Python中try/except/else/finally异常处理方法详解》:本文主要介绍Python中try/except/else/finally异常处理方法的相关资料,涵... 目录1. 基本结构2. 各部分的作用tryexceptelsefinally3. 执行流程总结4. 常见用法(1)多个e

SpringBoot日志级别与日志分组详解

《SpringBoot日志级别与日志分组详解》文章介绍了日志级别(ALL至OFF)及其作用,说明SpringBoot默认日志级别为INFO,可通过application.properties调整全局或... 目录日志级别1、级别内容2、调整日志级别调整默认日志级别调整指定类的日志级别项目开发过程中,利用日志

Java中的抽象类与abstract 关键字使用详解

《Java中的抽象类与abstract关键字使用详解》:本文主要介绍Java中的抽象类与abstract关键字使用详解,本文通过实例代码给大家介绍的非常详细,感兴趣的朋友跟随小编一起看看吧... 目录一、抽象类的概念二、使用 abstract2.1 修饰类 => 抽象类2.2 修饰方法 => 抽象方法,没有

SpringBoot 多环境开发实战(从配置、管理与控制)

《SpringBoot多环境开发实战(从配置、管理与控制)》本文详解SpringBoot多环境配置,涵盖单文件YAML、多文件模式、MavenProfile分组及激活策略,通过优先级控制灵活切换环境... 目录一、多环境开发基础(单文件 YAML 版)(一)配置原理与优势(二)实操示例二、多环境开发多文件版