Linux第31步_了解STM32MP157的TF-A

了解STM32MP157的TF-A,为后期移植服务。

一、指令集

ARMV8提供了两种指令集:AAarch64和AArch32,根据字面意思就是64位和32位。

ARMV7提供的指令集是AArch32。

二、TF-A

指令集是AArch64的芯片,TF-A有:bl1、bl2、bl31、bl32 和 bl33这几个阶段。

bl1: Boot loader stage 1 (BL1).

bl2: Boot loader stage 2 (BL2)。

bl31: Boot loader stage 3-1 (BL31).

bl32: Boot loader stage 3-2 (BL32)。

bl32和 bl33是TF-A要启动第三方固件,比如 TEE OS和 uboot。

bl33: Boot loader stage 3-3 (BL33)。

TF-A启动流程:b11→b12→(b131/b132/b133)。

指令集是AArch32的芯片,TF-A有:bl1、bl2、bl32 和 bl33这几个阶段。

其中bl1、bl2和bl32属于TF-A的一部分,但是没有bl31

bl33一般是 uboot

打开TF-A源码目录,可以看到这5部分:

bl1一般是半导体厂商自己编写的内部“BootROM代码”。主要用来初始化NAND、EMMC、SD、USB或串口等。然后根据BOOT引脚的高低电平来判断当前所选择的启动设备,从对应的启动设备中加载b12镜像,并放到对应的内存中,最后跳转到 b12 镜像并运行。

bl2为安全启动固件,bl2会将剩余的三个启动阶段bl31、bl32和bl33对应的镜像文件加载到指定的内存中。

三、STM32MP1的TF-A

由于STM23MP1使用的指令集是AArch32,因此也没有bl31部分。

ST公司没有用TF-A提供的bl1,导致STM32MP1采用的是内部ROM代码,因此,bl2 和bl32(sp_min)是STM32MP1中TF-A的两个固件。又由于TF-A源码采用了设备树,所以STM32MP1中TF-A一共有四个部分:

STM32头部信息、设备树、bl2 和bl32

这四部分在编译的时候会被合并成一个二进制文件,这就是我们烧写到外部flash 中的TF-A镜像,即“tf-a-stm32mp157datk-trusted.stm32”。

注意:bl33镜像,就是uboot。

在STM32MP1中,TF-A的bl2部分主要功能:

首先是安全部分,STM32MP1的b12部分会初始化的外设如下:

①、BOOT、安全和OTP控制器,也就是ETZPC外设。

②、扩展的TrustZone 保护控制器,也就是BSEC外设。

③、TrustZone 针对 DDR 的地址空间保护控制器,也就是 TZC 外设。由于 bl2 需要从外部 flash 中加载下一阶段的镜像,因此还需要初始化一些外部 flash,比如:

①、SD 卡。

②、EMMC

③、NAND.

④、NOR.

最后,STM32MP1的b12部分还要初始化一些其他的外设,比如:

①、DDR内存。

②、时钟。

③、串口,用于调试以及使用 STM32CubeProgrammer 的时候通过串口下载系统。

④、USB,用 STM32CubeProgrammer 通过USB烧写系统的时候需要用到。bl2 还需要对镜像镜像进行验证和鉴权,鉴权是通过调用内部 ROM 代码的鉴权服务来完成。最后,bl2 会加载 bl32 和 bl33 的固件到指定的内存区域,并跳转到 bl32,bl32 接着运行。

四、STM32MP1的TF-A和Uboot的存储映射图

由于TF-A各部分存储映射不是固定的,所以在编译TF-A时,会因配置不同,导致其存储地址不同。例如:

上图中BL32的起始地址为0x2FFEDO00,但在其他地方,有可能是别的地址,这个是没关系的,我们需要重点它的存储映射形式。

五、其它

STM32MP1的bl1部分是也可以选择的。

在TF-A源码里“tf-a-stm32mp-2.2.r1/plat/st/stm32mp1/platform.mk”,

