STM32L4系列内部FLASH双字编程示例

发布者:CuriousTraveler最新更新时间:2024-05-11 来源: elecfans关键字:STM32L4系列  内部FLASH 手机看文章 扫描二维码
随时随地手机看文章

有人使用STM32L476芯片开发产品,他想在内部FLASH空间特定位置写些数据,发现总是失败,并补充说之前使用STM32F1系列、STM32L1系列却没有类似问题。


其实,针对STM32L4的内部FLASH编程,跟STM32F1/L1系列是不同的,其中STM32F1的内部FLASH编程仅支持半字编程,STM32L1的内部FLASH编程主要支持字编程或半页编程。而STM32L4系列的内部FLASH编程所支持的则是64位双字编程或以32个双字为单位的快速行编程。


对于少量的零星数据编程自然会选择64位双字编程模式,即每次改写Flash内容必须以64位为单位。硬件还针对这64位数据做了8位的ECC,我们用户看不到而已。下面简单介绍下64位双字编程过程。

在基于64位双字编程时,如果只是就字节或半字进行编程则会产生错误;或者尽管使用双字编程却没有遵循双字地址对齐【8字节对齐】时也会产生错误。

这里我使用ARM MDK V2.9开发环境,借助于STM32L476_NUCELO开发板演示一下对内部FLASH某个位置写几个64位数据的实现过程【写之前相关区域已经被擦除过了】。

我通过IDE将内部FLASH最后的0x1000地址空间预留出来用于填写些数据,即我将内部FLASH分成2块,将最后的0x1000的FLASH空间划了出来。如下图所示:【这里的芯片是STM32L476RGT6,下面只演示写三个64位数据。】

我将特定数据区定义在内部FLASH空间0x80ff000开始的地方。

#define Address_Const (0x80FF000)

另外还定义了一个64位地址指针和一个64位数据数组。

相关执行参考代码如下:

代码是基于STM32Cube库来组织的,连续写了三个64位的数据到指定的FLASH空间。其中主要涉及到一个FLASH编程函数HAL_FLASH_Program(),它有三个变量,分别是编程模式,待编程的FLASH地址以及用于编程的数据。

代码比较简单,对欲编程的地址做检查确认,然后进行FLASH编程开锁,清除可能存在的各种挂起状态标志,进行双字编程,之后对FLASH寄存器访问进行上锁。

现在基于上面的代码看看运行结果:

我们可以看到在指定的FLASH地址空间写三个64位数据。

在上面介绍64位双字编程规则时,可能有人会问,如果我遵循了8字节地址对齐,待写的数据也不是字节或半字,而是一个字会怎么样呢?那你也得凑成2个字来写,方能完成一次写操作。

比方基于上面测试代码,仅仅将每次待写的数据改为32位字,最后结果便是高位字被填0了。就像下面这样:

好,关于STM32L4系列内部FLASH双字编程模式就介绍到这里。整个过程应该说不难,只要注意到各个细节就好。

趁此再抛砖引玉似地做些提醒:STM32系列众多,各个系列的内部FLASH编程模式以及页或扇区的容量规划、地址安排往往各有差异,在FLASH编程时千万别跟着惯性或感觉走。还有,不同的编程模式往往对芯片的电源电压有不同的要求,这点也要特别特别特别注意。


关键字:STM32L4系列  内部FLASH 引用地址:STM32L4系列内部FLASH双字编程示例

上一篇:关于STM32CubeIDE环境下的变量显示及监测
下一篇:如何利用stm32单片机进行超声波测距

推荐阅读最新更新时间:2026-03-25 11:02

