Linux第32步_编译ST公司的TF-A源码

news2025/1/16 0:44:36

正点原子STM32MP157开发板使用的CPU型号是STM32MP157DAA1,而开发板硬件参考了ST公司的STM32MP157 EVK开发板,因此我们在移植的时候需要关注“stm32mp157d-ev1”。

一、了解SDK 包

ST公司会从ARM官方下载TF-A软件包,然后将STM32MP1 芯片添加进去,最终打包好提供给我们用户,这个就是SDK 包。

ST公司提供的SDK 包是在他自己的“STM32MP157 EVK 开发板”上验证通过的,它包括 TF-A、uboot、linux kermel等。“正点原子的 STM32MP157开发板”是在ST公司开发板硬件的基础上修改得到的,由于硬件被修改,所以软件也要在“ST公司提供的SDK 包”上修改

二、编译ST公司的TF-A

1、打开终端

输入“ls回车”,列出当前目录下所有的文件和文件夹

输入“cd linux回车”,切换“linux”目录下

输入“ls回车”,列出当前目录下所有的文件和文件夹

输入“cd my-tfa回车”,切换my-tfa”目录下

输入“ls回车”,列出“my-tfa”目录下所有的文件和文件夹

注意:my-tfa目录下的文件就是ST公司的SDK包,这是我们在前面做好的备份文件。

见下图:

2、输入“vim Makefile.sdk回车”,使用vim命令打开已有的“Makefile.sdk”文件,见下图:

 3、将“arm-ostl-linux-gnueabi-”改为“arm-none-linux-gnueabihf-”,见下图:

4、按“ESC键”+“:wq键”,保存退出。

5、输入“cd tf-a-stm32mp-2.2.r1/回车”,进入到 tf-a源码目录下;

输入“ls回车”,列出“tf-a-stm32mp-2.2.r1”目录下所有的文件和文件夹

这时,我们发现有一个Makefile文件,见下图:

 6、输入“make -f ../Makefile.sdk all回车”, 执行编译, '-f'的意思是重新指定Makefile。

如果需要加快编译速度,可是使用多线程编译,线程数量最好和自己给虚拟机分配的物理核心保持一致,使用-j来指定线程数,命令如下:

make -f ../Makefile.sdk -j8 all //使用8线程编译

7、编译完成,见下图:

 8、输入“ls -l回车”,列出“tf-a-stm32mp-2.2.r1”目录下所有的文件和文件夹

9、输入“cd ..回车”返回到my-tfa”目录

输入“ls回车”,列出“my-tfa”目录下所有的文件和文件夹

注意:编译后,发现my-tfa”目录下多了一个“build”目录,见下图:

10、输入“cd build/回车”,切换到“build”目录下;

输入“ls回车”,列出“build”目录下所有的文件和文件夹

optee是针对OP-TEE 的,正点原子没使用OP-TEE,所以optee目录和我们没关系。

serialboot和串行启动有关的,就是通过串口或者USB烧写系统的时候需要用到serialboot下的可执行文件“tf-a-stm32mp157d-atk-serialboot.stm32”。

trusted目录下的文件是我们烧写到开发板中的“TF-A镜像文件”。

见下图:

11、输入“cd trusted/回车”,切换到“trusted”目录下;

12、输入“ls 回车”,列出当前目录下所有的文件和文件夹

注意:

1)、由于我们使用的是“STM32M157D芯片的EV1开饭板”,因此,我们需要关注“前缀为tf-a-stm32mp157d-ev1”的文件”。

2)、“tf-a-stm32mp157d-ev1-trusted.stm32”和tf-a-stm32mp157d-ev1.stm32文件一模一样,只是重命名了一下。

3)、我们在烧写程序的时候,使用“tf-a-stm32mp157d-ev1-trusted.stm32”。

 ST公司开发板对应的TF-A固件不能直接在正点原子的开发板上运行,因此需要进行修改,执行TF-A移植。

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

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

相关文章

实例分割中mIOU的定义是什么?

问题描述:实例分割中mIOU的定义是什么? 问题解答: mIOU(Mean Intersection over Union)是实例分割任务中常用的性能指标之一,用于评估模型的准确性。mIOU 是每个类别的 Intersection over Union&#xff…

【Oracle】收集Oracle数据库内存相关的信息

文章目录 【Oracle】收集Oracle数据库内存相关的信息收集Oracle数据库内存命令例各命令的解释输出结果例参考 【声明】文章仅供学习交流,观点代表个人,与任何公司无关。 编辑|SQL和数据库技术(ID:SQLplusDB) 【Oracle】收集Oracle数据库内存相关的信息 …

原子操作以及原子操作类AtomicInteger简介

前言 问:什么是原子操作 什么是原子操作,所谓原子操作,就是一个操作是不能打断的操作。确切的说应该是不备其他线程或者任务影响的操作。 没错,原子操作就是你在家里的一次上厕所的操作 >> 进厕所,上锁&#…

TPM模拟器安装

目录 TPM模拟器安装 1)安装配置所需依赖 2)从官网下载TPM模拟器程序ibmtpm1332.tar.gz 3)创建安装目录并将源码解压到对应目录 4)进入解压后的目录,然后执行安装命令 5)将tpm服务器添到Linux系统执行目…

【蓝桥杯日记】复盘篇一:深入浅出顺序结构

🚀前言 本期是一篇关于顺序结构的题目的复盘,通过复盘基础知识,进而把基础知识学习牢固!通过例题而进行复习基础知识。 🚩目录 前言 1.字符三角形 分析: 知识点: 代码如下 2. 字母转换 题目分析: 知…