platform.mk文件定了“BL2 AT EL3”为 1,因此,在编译STM32MP1平台对应的TF-A的时候不会编译b11部分由内部“ROM代码”完成了TF-A中的 bl1部分的工作,主要就是将外部Flash中的 b12代码加载到内部RAM中并运行。 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/632437.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

再见了RDM,Redis官方GUI才是最好的!

1 简介 直观高效的 Redis GUI 管理工具,它可以对 Redis 的内存、连接数、命中率以及正常运行时间进行监控,并且可以在界面上使用 CLI 和连接的 Redis 进行交互(RedisInsight 内置对 Redis 模块支持),官方下载地址。 使…

Power Designer 连接 PostgreSQL 逆向工程生成pd表结构操作步骤以及过程中出现的问题解决

一、使用PowerDesigner16.5 链接pg数据库 1.1、启动PD.选择Create Model…。 1.2、选择Model types / Physical Data Model Physical Diagram:选择pgsql直接【ok】 1.3、选择connect 在工具栏选择Database-Connect… 快捷键:ctrlshiftN.如下图&#xff…

查询数据库表字段具有某些特征的表

目录 引言举例总结 引言 当我们把一个项目做完以后,客户要求我们把系统中所有的电话,证件号等进行加密处理时,我们难道要一个表一表去查看那些字段是电话和证件号码吗? 这种办法有点费劲,下面我们来探索如何找到想要的…

CVE-2024-0195-SpiderFlow爬虫平台远程命令执行漏洞分析

项目下载地址 spider-flow: 新一代爬虫平台,以图形化方式定义爬虫流程,不写代码即可完成爬虫。https://gitee.com/ssssssss-team/spider-flow 在平台spiderflow的页面中有一个自定义函数,看到函数应是非常的敏感了。 可以做一些猜想与尝试&…

「优选算法刷题」:盛最多水的容器

一、题目 给定一个长度为 n 的整数数组 height 。有 n 条垂线,第 i 条线的两个端点是 (i, 0) 和 (i, height[i]) 。 找出其中的两条线,使得它们与 x 轴共同构成的容器可以容纳最多的水。 返回容器可以储存的最大水量。 说明:你不能倾斜容器…

RT Thread Stdio生成STM32L431RCT6无法启动问题

一、问题现象 使用RT thread Stdio生成STM32L431RCT6工程后,编译下载完成后系统无法启动,无法仿真debug; 二、问题原因 如果当前使用的芯片支持包版本为0.2.3,可能是这个版本问题,目前测试0.2.3存在问题&#xff0c…

【白话机器学习的数学】读书笔记(4)评估(评估已建立的模型)

四、评估(评估已建立的模型) 目录 四、评估(评估已建立的模型)1.评估什么2.交叉验证1 回归问题的验证2 分类问题的验证3 精确率和召回率1.精确率Precision2.召回率Recall 4 F值5 K折交叉验证 3.正则化1 正则化的方法2 正则化的效果3 分类的正则化4 包含正则化项的表达式的微分1…

docker安装运行CloudBeaver并设置默认语言为中文

1、CloudBeaver CloudBeaver 是一个开源的 Web 数据库管理工具,它提供了一个基于浏览器的用户界面,允许用户管理和操作各种类型的数据库。CloudBeaver 支持多种数据库系统,包括但不限于 PostgreSQL、MySQL、SQLite、Oracle、SQL Server 以及…

安全帽识别:智能监控新趋势

在现代工业安全领域,安全帽识别技术已成为一项关键的创新。这项技术通过智能监控系统确保工作人员在危险环境中佩戴安全帽,显著提升了工作场所的安全标准。本文将探讨这一技术的工作原理、应用前景及其在现代工业中的重要性。 安全帽识别的工作机制 安全…

YOLOv5全网独家首发:DCNv4更快收敛、更高速度、更高性能,效果秒杀DCNv3、DCNv2等 ,助力检测实现暴力涨点

