说明

对STM32内部的flash进行结构体数据存储,和读取。方便小型工程的数据掉电保存。
在初次使用的时候进行自动初始化默认值,后续掉电就不会再初始化了。

直接上代码

代码中的DATA_STORE需要自行定义结构体变量。

#include "store.h"
#define FLASH_START 0x0803D800//flash起始地址
extern STORE_SHEET DATA_STORE;//数据存储结构体
extern u16 crc_cal_by_byte(const u8* ptr, u32 len,u16 crc);//CRC校验函数
static u32 size = sizeof(STORE_SHEET);
void WriteDataToFlash(void){//写函数int i = 0;FLASH_Unlock();FLASH_ClearFlag(FLASH_FLAG_EOP | FLASH_FLAG_OPTERR | FLASH_FLAG_PGERR | FLASH_FLAG_WRPRTERR);FLASH_ErasePage(FLASH_START);for (i = 0; i < size/4; i++)FLASH_ProgramWord(FLASH_START+4 * i, *((u32 *)(((u8 *)&DATA_STORE) + 4 * i)));  //必须写入整字FLASH_Lock();
}
//==================================================================================================================
//++++++++++++++读写安全套接层
//==================================================================================================================
void READ_CHECK(void)//读安全校验
{u8 cnt = 0;   taskENTER_CRITICAL();do memcpy((char *)(&DATA_STORE), (void *)(FLASH_START), size);while(crc_cal_by_byte(((u8 *)&DATA_STORE) + 4, size - 8,998) != DATA_STORE.u32Crc&&cnt++ < 10);taskEXIT_CRITICAL();
}
void WRITE_CHECK(void)//写安全校验
{u8 cnt = 0;   taskENTER_CRITICAL();do{DATA_STORE.u32Crc = crc_cal_by_byte(((u8 *)&DATA_STORE) + 4, sizeof(DATA_STORE) - 8,998); /*CRC CALCULATE*/   WriteDataToFlash();}while(crc_cal_by_byte(((u8 *)FLASH_START) + 4, size - 8,998) != DATA_STORE.u32Crc&&cnt++ < 10);taskEXIT_CRITICAL();
}
//==================================================================================================================
//++++掉电数据体初始化默认值++++++数据读出接口++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
//==================================================================================================================
void STORE_ConfigInitPara(void)
{READ_CHECK();if(DATA_STORE.MAGIC != MAGIC_FLAG) {memset(&DATA_STORE,0,sizeof(STORE_SHEET));DATA_STORE.MAGIC = MAGIC_FLAG;//初始化掉电数据宏//==============================================================//==F410 掉电保存初值 ==////--TIMERDATA_STORE.STD_TIME = 14400;   //关机定时发送时间 14400sDATA_STORE.HEART  = 10;//--WIFImemset(DATA_STORE.WIFI.SSID,0,32);memset(DATA_STORE.WIFI.PWD,0,32);memcpy(DATA_STORE.WIFI.SSID, "Langyun",7);memcpy(DATA_STORE.WIFI.PWD, "hfly8888",8);//--LIMITERDATA_STORE.LIMITER.POWER_LIMIT = 11.5;                     //低电电压  DATA_STORE.LIMITER.SPEED_LIMIT = 15;                       //速度限制 DATA_STORE.LIMITER.LOCK_ACTION =0;                          //1正常使用 //0强制关机//--GPSDATA_STORE.GPSS.latitude  = 31.782533;DATA_STORE.GPSS.longitude = 117.34911;                        //--FLASH_StoreBuffer_cntDATA_STORE.HIS.ADDO = 0;                      //Address where data startsDATA_STORE.HIS.ADDW = 0;                        //Address where data ends//执行写入STORE_DATA();}
}
static _Bool restore = false;
//====================================================数据存入接口
u8 STORE_DATA(void)
{DATA_STORE.MAGIC = MAGIC_FLAG;if(restore) DATA_STORE.MAGIC = 0xffffffff;//清除掉电数据恢复出厂设置   WRITE_CHECK();//写安全校验return 1;
}
//===================================================主动重新初始化掉电数据配置
void set_restore(void)
{restore = true;
}

头文件

#ifndef _STORE_H
#define _STORE_H
#include "sys.h"
/* 掉电数据存储表 */
//==============================================================================================
void    STORE_ConfigInitPara(void); //读取和配置函数
u8      STORE_DATA(void);           //结构体数据存储FLASH
void    set_restore(void);          //清除FLASH掉电数据
#endif

crc_cal_by_byte校验函数提供如下

const unsigned int crc_ta_8[256]={ /* CRC 字节余式表 */0x0000, 0x1021, 0x2042, 0x3063, 0x4084, 0x50a5, 0x60c6, 0x70e7,0x8108, 0x9129, 0xa14a, 0xb16b, 0xc18c, 0xd1ad, 0xe1ce, 0xf1ef,0x1231, 0x0210, 0x3273, 0x2252, 0x52b5, 0x4294, 0x72f7, 0x62d6,0x9339, 0x8318, 0xb37b, 0xa35a, 0xd3bd, 0xc39c, 0xf3ff, 0xe3de,0x2462, 0x3443, 0x0420, 0x1401, 0x64e6, 0x74c7, 0x44a4, 0x5485,0xa56a, 0xb54b, 0x8528, 0x9509, 0xe5ee, 0xf5cf, 0xc5ac, 0xd58d,0x3653, 0x2672, 0x1611, 0x0630, 0x76d7, 0x66f6, 0x5695, 0x46b4,0xb75b, 0xa77a, 0x9719, 0x8738, 0xf7df, 0xe7fe, 0xd79d, 0xc7bc,0x48c4, 0x58e5, 0x6886, 0x78a7, 0x0840, 0x1861, 0x2802, 0x3823,0xc9cc, 0xd9ed, 0xe98e, 0xf9af, 0x8948, 0x9969, 0xa90a, 0xb92b,0x5af5, 0x4ad4, 0x7ab7, 0x6a96, 0x1a71, 0x0a50, 0x3a33, 0x2a12,0xdbfd, 0xcbdc, 0xfbbf, 0xeb9e, 0x9b79, 0x8b58, 0xbb3b, 0xab1a,0x6ca6, 0x7c87, 0x4ce4, 0x5cc5, 0x2c22, 0x3c03, 0x0c60, 0x1c41,0xedae, 0xfd8f, 0xcdec, 0xddcd, 0xad2a, 0xbd0b, 0x8d68, 0x9d49,0x7e97, 0x6eb6, 0x5ed5, 0x4ef4, 0x3e13, 0x2e32, 0x1e51, 0x0e70,0xff9f, 0xefbe, 0xdfdd, 0xcffc, 0xbf1b, 0xaf3a, 0x9f59, 0x8f78,0x9188, 0x81a9, 0xb1ca, 0xa1eb, 0xd10c, 0xc12d, 0xf14e, 0xe16f,0x1080, 0x00a1, 0x30c2, 0x20e3, 0x5004, 0x4025, 0x7046, 0x6067,0x83b9, 0x9398, 0xa3fb, 0xb3da, 0xc33d, 0xd31c, 0xe37f, 0xf35e,0x02b1, 0x1290, 0x22f3, 0x32d2, 0x4235, 0x5214, 0x6277, 0x7256,0xb5ea, 0xa5cb, 0x95a8, 0x8589, 0xf56e, 0xe54f, 0xd52c, 0xc50d,0x34e2, 0x24c3, 0x14a0, 0x0481, 0x7466, 0x6447, 0x5424, 0x4405,0xa7db, 0xb7fa, 0x8799, 0x97b8, 0xe75f, 0xf77e, 0xc71d, 0xd73c,0x26d3, 0x36f2, 0x0691, 0x16b0, 0x6657, 0x7676, 0x4615, 0x5634,0xd94c, 0xc96d, 0xf90e, 0xe92f, 0x99c8, 0x89e9, 0xb98a, 0xa9ab,0x5844, 0x4865, 0x7806, 0x6827, 0x18c0, 0x08e1, 0x3882, 0x28a3,0xcb7d, 0xdb5c, 0xeb3f, 0xfb1e, 0x8bf9, 0x9bd8, 0xabbb, 0xbb9a,0x4a75, 0x5a54, 0x6a37, 0x7a16, 0x0af1, 0x1ad0, 0x2ab3, 0x3a92,0xfd2e, 0xed0f, 0xdd6c, 0xcd4d, 0xbdaa, 0xad8b, 0x9de8, 0x8dc9,0x7c26, 0x6c07, 0x5c64, 0x4c45, 0x3ca2, 0x2c83, 0x1ce0, 0x0cc1,0xef1f, 0xff3e, 0xcf5d, 0xdf7c, 0xaf9b, 0xbfba, 0x8fd9, 0x9ff8,0x6e17, 0x7e36, 0x4e55, 0x5e74, 0x2e93, 0x3eb2, 0x0ed1, 0x1ef0
};
u16 crc_cal_by_byte(const u8* ptr, u32 len,u16 crc)
{while(len-- != 0){u32 high = (u32)(crc/256); //取CRC高8位crc <<= 8;crc ^= crc_ta_8[high^*ptr];ptr++;}return crc;
}

STM32 内部flash 数据掉电存储相关推荐

  1. map文件分析 stm32_使用STM32内部Flash额外的空间来存储数据

    本次分享关于STM32内部FLASH的笔记. STM32 芯片内部的 FLASH 存储器,主要用于存储我们代码.如果内部FLASH存储完我们的代码还有剩余的空间,那么这些剩余的空间我们就可以利用起来, ...

  2. stm32内部Flash读写

    文章目录 1.stm32内部flash介绍 2.读写驱动编写 3.源码 上篇文章讲到了STM32来驱动外部flah的操作,flash真是好东西啊,内存大,能存的东西多,这样我们就可以用它来做一些大点的 ...

  3. STM32内部flash详解(1)

    STM32 内部FLAsh概述 今天说一下STM32中的内部flash. 当我们把写好的代码下载MCU中,这个代码时存放在flash中的.当芯片重启复位上电后,会通过内核对flash进行代码的加载运行 ...

  4. 新手必看!单片机掉电检测与数据掉电保存方案

    单片机在正常工作时,因某种原因造成突然掉电,将会丢失数据存储器(RAM)里的数据.在某些应用场合如测量.控制等领域,单片机正常工作中采集和运算出一些重要数据,待下次上电后需要恢复这些重要数据. 因此, ...

  5. 读写STM32内部flash读写代码

    读写STM32内部flash读写代码 由于老师的要求,所以写了一份读写STM32内部FLASH的代码,这样的话就可以把STM32里面没有用来保存代码段的部分用来存储数据了. 由于<stm32fl ...

  6. STM32内部Flash的使用

    简介 STM32内部自带不同大小的Flash,其主要功能是保存已经编译完成的代码.在实际的产品中为了节约成本如果有需要存储少量的数据会选择存放在内部Flash中. 注:STM32对于Flash 大小的 ...

  7. STM32CubeMX系列|STM32内部FLASH

    STM32内部FLASH 1. 内部FLASH简介 之前的文章中介绍过STM32F1利用SPI与外部FLASH(W25QXX芯片)通讯的例程,本例程将介绍STM32F1的内部FLASH,通过内部FLA ...

  8. STM32 内部Flash读写 程序源码 [已验证]

    目录 STM32 内部Flash带缓存读写 程序源码 0 Macro 1.Flash_Erase 2. Flash_Read_Byte 3.Flash_Write_NoBuffer 4.Flash_W ...

  9. flash写保护原理_STM32系统中的2种数据掉电保护方法!

    在嵌入式设备开发中,往往需要保存一些掉电不易失性的数据,如果系统配置.用户定制信息等等,如果增加额外的ROM IC,比如(基于I2C的24C02等等)往往会造成额外的PCB空间增大,硬件成本增加,降低 ...

  10. esp8266 eeprom_ESP8266_08基于flash的数据掉电保护

    这一节主要研究一下flash的用法,目的嘛,实现数据的掉电保护. 听起来像EEPROM? 确实很像,但不是!以STM32为例,片上是没有EEPROM的.但是,可以把一部分ROM当做EEPROM,通过程 ...

最新文章

  1. “伪高管”是如何搞垮一个公司的?
  2. Java反射机制简单使用
  3. linux——samba共享以及基础用法
  4. QT的QScrollArea类的使用
  5. 自己使用的一个.NET轻量开发结构
  6. 【洛谷 - U43391】不是0-1背包的暴力AC(思维,二分,可转化为二元组问题,复习暴力dfs总结)
  7. 论文浅尝 | 用于嵌套命名实体识别的二部平面图网络(BiFlaG)
  8. [Vue.js] 路由 -- 基于vue-router的案例--后台管理
  9. 【SpringMVC】下载功能
  10. git 裁切_GitHub - taiyang0725/PicCrop: 图片裁剪的工具类,基于uCrop封装,使用十分便捷...
  11. linux用户limit修改,linux – 使用cgroups作为用户设置用户创建的systemd范围的MemoryLimit...
  12. php mysql 读写删改_PHP+MYSQL实现用户的增删改查
  13. Atitit node.js的缺点 优缺点 和php比较 1. 门槛比较 php简单,node麻烦 1 1.1. php的优势是语法简单易学,学习曲线平滑度可能居所有语言之首 2 1.2. 当用N
  14. 利用IS61LV12816实现DSP28335的内存扩展
  15. 德标螺纹规格对照表_德标、欧标、国际、国标对照表
  16. C语言也能干大事第十二节(如鹏基础)
  17. 华为云学院给大学生的献礼:轻松玩转微认证
  18. 十七、DS1302的基本应用
  19. 求教吉他继续提高的方法
  20. python第五次作业——潘芊睿

热门文章

  1. 第一次竞选博客之星,第一次阳光普照
  2. 每天进步一点点————MUMA架构优化和应用优化
  3. ifox格式如何快速的转换成mp4格式?
  4. pdf文件展示盖章及下载
  5. openlayers中海图的加载
  6. 易到实际控制人温晓东成老赖:与贾跃亭曾是盟友 如今反目
  7. 22春天津大学《财务会计》在线作业2
  8. ewebeditor
  9. 版署通过《魔兽世界.燃烧远征》
  10. 软件是计算机所需要的程序,软件是指电脑运行所需要的各种程序及其有关资料.doc...