申请开启|成为亚马逊云科技 Community Builder,共建云端社区!

在探索由技术打造的云端世界时,和同行者一起学习,与技术专家共同探讨是开发者成长的最佳助力! 亚马逊云科技开发者社区 Community Builders 为技术爱好者和新兴思想领袖提供技术资源、学习和交流机会,帮助开发者探索、分享技术相关…

windows如何切换访问NAS共享文件夹用户

从资源管理器对NAS共享文件夹输入用户名与密码进行访问后,想切换访问用户,搜索了一圈,网上介绍的方法都无效,最后只能注销windows7登陆,然后重新登陆,再访问NAS共享时才能切换用户,各位观众如有…

智能文件管理,按数量自动新建文件夹归类

文件管理,一直以来都是许多人头疼的问题。当你拥有大量的文件时,如何有效地归类和整理这些文件就显得尤为重要。现在,我们为你带来了一款全新的文件管理工具,让你轻松实现按数量自动新建文件夹进行归类! 首先第一步&am…

数据库(MySQL库表操作)

目录 1.1 SQL语句基础(SQL命令) 1.1.1 SQL的简介 1.1.2 SQL语句的分类 1.1.3 SQL语句的书写规范 1.2 数据库操作 1.2.1 查看 1.2.2 自建库 1.2.3 切换数据库 1.2.4 删库 1.3 MySQL字符集 1.3.1 MySQL字符集包括: 1.3.2 utf8 和 u…

审稿周期短,且出版效率高的10本医学类中文核心期刊推荐!

常笑医学整理了适合医务工作者进行论文投稿的10本医学类中文核心期刊, 以及期刊详细参数,供大家参考。 1.《保健医学研究与实践》 (详细投稿信息请点击刊物名称查看) 简介:《保健医学研究与实践》是中国高校保健医学研…

SpringMVC环境搭配

概述 Spring MVC是Spring Framework提供的Web组件,全称是Spring Web MVC,是目前主流的实现MVC设计模式的框架,提供前端路由映射、视图解析等功能 mvc是什么 MVC是一种软件架构思想,把软件按照模型,视图,控制器来划分…

架构篇05-复杂度来源:高可用

文章目录 计算高可用存储高可用高可用状态决策小结 今天,我们聊聊复杂度的第二个来源高可用。 参考维基百科,先来看看高可用的定义。 系统无中断地执行其功能的能力,代表系统的可用性程度,是进行系统设计时的准则之一。 这个定义…

R2DBC-响应式数据库

简单查询 基于全异步,响应式,消息驱动 用法: 1.导入驱动:导入连接池(r2dbc-pool),导入驱动(r2dbc-mysql) 2. 使用驱动提供的api操作 pom.xml <properties><r2dbc-mysql.version>1.0.5</r2dbc-mysql.version> </properties><dependencies><d…

浙江建筑模板批发 — 广西源头厂家供应

在建筑行业中&#xff0c;高质量的模板材料对于确保工程的顺利进行和质量至关重要。我们的浙江强度高耐水建筑模板&#xff0c;直接来自广西的源头厂家&#xff0c;以其出色的性能和质量&#xff0c;成为建筑项目的理想选择。 产品特性 高强度稳定性&#xff1a;精选优质材料制…

Java--类继承

文章目录 主要内容一.学生类1.源代码代码如下&#xff08;示例&#xff09;: 2.结果 二.交通工具类1.源代码代码如下&#xff08;示例&#xff09;: 2.结果 三.圆类1.源代码代码如下&#xff08;示例&#xff09;: 2.结果 总结 主要内容 学生类交通工具类圆类 一.学生类 具有…

2.RHCSA启动配置

rht-clearcourse 0 #重置练习环境 rht-setcourse rh134 #切换CSA练习环境 cat /etc/rht #查看当前环境 virt-manager #打开KVM控制台 rht-vmctl start classroom #必做&#xff0c;start all不会包含classroom&#xff0c;需…

Appium 环境配置

Appium 是一个开源的、跨平台的测试框架&#xff0c;可以用来测试 Native App、混合应用、移动 Web 应用&#xff08;H5 应用&#xff09;等&#xff0c;也是当下互联网企业实现移动自动化测试的重要工具。Appium 坚持的测试理念&#xff1a; •无需用户对 App 进行任何修改或…

神策 CDP 获评中国软件评测中心「优秀大数据产品」

近日&#xff0c;中国软件评测中心在第十三届软件大会上揭晓了「第十五期优秀大数据产品、解决方案和案例测评结果」。神策数据基于客户旅程编排的客户数据平台&#xff08;CDP&#xff09;1.3.0 凭借出色的产品能力获评「优秀大数据产品」&#xff0c;并获得大数据基础设施类产…

[网络编程]UDP协议,基于UDP协议的回显服务器

目录 1.UDP协议介绍 2.UDP协议在Java中的类 2.1DatagramSocket类 2.2DatagramPacket 3.回显服务器 3.1Sever端 3.2Client端 1.UDP协议介绍 UDP协议是一种网络协议&#xff0c;它是无连接的&#xff0c;全双工&#xff0c;并且是面向数据报&#xff0c;不可靠的一种协议…

C语言实现简单的扫雷游戏

目录 1 -> test.c 2 -> game.c 3 -> game.h 1 -> test.c #define _CRT_SECURE_NO_WARNINGS 1#include "game.h"void menu() {printf("************************************\n");printf("********* 1.play ********\n&quo…