本帖最后由 stm1024 于 2019-1-18 11:15 编辑 Flash现已成为MCU的标配,Flash的特性在决定了MCU的一些功能,如代码大小、执行效率、FDU等。了解一款MCU的Flash显得很重要,这里测试一下G071的Flash。 先看看和F0存在的不同。flash的大小就没必要深究了,主要的区别如下: 1.指令缓存。Flash控制器含有一个8字节的预取指缓冲器和一个16字节的指令缓存。 2.OTP区域。所谓的OTP,也就是one time programming,这个区域可以按双字方式写入数据,而且只能写一次,如果写入的数据有一个bit不为0,则以后这个区域就不可更改了,可用于存取非擦写的用户数据。 3.快速编程。官方给出的数据是22ms的擦除时间和写入每双字时间为82us。 4.PCROP。这个是proprietary code readout protection的缩写,用于保护代码,其代码只能用来执行,而不能被读取或写入。至于Securable Memory,则是安全储存器,该区域不能被非安全区域外访问, 5.ECC。ECC是Error Correction and Checking,即错误检查和纠正。能检查2 bits的错误,并能纠正1 bit翻转错误。 再看看Flash的组织。见下图: Flash主要分为两块,分别是主块和信息块。主块就是常规使用的Flash,通常也是我们程序的入口地址,这一块可以随便使用。 而信息块则包含了系统储存器,OTP区域和选项字节,Flash的操作方式按下图: 编程需要一次写入8字节,也就是粒度为64bits(实际上是72bits,还有8bits的ECC)快速编程为256字节(仅支持Main Memory),快速编程因为不检查所写入的地址,因此比标准编程快了约37%。擦除可按2KB的页或者整个擦除(128KB),但花费的时间相当。 在选项字节的配置上,和F0系列没有差别(或者我还没有发现)。 以下Flash编程测试代码:
不得不说,有ST Link Utility就是好,直接Dump Flash。 此外,可以看到刚好改写数据是1页: 因为0x2000-0x1800=0x800,也就是1 Page的大小。 |
2022-04-20
Test-2022-02-21: share
STM32
超强工具——STM32CubeMX 你会用吗?
集结出发! STM32全国研讨会系列之一:ST智能门铃中国首秀
关于STM32启动文件的几个小问题
【银杏科技ARM+FPGA双核心应用】STM32H7系列35——USB_VCP_FS
【银杏科技ARM+FPGA双核心应用】STM32H7系列28——USB_HID
粉丝分享 | 图说CRC原理应用及STM32硬件CRC外设
STM32L151进入低功耗,并由RTC唤醒的故事
谢谢!
另外还有页设置的函数GetPage()是在哪个文件中定义的?我在编译时提示未定义。
这个问题已经解决了,编译通过了。
啊,这个没复制进去。
一行代码:
这个可以参考HAL库的文档,我都是调用的HAL库函数
额,这个还没见到过,不过一般用的好像都是F103C8T6
感谢分享