
目前flash模拟EEPROM是参考的官方的flash读写代码,但C语言中attribute ((at())绝对定位的应用 网上的一段代码如下 1、定位到flash中,一般用于固化的信息,如出厂设置的参数,上位机配置的参数,ID卡的ID号,flash标记等等。 1 const u16 gFlashDefValue[512] attribute((at(0x0800F000))) = {0x1111,0x1111,0x1111,0x0111,0x0111,0x0111};//定位在flash中,其他flash补充为00 2 const u16 gflashdataattribute((at(0x0800F000))) = 0xFFFF; 请问这种可以直接写flash,但官方代码写flash先要解锁。 请问这种操作可以不? 谢谢! |
关于AN2867文档的疑问
tougfx 显示问题
F429同时使用SDRAM和SRAM
CAN数据重发
littlefs系统能读写SD卡吗?
STM32F405的ADC功耗参数不理解
STM32F405RGT6 ADC2+TIM4触发+DMA(DMA2_Stream2_CH1)+DMA中断会死机(取消中断后完全正常)
CUBEIDE1.19.0
stm32支持canfd和dma结合使用吗
NUCLEO-F401RE板卡,连接USB,在KEIL下可以找到ST-LINK仿真器,也可以下载代码。在电脑上看不到NODE_F401RE的磁盘,有知道是什么原因?
运行程序时通过STM32的Flash控制器API(如HAL库的HAL_FLASH_Program)对Flash特定地址进行擦写操作。
需要先解锁Flash写保护,执行擦除(通常是页擦除),然后写入数据,最后重新上锁。
这是对Flash存储器的实时地动态修改,可以在程序运行过程中改变Flash内容。
这个做法灵活,适合支持多次写入和更新Flash内容的场合,相对操作复杂些。
2、通过定义const变量编译时写入Flash
这个做法是在程序编译链接时将数据写入Flash,程序运行时为只读。
可视为静态存储。
这个操作简单方便,无需运行时进行Flash操作。适合存储固定数据,
如查表数据、固件版本号、常量配置等。
一般来讲,这类数据不适合在程序运行时更新,往往需要重新编译和烧录才能改变数据。
理解 谢谢您的解答