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

相关文章

揭秘Python Socket网络编程的7种硬核用法

《揭秘PythonSocket网络编程的7种硬核用法》Socket不仅能做聊天室,还能干一大堆硬核操作,这篇文章就带大家看看Python网络编程的7种超实用玩法,感兴趣的小伙伴可以跟随小编一起... 目录1.端口扫描器:探测开放端口2.简易 HTTP 服务器:10 秒搭个网页3.局域网游戏:多人联机对战4.

Spring Boot + MyBatis Plus 高效开发实战从入门到进阶优化(推荐)

《SpringBoot+MyBatisPlus高效开发实战从入门到进阶优化(推荐)》本文将详细介绍SpringBoot+MyBatisPlus的完整开发流程,并深入剖析分页查询、批量操作、动... 目录Spring Boot + MyBATis Plus 高效开发实战:从入门到进阶优化1. MyBatis

Java并发编程必备之Synchronized关键字深入解析

《Java并发编程必备之Synchronized关键字深入解析》本文我们深入探索了Java中的Synchronized关键字,包括其互斥性和可重入性的特性,文章详细介绍了Synchronized的三种... 目录一、前言二、Synchronized关键字2.1 Synchronized的特性1. 互斥2.

Spring Boot 配置文件之类型、加载顺序与最佳实践记录

《SpringBoot配置文件之类型、加载顺序与最佳实践记录》SpringBoot的配置文件是灵活且强大的工具,通过合理的配置管理,可以让应用开发和部署更加高效,无论是简单的属性配置,还是复杂... 目录Spring Boot 配置文件详解一、Spring Boot 配置文件类型1.1 applicatio

Spring Boot 3.4.3 基于 Spring WebFlux 实现 SSE 功能(代码示例)

《SpringBoot3.4.3基于SpringWebFlux实现SSE功能(代码示例)》SpringBoot3.4.3结合SpringWebFlux实现SSE功能,为实时数据推送提供... 目录1. SSE 简介1.1 什么是 SSE?1.2 SSE 的优点1.3 适用场景2. Spring WebFlu

Python实现无痛修改第三方库源码的方法详解

《Python实现无痛修改第三方库源码的方法详解》很多时候,我们下载的第三方库是不会有需求不满足的情况,但也有极少的情况,第三方库没有兼顾到需求,本文将介绍几个修改源码的操作,大家可以根据需求进行选择... 目录需求不符合模拟示例 1. 修改源文件2. 继承修改3. 猴子补丁4. 追踪局部变量需求不符合很

Spring Boot结成MyBatis-Plus最全配置指南

《SpringBoot结成MyBatis-Plus最全配置指南》本文主要介绍了SpringBoot结成MyBatis-Plus最全配置指南,包括依赖引入、配置数据源、Mapper扫描、基本CRUD操... 目录前言详细操作一.创建项目并引入相关依赖二.配置数据源信息三.编写相关代码查zsRArly询数据库数

一文详解如何从零构建Spring Boot Starter并实现整合

《一文详解如何从零构建SpringBootStarter并实现整合》SpringBoot是一个开源的Java基础框架,用于创建独立、生产级的基于Spring框架的应用程序,:本文主要介绍如何从... 目录一、Spring Boot Starter的核心价值二、Starter项目创建全流程2.1 项目初始化(

Spring Boot 整合 MyBatis 连接数据库及常见问题

《SpringBoot整合MyBatis连接数据库及常见问题》MyBatis是一个优秀的持久层框架,支持定制化SQL、存储过程以及高级映射,下面详细介绍如何在SpringBoot项目中整合My... 目录一、基本配置1. 添加依赖2. 配置数据库连接二、项目结构三、核心组件实现(示例)1. 实体类2. Ma

Python异步编程中asyncio.gather的并发控制详解

《Python异步编程中asyncio.gather的并发控制详解》在Python异步编程生态中,asyncio.gather是并发任务调度的核心工具,本文将通过实际场景和代码示例,展示如何结合信号量... 目录一、asyncio.gather的原始行为解析二、信号量控制法:给并发装上"节流阀"三、进阶控制