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

本文主要是介绍stm32MP135裸机编程:修改基于SD卡的FSBL-A用户程序引导程序(boot),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

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中运行了。

这篇关于stm32MP135裸机编程:修改基于SD卡的FSBL-A用户程序引导程序(boot)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

Spring Boot整合Redis注解实现增删改查功能(Redis注解使用)

《SpringBoot整合Redis注解实现增删改查功能(Redis注解使用)》文章介绍了如何使用SpringBoot整合Redis注解实现增删改查功能,包括配置、实体类、Repository、Se... 目录配置Redis连接定义实体类创建Repository接口增删改查操作示例插入数据查询数据删除数据更

Java AOP面向切面编程的概念和实现方式

《JavaAOP面向切面编程的概念和实现方式》AOP是面向切面编程,通过动态代理将横切关注点(如日志、事务)与核心业务逻辑分离,提升代码复用性和可维护性,本文给大家介绍JavaAOP面向切面编程的概... 目录一、AOP 是什么?二、AOP 的核心概念与实现方式核心概念实现方式三、Spring AOP 的关

idea+spring boot创建项目的搭建全过程

《idea+springboot创建项目的搭建全过程》SpringBoot是Spring社区发布的一个开源项目,旨在帮助开发者快速并且更简单的构建项目,:本文主要介绍idea+springb... 目录一.idea四种搭建方式1.Javaidea命名规范2JavaWebTomcat的安装一.明确tomcat

Spring Boot分层架构详解之从Controller到Service再到Mapper的完整流程(用户管理系统为例)

《SpringBoot分层架构详解之从Controller到Service再到Mapper的完整流程(用户管理系统为例)》本文将以一个实际案例(用户管理系统)为例,详细解析SpringBoot中Co... 目录引言:为什么学习Spring Boot分层架构?第一部分:Spring Boot的整体架构1.1

java程序远程debug原理与配置全过程

《java程序远程debug原理与配置全过程》文章介绍了Java远程调试的JPDA体系,包含JVMTI监控JVM、JDWP传输调试命令、JDI提供调试接口,通过-Xdebug、-Xrunjdwp参数配... 目录背景组成模块间联系IBM对三个模块的详细介绍编程使用总结背景日常工作中,每个程序员都会遇到bu

uni-app小程序项目中实现前端图片压缩实现方式(附详细代码)

《uni-app小程序项目中实现前端图片压缩实现方式(附详细代码)》在uni-app开发中,文件上传和图片处理是很常见的需求,但也经常会遇到各种问题,下面:本文主要介绍uni-app小程序项目中实... 目录方式一:使用<canvas>实现图片压缩(推荐,兼容性好)示例代码(小程序平台):方式二:使用uni

Spring Boot中获取IOC容器的多种方式

《SpringBoot中获取IOC容器的多种方式》本文主要介绍了SpringBoot中获取IOC容器的多种方式,包括直接注入、实现ApplicationContextAware接口、通过Spring... 目录1. 直接注入ApplicationContext2. 实现ApplicationContextA

Python函数的基本用法、返回值特性、全局变量修改及异常处理技巧

《Python函数的基本用法、返回值特性、全局变量修改及异常处理技巧》本文将通过实际代码示例,深入讲解Python函数的基本用法、返回值特性、全局变量修改以及异常处理技巧,感兴趣的朋友跟随小编一起看看... 目录一、python函数定义与调用1.1 基本函数定义1.2 函数调用二、函数返回值详解2.1 有返

Nginx屏蔽服务器名称与版本信息方式(源码级修改)

《Nginx屏蔽服务器名称与版本信息方式(源码级修改)》本文详解如何通过源码修改Nginx1.25.4,移除Server响应头中的服务类型和版本信息,以增强安全性,需重新配置、编译、安装,升级时需重复... 目录一、背景与目的二、适用版本三、操作步骤修改源码文件四、后续操作提示五、注意事项六、总结一、背景与

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

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