完善资料让更多小伙伴认识你,还能领取20积分哦, 立即完善>
|
|
相关推荐
1个回答
|
|
基础简介
不同芯片内部的flah大小不同,stm32f407内部flah是1M(1024K)大小,其结构划分如图所示: STM32F4 的闪存模块由:主存储器、系统存储器、 OPT 区域和选项字节等 4 部分组成 主存储器:该部分用来存放代码和数据常数(如 const 类型的数据),分为 12 个大小不同的扇区,主存储器的起始地址是 0X08000000。 系统存储器:这个区主要用来存放 STM32F4 的 bootloader 代码,此代码是出厂的时候就固化在芯片内部了,比例用串口下载程序时的bootload(ISP下载)。 OTP 区域:即一次性可编程区域,一次性的,写完一次,永远不能擦除。 选项字节:用于配置读保护、 BOR 级别、软件/硬件看门狗以及器件处于待机或停止模式 下的复位,相当于一些寄存器位。 在执行闪存写操作时,任何对闪存的读操作都会锁住总线,在写操作完成后读操作才能正 确地进行;既在进行写或擦除操作时,不能进行代码或数据的读取操作。所以在写的时候有必要写FLASH_DataCacheCmd(DISABLE);来禁止数据缓存,写完后再打开。 flash擦除后每个地址块的数据是0xff,擦除就是将地址内的数据转变为0xff,写入数据就是将有关位置0; 地址、内存相关基础讲解 计算机中最小的信息单位是bit,也就是一个二进制位,8个bit组成一个Byte,也就是1个字节;我们常说的flash空间,多少多少K,指的是多少多少K byte 1个存储单元存放1个字节,以stm32为例是32位单片机,它每个存储单元对应一个32位(bit)地址,即一个32位地址指向1个字节! *(u16*)0x0800 0000、*(u32*)0x0800 0000,蓝色是以0x0800 0000为首地址取一个16bit的数据(0x0800 0000和0x0800 0001一起组成16位),紫色是以0x0800 0000首地址取一个32bit的数据(0x0800 0000、0x0800 0001、0x0800 0002和0x0800 0003一起组成32位)。 flash操作是以字节为最小单位进行操作。 配置操作 读数据 STM23F4 的 FLASH 读取是很简单的。例如,我们要从地址 addr,读取一个字(字节为 8位, 半字为 16 位,字为 32 位),可以通过如下的语句读取: data=*(vu32*)addr; //addr为内存地址值 将 addr 强制转换为 vu32 指针,然后取该指针所指向的地址的值,即得到了 addr 地址的值。 类似的,将上面的 vu32 改为 vu16,即可读取指定地址的一个半字。 擦除和编程 擦除要先解锁,要写 0X45670123 到 FLASH_KEYR,写 0XCDEF89AB 到 FLASH_KEYR来解锁。 STM32F4 闪存的编程位数可以通过 FLASH_CR 的 PSIZE 字段配置, PSIZE 的设置必须和 电源电压匹配 在正点原子教程里面有句话:“由于我们开发板用的电压是 3.3V,所以 PSIZE 必须设置为10,即 32 位并行位数。擦除或者编程,都必须以 32 位为基础进行”。但是在野火的教程里写的是:“在内部 FLASH 进行擦除及写入操作时,电源电压会影响数据的最大操作位数,我们接的是3.3V电压,所以最大可以配置为X32,当然也可以配置为X16、X8”,这里建议还是以正点原子的为准。 擦除编写步骤: 解锁:void FLASH_Unlock(void); 关闭数据缓存:FLASH_DataCacheCmd(ENABLE); 擦除扇区/块: FLASH_Status FLASH_EraseSector(uint32_t FLASH_Sector, uint8_t VoltageRange); //擦除指定扇区,VoltageRange是擦除的位数,与电压有关。 FLASH_Status FLASH_EraseAllSectors(uint8_t VoltageRange);//擦除所有扇区 FLASH_StatusFLASH_EraseAllBank1Sectors(uint8_t VoltageRange);//擦除bank1 4.在指定地址写数据 FLASH_Status FLASH_ProgramDoubleWord(uint32_t Address, uint64_t Data); //指定地址写入双字64bit FLASH_Status FLASH_ProgramWord(uint32_t Address, uint32_t Data); //指定地址写入字32bit FLASH_Status FLASH_ProgramHalfWord(uint32_t Address, uint16_t Data); //指定地址写入半字16bit FLASH_Status FLASH_ProgramByte(uint32_t Address, uint8_t Data); //指定地址写入字节8bit 5.打开数据缓存:FLASH_DataCacheCmd(ENABLE); 6.上锁: FLASH_Lock(); //上锁 注意事项 写入地址必须是用户代码区以外的地址。不能覆盖用户代码,否则程序会出错。 写入地址必须是 4 的倍数。因为数据是以32bit写入的,占用4个地址位,所以是4的倍数。 设置 FLASH 保存地址必须为偶数。 |
|
|
|
只有小组成员才能发言,加入小组>>
调试STM32H750的FMC总线读写PSRAM遇到的问题求解?
1561 浏览 1 评论
X-NUCLEO-IHM08M1板文档中输出电流为15Arms,15Arms是怎么得出来的呢?
1501 浏览 1 评论
933 浏览 2 评论
STM32F030F4 HSI时钟温度测试过不去是怎么回事?
665 浏览 2 评论
ST25R3916能否对ISO15693的标签芯片进行分区域写密码?
1555 浏览 2 评论
1848浏览 9评论
STM32仿真器是选择ST-LINK还是选择J-LINK?各有什么优势啊?
610浏览 4评论
STM32F0_TIM2输出pwm2后OLED变暗或者系统重启是怎么回事?
504浏览 3评论
508浏览 3评论
stm32cubemx生成mdk-arm v4项目文件无法打开是什么原因导致的?
489浏览 3评论
小黑屋| 手机版| Archiver| 电子发烧友 ( 湘ICP备2023018690号 )
GMT+8, 2024-11-10 17:08 , Processed in 0.486791 second(s), Total 45, Slave 40 queries .
Powered by 电子发烧友网
© 2015 bbs.elecfans.com
关注我们的微信
下载发烧友APP
电子发烧友观察
版权所有 © 湖南华秋数字科技有限公司
电子发烧友 (电路图) 湘公网安备 43011202000918 号 电信与信息服务业务经营许可证:合字B2-20210191 工商网监 湘ICP备2023018690号