INflash.c 3.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125
  1. #include "stm32f10x.h"
  2. #include "INflash.h"
  3. #include "AT.h"
  4. #include "string.h"
  5. Coefficient_Data flashdata;
  6. uint8_t register_success;
  7. u16 STMFLASH_BUF[STM32_SECTOR_SIZE/2];//最多是2K字节
  8. void write_to_flash(u32 WriteAddr,u16 *pBuffer,u16 NumToWrite)
  9. {
  10. u16 i;
  11. for(i=0;i<NumToWrite;i++)
  12. {
  13. FLASH_ProgramHalfWord(WriteAddr,pBuffer[i]);
  14. WriteAddr+=2;//地址增加2.
  15. }
  16. }
  17. //读取指定地址的半字(16位数据)
  18. //faddr:读地址(此地址必须为2的倍数!!)
  19. //返回值:对应数据.
  20. u16 STMFLASH_ReadHalfWord(u32 faddr)
  21. {
  22. return *(vu16*)faddr;
  23. }
  24. //从指定地址开始读出指定长度的数据
  25. //ReadAddr:起始地址
  26. //pBuffer:数据指针
  27. //NumToWrite:半字(16位)数
  28. void STMFLASH_Read(u32 ReadAddr,u16 *pBuffer,u16 NumToRead)
  29. {
  30. u16 i;
  31. for(i=0;i<NumToRead;i++)
  32. {
  33. pBuffer[i]=STMFLASH_ReadHalfWord(ReadAddr);//读取2个字节.
  34. ReadAddr+=2;//偏移2个字节.
  35. }
  36. }
  37. void STMFLASH_Write(u32 WriteAddr,u16 *pBuffer,u16 NumToWrite)
  38. {
  39. u32 secpos; //扇区地址
  40. u16 secoff; //扇区内偏移地址(16位字计算)
  41. u16 secremain; //扇区内剩余地址(16位字计算)
  42. u16 i;
  43. u32 offaddr; //去掉0X08000000后的地址
  44. if(WriteAddr<STM32_FLASH_BASE||(WriteAddr>=(STM32_FLASH_BASE+1024*STM32_FLASH_SIZE)))return;//非法地址
  45. FLASH_Unlock();
  46. offaddr=WriteAddr-STM32_FLASH_BASE; //实际偏移地址.
  47. secpos=offaddr/STM32_SECTOR_SIZE; //扇区地址 0~127 for STM32F103RBT6
  48. secoff=(offaddr%STM32_SECTOR_SIZE)/2; //在扇区内的偏移(2个字节为基本单位.)
  49. secremain=STM32_SECTOR_SIZE/2-secoff; //扇区剩余空间大小
  50. if(NumToWrite<=secremain)secremain=NumToWrite;//不大于该扇区范围
  51. while(1)
  52. {
  53. STMFLASH_Read(secpos*STM32_SECTOR_SIZE+STM32_FLASH_BASE,STMFLASH_BUF,STM32_SECTOR_SIZE/2);//读出整个扇区的内容
  54. for(i=0;i<secremain;i++)//校验数据
  55. {
  56. if(STMFLASH_BUF[secoff+i]!=0XFFFF)break;//需要擦除
  57. }
  58. if(i<secremain)//需要擦除
  59. {
  60. FLASH_ErasePage(secpos*STM32_SECTOR_SIZE+STM32_FLASH_BASE);//擦除这个扇区
  61. for(i=0;i<secremain;i++)//复制
  62. {
  63. STMFLASH_BUF[i+secoff]=pBuffer[i];
  64. }
  65. write_to_flash(secpos*STM32_SECTOR_SIZE+STM32_FLASH_BASE,STMFLASH_BUF,STM32_SECTOR_SIZE/2);//写入整个扇区
  66. }else write_to_flash(WriteAddr,pBuffer,secremain);//写已经擦除了的,直接写入扇区剩余区间.
  67. if(NumToWrite==secremain)break;//写入结束了
  68. else//写入未结束
  69. {
  70. secpos++; //扇区地址增1
  71. secoff=0; //偏移位置为0
  72. pBuffer+=secremain; //指针偏移
  73. WriteAddr+=secremain; //写地址偏移
  74. NumToWrite-=secremain; //字节(16位)数递减
  75. if(NumToWrite>(STM32_SECTOR_SIZE/2))secremain=STM32_SECTOR_SIZE/2;//下一个扇区还是写不完
  76. else secremain=NumToWrite;//下一个扇区可以写完了
  77. }
  78. };
  79. FLASH_Lock();//上锁
  80. }
  81. //清空flash
  82. void clearflash(void){
  83. flashdata.read_flag=0;
  84. memcpy(flashdata.deviceSecret,"0",Secretsize);
  85. memcpy(flashdata.productKey,"0",productsize);
  86. memcpy(flashdata.deviceName,"0",productsize);
  87. delay_ms(10);
  88. STMFLASH_Write(FLASH_SAVE_ADDR,(u16*)&flashdata,sizeof(flashdata));
  89. }
  90. void storedata(void){
  91. flashdata.read_flag=1;
  92. Log_Printf_Debug("deviceSecret:%s,productKey:%s,deviceName:%s,read_flag:%d\r\n",flashdata.deviceSecret,flashdata.productKey,flashdata.deviceName,flashdata.read_flag);
  93. Log_Printf_Debug("结构体大小: %d\r\n", sizeof(Coefficient_Data));
  94. delay_ms(10);
  95. STMFLASH_Write(FLASH_SAVE_ADDR,(u16*)&flashdata,sizeof(flashdata));
  96. flashdata.read_flag=0;
  97. delay_ms(10);
  98. Log_Printf_Debug("写入数据完成\r\n");
  99. STMFLASH_Read(FLASH_SAVE_ADDR,(u16*)&flashdata,sizeof(flashdata));
  100. Log_Printf_Debug("读取完成read_flag:%d,deviceSecret:%s,productKey:%s,deviceName:%s\r\n",flashdata.read_flag,flashdata.deviceSecret,flashdata.productKey,flashdata.deviceName);
  101. }
  102. void store(void){
  103. if(register_success==1){
  104. storedata();
  105. }
  106. else
  107. {
  108. Log_Printf_Debug("数据解析失败,没有存储flash\r\n");
  109. flashdata.read_flag=0;
  110. }
  111. }