真的很着急,看那极速赛车网站开发 haozbbs.comQ1446595067 些老师云里雾里说来说去,他们知道自己说的是什么吗?
正点原子:第67讲 FLASH闪存编程原理与步骤-M3第68讲 FLASH模拟EEPROM实验-M3
其实就是说STM32的闪存,主要是读/写/擦除,做出了一个风格和SPI FLASH一致的模块。
而所谓的模拟EEPROM其实是:前者是页为单位,写之前要擦除,一擦就是2k这样(李工说:主要是器件只能1-->0而不能0-->1所以擦除其实是全部覆盖成1),而后者EEPROM是任意字节的读写。模拟就是先把Flah的东西读出来,在把要写的拼接进去,随后一起写入,假装你可以单字节控制。
说两个C基础知识:
其一
u16 STMFLASH_ReadHalfWord(u32 faddr)
{
return (vu16)faddr;
}
这是直接去读,地址给我,我转化就行!以前是(&a) 现在呢?地址是确定是 是(a)
其二
void St_Flash_Write(unsigned char* pBuffer,unsigned int WriteAddr,short NumByteTowrite)
{
short i=0;
unsigned int data;
for(i=0;i<NumByteTowrite;i+=4)
{
data=(pBuffer[i+3]<<24)|(pBuffer[i+2]<<16)|(pBuffer[i+1]<<8)|(pBuffer[i+0]);//3-2-1-0//0-1-2-3
St_Flash_Write_U32(WriteAddr+i,data);
}
}
传入一个u8的数组,在里面我自己操作的,每4个拼接成一个U32,真是愚蠢。
改进1
data = (unsigned int )&pBuffer[i];
这样就好了,别自己手动搞。
改进2
其实可以更加高级一点,现在别人传递参数u8数组,是挺方便的,我可以让别人在传递参数的强行转化成U32。
const u8 T_Buffer[]={"HELLO"};
#define SIZE sizeof(T_Buffer) //数组长度
#define FLASH_SAVE_ADDR 0X0807F800
St_Flash_Page_Clear(FLASH_SAVE_ADDR);
St_Flash_Write((u32*)T_Buffer,FLASH_SAVE_ADDR,SIZE);
这样也挺好的!自动转化了,效果呢?
自己的函数要优化一下
void St_Flash_Write(unsigned int pBuffer,unsigned int WriteAddr,short NumByteTowrite)
{
short i=0;
short total=NumByteTowrite%4?(NumByteTowrite/4+1):(NumByteTowrite/4);
for(i=0;i<total;i++)
{
St_Flash_Write_U32(WriteAddr+i4,pBuffer[i]);
}
// while(pBuffer[i])
// {St_Flash_Write_U32(WriteAddr+i*4,pBuffer[i]);
// i++;};
}
上面两种方法都可以。第一种是重新确定数组长度u8的时候是5变成U32就是2啦!第二种也好,不需要长度了,数组结束的地方是0
原文地址:http://blog.51cto.com/13859684/2139167