stm32MP135裸机编程:修改基于SD卡的FSBL-A用户程序引导程序(boot)

news2025/1/16 16:58:20

0 参考资料

轻松使用STM32MP13x - 如MCU般在cortex A核上裸跑应用程序.pdf
stm32mp135官方开发板原理图(mb1635-bdp-v1-0.zip)
STM32Cube_FW_MP13_V1.0.0
STM32CubeIDE v1.15

1 为什么需要修改FSBL-A用户程序引导程序

FSBL-A用户程序引导程序的作用在《轻松使用STM32MP13x - 如MCU般在cortex A核上裸跑应用程序》中描述得非常清楚:
在这里插入图片描述
其实它最主要的作用就是去初始化DDR,然后将存储设备(如SD卡、NOR Flash、EMMC)中的用户程序拷贝到DDR起始地址,最后将PC指针指向DDR首地址跳转到用户程序。这一套操作和我们MCU的BOOT的操作是非常相似的。
一般来说,如果我们使用的板子和FSBL-A用户程序引导程序不需要修改,但如果我们的板子和官方开发板不一致的地方导致错误发生时,官方的FSBL-A用户程序引导程序便不能正常使用,我们必须要根据自己的实际情况进行修改。

2 修改FSBL-A用户程序引导程序

2.1 使用stm32CubeIDE导入官方FSBL-A用户程序引导程序

这里使用的官方软件包版本为STM32Cube_FW_MP13_V1.0.0,最新的V1.0.1的FSBL-A用户程序引导程序已经不对外公开,无法再进行修改。
直接使用everything搜索FSBLA_SDMMC1,然后将V1.0.0软件包内的FSBL-A用户程序引导程序工程导入STM32CubeIDE中即可:
在这里插入图片描述

2.2 修改用户程序扇区偏移地址

FSBL-A用户程序引导程序需要固定烧录到SD卡的LBA128,也就是第128扇区,用户程序的扇区偏移地址应该考虑到FSBL-A用户程序占用空间大小,本例参考官方V1.1.0软件包,将用户程序扇区偏移地址设置为0x500。这样FSBL-A用户程序引导程序最大支持的大小为1152扇区,也就是1152x512字节=576KB,用来存FSBL-A用户程序引导程序绰绰有余。
修改方法:
找到OFFSET_HEADER宏定义,修改为0x500。
在这里插入图片描述

#define OFFSET_HEADER 0x500 /* Offset of the cube example header */

2.3 删除无关的BSP初始化程序

官方的FSBL-A用户程序引导程序有很多和官方开发板相关的板级初始化程序,将可能导致我们的FSBL-A用户程序引导程序出错,无法正常引导用户程序,因此必须要删除无关的BSP初始化程序。
对比官方原理图和本例使用的开发板(正点原子stm32MP135)原理图,可以看到官方有一个电源管理芯片,这在本例使用的开发板上是不存在的,直接注释掉有关该电源管理芯片初始化代码:
在这里插入图片描述
继续跟踪main函数内的初始化函数,发现DDR底层初始化函数内也使用到了这个电源管理芯片去设置供电电压,我们直接注释掉:
在这里插入图片描述
不注释掉的话,将会进入板级错误回调函数,板级错误回调函数如下:
在这里插入图片描述
FSBL-A用户程序引导程序一旦进入板级错误回调函数便无法再正常引导用户程序,本例一开始没有得到该部分源码导致一直无法进入用户程序浪费了大量时间。因此,我们一定要注释掉无关代码,根据我们自己的板子量身定制FSBL-A用户程序引导程序。

2.4 检查SD卡引脚是否和官方一致

