STM32G47x系列MCU中双Bank的工作原理及在线升级实现

发布时间:2023-10-12  

1、前言

STM32G47x 的 Flash 可以工作在双 bank 模式下,在该模式下对 FLASH 的操作支持RWW(Read-While-Write),在 Bank1 中可以对 Bank2 进行操作而不影响当前 Bank1 中的应用程序的运行,反之亦然。本文对双 Bank 模式下程序在线升级进行介绍,指出操作中的注意事项。


2、双 Bank 工作原理

STM32G47x 系列 MCU 支持 Flash 双 Bank 功能,且芯片出厂默认配置即使能了双 Bank功能。基于两个独立的 Bank,用户可以选择将应用程序放在任意一个 Bank 中运行,通过设置标志位 BFB2 来决定从哪一个 Bank 启动:

BFB2 = 0,MCU 双 Bank 启动禁用,从 Bank1 启动运行;

BFB2 = 1,MCU 双 Bank 启动使能,从 Bank2 启动运行,若是 Bank2 中无正常程序,则检测 Bank1 中是否有正常程序,若有则运行 Bank1 中的程序,若无则跳转到系统 Bootloader 运行(详见 AN2606 对应说明)。FB_MODE 反映了 Bank 的地址映射,双 Bank 的地址映射方式如下:

FB_MODE= 0 时,Bank1 的起始地址为 0x08000000,Bank2 的起始地址为

0x08040000;FB_MODE= 1 时,Bank1 的起始地址为 0x08040000,Bank2 的起始地址为0x08000000;

a4940430-35c8-11ed-ba43-dac502259ad0.png

在 STM32G47x 系列 MCU 中,MCU 启动时始终是从 0x08000000 这个地址开始运行。通过地址重映射的方式,将不同的 Bank 起始地址指定到 0x08000000,所以当从 Bank2 启动运行时,千万不要认为 MCU 是从 0x08040000 开始运行的,MCU 依旧是从 0x08000000 这个地址开始运行,认清这点对程序在线升级时对 Flash 的擦除与烧写特别重要。

另外基于以上地址重映射操作,在程序设计过程中,用户也不需要对地址空间做偏移处理,完全按照单 Bank 的思路进行设计即可,但程序不能超过单 Bank 大小。

3、在线升级实现

ST 的固件库中给出了完整单 Bank MCU 的 IAP 升级方案,基于 UART 和 Y-Modem 协议。在双 Bank 模式下,数据传输层面与单 Bank 是完全一样的,所以本文不再对 IAP 的数据传输方式与协议进行描述,具体可以参考 AN4045 与 Y-Modem 协议内容。

G4 系列的开发包中目前还没有专门的 IAP 例程,直接从其他系列移植即可,比如 F3 或是L4 系列。这些例程中存在两个工程,即 IAP 工程与APP程序工程。在 G47x 双 Bank 模式下,是在当前 Bank 中对另一 Bank 进行操作,且由于 Flash 支持 RWW,所以不需要再将 IAP 与应用程序分开,可以合并到一起。

以 L4 的 IAP 例程为基础,在原 IAP 例程的基础上,为了双 Bank,需要修改的点如下(本文只讨论程序下载,其他暂不讨论):

a4fb3344-35c8-11ed-ba43-dac502259ad0.png

a5bfe95a-35c8-11ed-ba43-dac502259ad0.png

将修改后的代码编译生成 bin 文件,通过 CubeProgrammer 烧录到 0x08000000。

4、结果验证

MCU 运行后的通过终端串口工具(Tera Term)打印调试信息,烧录完程序后,第一次上电的信息如下,BFB2 禁用,程序在 Bank1 中启动。在终端中输入 1 可以启动程序下载,输入 3 触发Bank 切换,“2”忽略。

c492ee90-35c8-11ed-ba43-dac502259ad0.png

此时 MCU 将进入等待数据传输,并显示“Waiting for the file to be sent ... (press 'a' to abort)”,用户在 Tera Term 通过以下的菜单选择目标 bin 文件,并启动传输。

d4f7d200-35c8-11ed-ba43-dac502259ad0.png

d57728b6-35c8-11ed-ba43-dac502259ad0.png

5、小结

本文简单介绍了双 Bank 的工作原理与双 Bank 进行在线 IAP 时应该注意的问题和需要添加的代码,并对最终运行的结果进行了验证。


