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

相关文章

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

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

MySQL的JDBC编程详解

《MySQL的JDBC编程详解》:本文主要介绍MySQL的JDBC编程,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录前言一、前置知识1. 引入依赖2. 认识 url二、JDBC 操作流程1. JDBC 的写操作2. JDBC 的读操作总结前言本文介绍了mysq

python获取指定名字的程序的文件路径的两种方法

《python获取指定名字的程序的文件路径的两种方法》本文主要介绍了python获取指定名字的程序的文件路径的两种方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要... 最近在做项目,需要用到给定一个程序名字就可以自动获取到这个程序在Windows系统下的绝对路径,以下

Python异步编程之await与asyncio基本用法详解

《Python异步编程之await与asyncio基本用法详解》在Python中,await和asyncio是异步编程的核心工具,用于高效处理I/O密集型任务(如网络请求、文件读写、数据库操作等),接... 目录一、核心概念二、使用场景三、基本用法1. 定义协程2. 运行协程3. 并发执行多个任务四、关键

AOP编程的基本概念与idea编辑器的配合体验过程

《AOP编程的基本概念与idea编辑器的配合体验过程》文章简要介绍了AOP基础概念,包括Before/Around通知、PointCut切入点、Advice通知体、JoinPoint连接点等,说明它们... 目录BeforeAroundAdvise — 通知PointCut — 切入点Acpect — 切面

Spring Boot 整合 SSE(Server-Sent Events)实战案例(全网最全)

《SpringBoot整合SSE(Server-SentEvents)实战案例(全网最全)》本文通过实战案例讲解SpringBoot整合SSE技术,涵盖实现原理、代码配置、异常处理及前端交互,... 目录Spring Boot 整合 SSE(Server-Sent Events)1、简述SSE与其他技术的对

MyBatis-Plus 与 Spring Boot 集成原理实战示例

《MyBatis-Plus与SpringBoot集成原理实战示例》MyBatis-Plus通过自动配置与核心组件集成SpringBoot实现零配置,提供分页、逻辑删除等插件化功能,增强MyBa... 目录 一、MyBATis-Plus 简介 二、集成方式(Spring Boot)1. 引入依赖 三、核心机制

基于Python编写自动化邮件发送程序(进阶版)

《基于Python编写自动化邮件发送程序(进阶版)》在数字化时代,自动化邮件发送功能已成为企业和个人提升工作效率的重要工具,本文将使用Python编写一个简单的自动化邮件发送程序,希望对大家有所帮助... 目录理解SMTP协议基础配置开发环境构建邮件发送函数核心逻辑实现完整发送流程添加附件支持功能实现htm

C#控制台程序同步调用WebApi实现方式

《C#控制台程序同步调用WebApi实现方式》控制台程序作为Job时,需同步调用WebApi以确保获取返回结果后执行后续操作,否则会引发TaskCanceledException异常,同步处理可避免异... 目录同步调用WebApi方法Cls001类里面的写法总结控制台程序一般当作Job使用,有时候需要控制

C#异步编程ConfigureAwait的使用小结

《C#异步编程ConfigureAwait的使用小结》本文介绍了异步编程在GUI和服务器端应用的优势,详细的介绍了async和await的关键作用,通过实例解析了在UI线程正确使用await.Conf... 异步编程是并发的一种形式,它有两大好处:对于面向终端用户的GUI程序,提高了响应能力对于服务器端应