一般来说,开发板设计者为了便于开发都会将开发板的SD卡和官方开发板设计一致,本例使用的开发板的SD卡引脚和官方一致,因此不需要再修改管脚。如果你开发板的SD卡管脚和官方不一致,可以通过修改以下SD卡底层初始化函数完成。(SD引脚可以通过OTP修改为其他管脚,但只能修改一次,一旦错误板子就报废了,因此默认它和官方是一致的!!!

在这里插入图片描述

2.5 跳转用户程序前关闭全局中断

官方的引导程序在跳转APP前没有关闭全局中断,将可能导致跳转失败,我们这里暂时只加一个关闭全局中断函数,后面再慢慢优化跳转前环境清理部分:
在这里插入图片描述

2.6 增加自定义提示LED

为了更直观看到FSBL-A引导程序执行情况,我们可以加上串口打印、指示灯等作为提示。本例使用PI3连接的红色LED作为引导程序指示灯,修改LED_RED的管脚定义即可:
在这里插入图片描述
至此,我们基于SD卡的FSBL-A用户程序引导程序初步修改完成,可以正常引导用户程序在DDR中运行了。

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

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

相关文章

李廉洋:6.11黄金原油持续震荡上行,今日行情走势分析策略。

黄金消息面分析:上周黄金市场的走势受到了PCE通胀数据和美联储政策预期的显着影响。尽管市场对黄金的长期看涨情绪依然存在,但短期内金价的波动性预计将持续。4月份的PCE通胀数据显示价格压力有所降温,这一结果与分析师预期一致,但…

Cocos2dlua棋牌Lua解密

点击上方↑↑↑蓝字[协议分析与还原]关注我们 “ 介绍使用libcocos2dlua.so库的游戏的解密分析方法。” Cocos2dlua是一款流行的游戏引擎,常用于开发棋牌游戏。为了保护游戏代码,Cocos2dlua通常会对游戏脚本lua文件进行加密,生成Luac文件&…

html+CSS+js部分基础运用20

根据下方页面效果如图1所示&#xff0c;编写程序&#xff0c;代码放入图片下方表格内 图1.效果图 <!DOCTYPE html> <html lang"en"> <head> <meta charset"UTF-8"> <meta http-equiv"X-UA-Compatible" conte…

WDF驱动开发-电源策略(三)

多组件设备的 KMDF 驱动程序只能将请求发送到处于活动状态的组件。 通常&#xff0c;驱动程序将 I/O 队列分配给组件或组件集。 首先考虑分配给单个组件的队列。 驱动程序在组件变为活动状态时启动队列&#xff0c;并在组件空闲时停止队列。 因此&#xff0c;当 KMDF 调用队列…

【Oracle生产运维】数据库服务器负载过高异常排查处理

说明 在Oracle数据库运维工作中&#xff0c;经常会遇到Oracle数据库服务器平均负载&#xff08;load average&#xff09;突然异常升高&#xff0c;如果放任不管&#xff0c;严重的情况下会出现数据库宕机、服务器重启等重大故障。因此&#xff0c;当发现数据库服务器平均负载…

2024年江苏三支一扶公告已出,招440人!

本次江苏省将招募440名高校毕业生&#xff0c;安排到乡镇&#xff08;街道&#xff09;从事支教、支农、支医、帮扶乡村振兴、水利、就业和社会保障服务工作&#xff08;以下简称“三支一扶”计划&#xff09;&#xff0c;服务期限为2年。 招募程序 招募工作按照个人报名、资格…

摩托罗拉手机在中国以外的市场复兴,在欧洲和美国大幅增长

摩托罗拉曾是全球手机行业的领导者&#xff0c;不过自从被诺基亚击败后&#xff0c;它就辗转被卖了又卖&#xff0c;曾经辉煌的品牌堕落了&#xff0c;让人颇为可惜&#xff0c;不过如今摩托罗拉手机似乎看到了复兴的希望&#xff0c;在中国以外的市场都取得了快速增长。 市调机…

GStreamer学习2.1----获取mp4中的图片

这里通过获取mp4中的图片例子来加深Gstreamer的理解&#xff0c;问问AI实现这样功能的命令&#xff0c; 得到 gst-launch-1.0 filesrc locationtest.mp4 ! qtdemux ! queue ! h264parse ! avdec_h264 ! videoconvert ! jpegenc ! multifilesink locationoutput_image_%03d.jp…

linux centos consul1.15.2一键安装部署

consul原理、作用、安装相关内容 一、理论部分二、安装下载版本地址三、安装consul服务 一、理论部分 1、consul的原理 Consul的原理及作用可以归纳为以下几点&#xff1a; ①、基于Gossip协议的通信&#xff1a;Consul使用了基于Gossip协议的Serf实现来进行通信。 Gossip协议…

【思考】Vue2响应丢失、$set

【思考】Vue2响应丢失、$set vue2响应丢失情况复现原因解决总结 vue2响应丢失情况复现 场景&#xff1a;直接通过数组下标去修改数组造成响应丢失 <template><div><p v-for"(item, index) in list" :key"index">{{item}}</p><…

《Brave New Words 》4.4 ​增加父母与孩子之间的连接点

Part IV Better Together 第四部分 携手共进 Increasing Points of Connection Between Parents and Their Kids 增加父母与孩子之间的连接点 From the moment I first used GPT-4 to the day our team concluded its hack-AI-thon, I found myself awed by its capabilities. …

设计模式-装饰器模式(结构型)

装饰器模式 装饰器模式是一种结构模式&#xff0c;通过装饰器模式可以在不改变原有类结构的情况下向一个新对象添加新功能&#xff0c;是现有类的包装。 图解 角色 抽象组件&#xff1a;定义组件的抽象方法具体组件&#xff1a;实现组件的抽象方法抽象装饰器&#xff1a;实现…

effective-C++ 条款6

&#x1f536;条款6——不能被拷贝的类  &#x1f536;delete 关键字能禁掉自动生成的函数  &#x1f531;让他的派生类不能被继承  &#x1f531;另一种实现派生类不能被拷贝的方法 条款6——不能被拷贝的类 1. delete 关键字能禁掉自动生成的函数 class Uncopy { publi…

【解决问题】QApplication: No such file or directory,C++ 使用Qt或项目未正确加载Cmake报错

运行环境&#xff1a; Clion编译&#xff0c;构建C工程项目报错QApplication: No such file or directory 问题描述 QApplication: No such file or directory 引用的#include <QApplication>飘红 解决方案 1、Qt没有安装正确&#xff0c;请使用对应版本的Qt。或编译…

Nodejs 第七十六章(MQ进阶)

MQ介绍和基本使用在上一章介绍过了&#xff0c;不再重复 消息&#xff1a;在RabbitMQ中&#xff0c;消息是传递的基本单元。它由消息体和可选的属性组成 生产者Producer&#xff1a;生产者是消息的发送方&#xff0c;它将消息发送到RabbitMQ的交换器&#xff08;Exchange&…

php 混合xml js,html 代码报错 ,结束标签关闭, short_open_tag 的作用,php关闭文件结束判断

结束标签关闭, short_open_tag 的作用&#xff0c;php关闭文件结束判断 有时候我们我们会将php&#xff0c;xml&#xff0c;js&#xff0c;html 混合编写 php文件只要开始标签而不要结尾标签? 混合代码看代码 直接运行 yntax error, unexpected version (T_STRING) in php…

【差分数组】1674. 使数组互补的最少操作次数

本文涉及知识点 差分数组 LeetCode1674. 使数组互补的最少操作次数 给你一个长度为 偶数 n 的整数数组 nums 和一个整数 limit 。每一次操作&#xff0c;你可以将 nums 中的任何整数替换为 1 到 limit 之间的另一个整数。 如果对于所有下标 i&#xff08;下标从 0 开始&…

reverse入门刷题(6.9)

总结&#xff1a; 拿到附件&#xff0c;先运行看看有没有信息&#xff0c;再查壳&#xff0c;再IDA运行 1.Easy_vb 收获&#xff1a; 使用搜索&#xff1a;在String的时候用的是ctrlf 在IDA_view的时候使用搜索是Aitt 打开IDA&#xff0c;Aitt搜索MCTF&#xff08;关键字即…

2024年6月最新开源电视影视TVAPP原生源码和后台管理平台源码及完整教程

本套源码为本人维护更新完善半年左右的还在使用开发的源码&#xff0c;与市面上倒卖的残次品不一样&#xff0c;没有可比性&#xff0c;向下兼容安卓4.0&#xff0c;向上兼容安卓13以上TV电视系统&#xff0c; 完全无闪退&#xff0c;弹窗报错&#xff0c;卡死、异常死循环残次…

加解密算法及国密算法应用

常见的加解密算法可以分为可逆和不可逆两种 不可逆算法 哈希算法&#xff0c;MD5&#xff0c;hs-256&#xff0c;SM3 一般系统中使用密码加密和数据防篡改校验字段就是不可逆算法 hs-256应用&#xff1a;JWT header头部payload荷载signature签名(防止篡改) 前两部分采用base…