文章来源于:电子工程世界    原文链接
本站所有转载文章系出于传递更多信息之目的,且明确注明来源,不希望被转载的媒体或个人可与我们联系,我们将立即进行删除处理。

相关文章

    串口屏与stm32串口通信;串口屏与单片机的发送与接收一.串口向单片机发送(使用串口屏和上位机软件USART HMI)1.波特率初始化2.按钮控件 printh 01二.单片机接收串口屏数据与发送给串口屏......
    屏能够直观、生动地显示运行参数和运行状态,而且通过触摸屏画面可以直接修改系统运行参数,人机交互性好。单片机广泛应用于工控领域中,与触摸屏配合,可组成良好的人机交互环境。 触摸屏与单片机通信,需要根据触摸屏采用的通信协议为单片机编写相应的通信......
    要求使用开发板,只好有点浪费了。 软件部分:软件部分是这个项目的核心。 刚开始参考了网上一些扫雷代码。在单片机上很多地方不一样,但大体思路还是一样的,主要解决的就是与串口屏之间的通信协议,贴一段简单的通信......
    基于labVIEW与单片机的上位机与下位机通信;在单片机控制系统中,经常会涉及到上位机与下位机的通信。本文主要通过一个简单的实例来介绍labVIEW与单片机的串口通信实现过程,包括下位机单片机......
    型应用系统,它要求系统完成从水温检测、信号处理、输入、运算,到输出控制电炉加热功率以实现水温控制的全过程。本设计实现了水温的智能化控制以及提供完善的人机交互界面及PC 机与单片机通信接口,系统由PC 机与单片机通信......
    *8bit.单片机AT89S52本身不具有I2C总线结口,所以可编写程序用并行端口模拟I2C总线协议读写AT24C04. 多个设备通信的重点(1.电平的区别,如串口通信中PC与单片机通信,PC机串口......
    机和单片机的通信速率为9 600 b/s,并选择相应电容与单片机的时钟引脚相连构成时钟回路。在复位电路设计中,采用复位引脚和相应的电容、电阻构成复位电路。单片机与PTR2000接口原理电路如图2所示......
    转换子程序分别送到6116数据区及8155RAM区,通过字形显示子程序显示各通道检测的数据。每采集完一个周期后,89C51单片机通过 MAX232接口PC机查询有无通信命令,有则响应,无则继续采集数据。该程......
    对基于GSM短消息收发系统的设计与实现作了具体描述,给出了系统的软硬件设计方案,对主要硬件,即GSM模块Q2403A 和8051单片机作了重点介绍。给出了系统的软件设计,包括PC与单片机通信......
    /RD、写/WR),直接与单片机引脚相连,如图2所示。 图2 TFT触摸屏与单片机连接控制原理图 2.2 VS1003音频解码控制电路 语音解码芯片VS1003可解码MP3(MPEG 1&2......

我们与500+贴片厂合作,完美满足客户的定制需求。为品牌提供定制化的推广方案、专属产品特色页,多渠道推广,SEM/SEO精准营销以及与公众号的联合推广...详细>>

利用葫芦芯平台的卓越技术服务和新产品推广能力,原厂代理能轻松打入消费物联网(IOT)、信息与通信(ICT)、汽车及新能源汽车、工业自动化及工业物联网、装备及功率电子...详细>>

充分利用其强大的电子元器件采购流量,创新性地为这些物料提供了一个全新的窗口。我们的高效数字营销技术,不仅可以助你轻松识别与连接到需求方,更能够极大地提高“闲置物料”的处理能力,通过葫芦芯平台...详细>>

我们的目标很明确:构建一个全方位的半导体产业生态系统。成为一家全球领先的半导体互联网生态公司。目前,我们已成功打造了智能汽车、智能家居、大健康医疗、机器人和材料等五大生态领域。更为重要的是...详细>>

我们深知加工与定制类服务商的价值和重要性,因此,我们倾力为您提供最顶尖的营销资源。在我们的平台上,您可以直接接触到100万的研发工程师和采购工程师,以及10万的活跃客户群体...详细>>

凭借我们强大的专业流量和尖端的互联网数字营销技术,我们承诺为原厂提供免费的产品资料推广服务。无论是最新的资讯、技术动态还是创新产品,都可以通过我们的平台迅速传达给目标客户...详细>>

我们不止于将线索转化为潜在客户。葫芦芯平台致力于形成业务闭环,从引流、宣传到最终销售,全程跟进,确保每一个potential lead都得到妥善处理,从而大幅提高转化率。不仅如此...详细>>