💡💡💡本文独家改进:DCNv4更快收敛、更高速度、更高性能,完美和YOLOv5结合,助力涨点 DCNv4优势:(1) 去除空间聚合中的softmax归一化,以增强其动态性和表达能力;(2) 优化存储器访问以最小化冗余操作以加速。这些改进显著加快了收敛速度,并大幅提高了处理速度,DCN…

超级详细的linux centos NFS共享服务器搭建

目录 背景说明: 1.服务端操作 1.1创建目录 1.2创建组 1.3创建用户 1.4目录授权给www:www 1.5安装nfs服务端 1.6配置权限 1.7启动服务 2.客户端操作 2.1安装软件 2.2创建目录 2.3挂载 2.4测试 2.4.1读写删除测试 2.4.1只读测试 背景说明: 看了一个帖子NFS教程,…

设备树下Led驱动实验-Led驱动加载测试

一. 简介 本文对前面两篇文章实现的 Led驱动程序进行测试。 通过应用程序调用驱动程序,从而进行 Led灯的打开与关闭。 二. Led驱动加载测试 1. 准备测试程序 将 前面实验中 3_newchrled工程中应用程序拷贝到 5_dtsled工程目录下。 进入 5_dtsled工程目录下进…

uncaught referenceError:cannot access ‘xxxStore‘ before initialization

目录 一、问题 二、解决方法 三、总结 tiips:如嫌繁琐,直接移步总结即可! 一、问题 1.写代码的时候引入store,居然报错:store没有初始化就被使用了,连页面都打不开了。 1)错误如下,详细错误如下图1-1所…

瑞_Java开发手册_(六)工程结构

文章目录 工程结构的意义(一) 应用分层(二) 二方库依赖(三) 服务器 🙊前言:本文章为瑞_系列专栏之《Java开发手册》的工程结构篇,主要介绍应用分层、二方库依赖、服务器。由于博主是从阿里的《Java开发手册》学习到Java的编程规约&#xff0c…

[LitCTF 2023] Web类题目分享

[LitCTF 2023] Web类题目做法及思路解析(个人分享) 题目平台地址:NSSCTF | 在线CTF平台 一、[LitCTF 2023]我Flag呢? 奇怪,放哪里了,怎么看不见呢?(初级难度) 1.访问…

基于Harris角点的多视角图像全景拼接算法matlab仿真

目录 1.算法运行效果图预览 2.算法运行软件版本 3.部分核心程序 4.算法理论概述 4.1 Harris角点检测 4.2 图像配准 4.3 图像变换和拼接 4.4 全景图像优化 5.算法完整程序工程 1.算法运行效果图预览 2.算法运行软件版本 matlab2022a 3.部分核心程序 function [ImageB…

C++--默认参数

一.默认参数🍗 C中允许函数提供默认参数,也就是允许在函数的声明或定义时给⼀个或多个参数指定默认值。在调 ⽤具有默认参数的函数时,如果没有提供实际参数,C将⾃动把默认参数作为相应参数的值。 二.使用规则🍗 1.如果…

Spring Boot 配置文件和日志

目录 配置文件格式 properties配置文件说明 1.properties基本语法 2.读取配置文件 3.properties缺点 yml配置文件说明 1.yml基本语法 2.配置不同数据类型 3.字符串特殊情况 4.配置对象 properties和yml对比 日志 日志的使用 日志级别 日志持久化 Lombok Lombo…

【MIdjourney】一些材质相关的关键词

1.多维剪纸(Multidimensional papercut) "Multidimensional papercut"(多维剪纸)是一种剪纸艺术形式,通过多层次的剪纸技巧和设计来创造出立体感和深度感。这种艺术形式通常涉及在不同的纸层上剪裁不同的图案,并将它们…

蓝桥杯真题(Python)每日练Day1

说明:在CSP认证的基础上(可以看看本人CSP打卡系列的博客)备赛2024蓝桥杯(Python),本人专业:大数据与数据科学 因此对python要求熟练掌握,通过练习蓝桥杯既能熟悉语法又能锻炼算法和思…