STM32L4系列 ADC基本原理
一、ADC简介 Analog-to-Digital Converter的缩写。指模/数转换器或者模拟/数字转换器。 STM32ADC简介 STM32 拥有 1~3 个 ADC,ADC1和ADC2紧密耦合,可在双模式下工作(ADC1为主模式)。每个ADC由一个12位逐次逼近的模数转换器组成。每个ADC有多达19个多路复用通道。各种通道的A/D转换可以在单一、连续、扫描或不连续模式下执行。ADC的结果是存储在左对齐或右对齐的16位数据寄存器中。模拟看门狗特性允许应用程序检测输入电压是否超出用户定义的高/低阀值。 ADC工作框图(根据STM32F1的ADC框图介绍STM32L4系列的ADC,大部分相同,有些寄存器有所变动)
[单片机]
<font color='red'>STM32L4</font><font color='red'>系列</font> ADC基本原理
stm32内部Flash的读写操作
stm32的产品都有内置Flash,而且不同系列的产品其内置Flash的大小不尽相同,结构上也有差异,本文将对stm32f07x,stm32f10x,stm32f40x的内置Flash结构,以及如何进行读写操作做一个介绍。 一、特性与构成 1.stm32f07x系列 2、stm32f10x系列               3、stm32f40x系列    二、对内部Flash的读写操作  2.1 stm32不同系列的产品,内部Flash的特性与构成确实存在一定的差异,但是对于读写操作,步骤一致,比如要往内部flash写入数据,需要几个步骤:   ①、解锁flash   ②、擦
[单片机]
stm32<font color='red'>内部</font><font color='red'>Flash</font>的读写操作
STM32F103学习笔记(3)——读写内部Flash
一、简介 在STM32芯片内部有一个 FLASH 存储器,它主要用于存储代码,我们在电脑上编写好应用程序后,使用下载器把编译后的代码文件烧录到该内部 FLASH 中,由于 FLASH 存储器的内容在掉电后不会丢失,芯片重新上电复位后,内核可从内部 FLASH 中加载代码并运行。 STM32 的内部 FLASH 包含主存储器、系统存储器以及选项字节区域,它们的地址分布及大小见下表 主存储器 一般我们说 STM32 内部 FLASH 的时候,都是指这个主存储器区域,它是存储用户应用程序的空间,芯片型号说明中的 256K FLASH、512K FLASH 都是指这个区域的大小。 主存储器分为 256 页,每页大小为 2
[单片机]
stm32中将结构体数据写到内部Flash时遇到的问题
在一次写代码的过程中,想把一个结构体的数据写到stm32单片机内部代码没有用到的空闲Flash,结构体开始时这样的: //#pragma pack(1) typedef struct { u8 DeviceAddr;//设备地址 LEDMODE LED_Mode; //LED 控制模式 BAUTRARE Baudrate; //串口波特率 u16 CRC16; //CRC校验 }SYSTEM_CONFIG; //#pragma pack() SYSTEM_CONFIG SystemConfig; LEDMODE和BAUTRARE是定义好的两个枚举类型,开始时发现同样的数据,在两次不同的CRC校验中得到的校验
[单片机]
STM32CubeMX系列 | STM32内部FLASH
1. 内部FLASH简介 之前的文章中介绍过STM32F1利用SPI与外部FLASH(W25QXX芯片)通讯的例程,本例程将介绍STM32F1的内部FLASH,通过内部FLASH实现数据读写操作。 不同型号的STM32,其FLASH容量也有所不同,最小的只有16K字节,最大的则达到了1024K字节。此处我们使用的是STM32F103ZET6,其FLASH容量为512K字节,属于大容量产品,大容量产品的闪存模块组织图如下图示 STM32F1的闪存模块由:主存储器、信息块和闪存存储器接口寄存器3部分组成 主存储器:用来存放代码和数据常量,起始地址是0x08000000,BOOT0和BOOT1都接GND时,就是从该起始地址运行代码
[单片机]
STM32对内部Flash的保护措施
1、STM32对内部Flash的保护措施 所有STM32的芯片都提供对Flash的保护,防止对Flash的非法访问 - 写保护和读保护。 1)、读保护即大家通常说的“加密”,是作用于整个Flash存储区域。一旦设置了Flash的读保护,内置的Flash存储区只能通过程序的正常执行才能读出,而不能通过下述任何一种方式读出: 通过调试器(JTAG或SWD); 从RAM中启动并执行的程序; 2)、写保护是以四页(1KB/页) Flash存储区为单位提供写保护,对被保护的页实施编程或擦除操作将不被执行,同时产生操作错误标志。 读与写设置的效果见下表: 读保护 写保护 对Flash的操作功能 有效 有效 CPU只能读,
[单片机]
MC9S12G128 内部flash与eeprom的读写配置
因为MC9S12G128 有内部flash和eeprom所以不需要用到 sci来通信。 并且MC9S12G128的flash与eeprom是共同管理的所以存取方式相同,只是地址范围不同。如下表所示 flash module的初始化 void eeprom_Init(){ while(FSTAT_CCIF==0); //等待正在处理的FLASH操作完成 FCLKDIV=0x17; //外部晶振为24M.FLASH时钟不超过1M while(FCLKDIV_FDIVLD==0); //等待时钟设置成功 }其中FCLKDIV的设置是根据busclock来进行选择的,我用的是24M
[单片机]
STM32 对内部FLASH读写接口函数
简介:因为要用内部FLASH代替外部EEPROM,把参数放在STM32的0x08000000+320K处,其中20K是bootloader,300K是应用程序。 原理:先要把整页FLASH的内容搬到RAM中,然后在RAM中改动,然后擦除整页FLASH,再把改动后的内容写入原Flash页。下面程序调试通过。 /******************************************************************************* * Function Name : I2C_EE_BufferRead * Description : Reads a block of data from th
[单片机]
小广播
最新单片机文章
何立民专栏 单片机及嵌入式宝典

北京航空航天大学教授,20余年来致力于单片机与嵌入式系统推广工作。

厂商技术中心

 
EEWorld订阅号

 
EEWorld服务号

 
汽车开发圈

 
机器人开发圈

电子工程世界版权所有 京ICP证060456号 京ICP备10001474号-1 电信业务审批[2006]字第258号函 京公网安备 11010802033920号 Copyright © 2005-2026 EEWORLD.com.cn, Inc. All rights reserved