第十二节 Flash的读写
嵌入式系统中需要存储数据,而片内的Flash资源很匮乏,所以我们经常需要使用SpiFlash来存储数据,MT254xboard中板载了一个512Kbyte的Flash,下面我们来驱动此Flash。上一小节中我们用SPI的方式驱动了LCD12864,这节我们继续用SPI来驱动板载的Flash,《GD25Q40.pdf》详细的说明了如何驱动这片Flash,在此不做累述,我们复制LCD12864工程,重命名为SpiFlash,在此工程中添加GD25Q40的两个驱动文件。
下面我们来检测这个Flash,检测的方法为,全部写入0xAA,然后再读出,对比是否为0xAA,如果是,那Flash是没有问题的,否则Flash可能已经有坏块。具体的代码见例程,这个过程所需要的时间取决于我们需要检测的区域大小,如果完全检测,则可能需要几分钟的时间。
嵌入式系统中需要存储数据,而片内的Flash资源很匮乏,所以我们经常需要使用SpiFlash来存储数据,MT254xboard中板载了一个512Kbyte的Flash,下面我们来驱动此Flash。上一小节中我们用SPI的方式驱动了LCD12864,这节我们继续用SPI来驱动板载的Flash,《GD25Q40.pdf》详细的说明了如何驱动这片Flash,在此不做累述,我们复制LCD12864工程,重命名为SpiFlash,在此工程中添加GD25Q40的两个驱动文件。
下面我们来检测这个Flash,检测的方法为,全部写入0xAA,然后再读出,对比是否为0xAA,如果是,那Flash是没有问题的,否则Flash可能已经有坏块。具体的代码见例程,这个过程所需要的时间取决于我们需要检测的区域大小,如果完全检测,则可能需要几分钟的时间。
int main(void)
{
SysStartXOSC();
LCD12864_Init(); // LCD初始化
GD25Q40_Init(); // Flash初始化
LCD12864_DisStr(0, "Flash Check....");
sprintf(LCDBuf, "Flash ID :%04X", GD25Q40_ReadID()); // 读取器件ID
LCD12864_DisStr(1, LCDBuf);
GD25Q40_EraseChip(); // 擦除整片Flash 大约需要10S
LCD12864_DisStr(2, "Erase Chip Complete");
uint32 iCnt = 0;
// 全部写入0xAA
const uint8 Write = 0xAA;
for(iCnt=0; iCnt < CHECK_ADDR_RANGE; iCnt++)
{
GD25Q40_Write(&Write, iCnt, 1); // 写入0xAA
}
// 读取Flash内部的值,与写入的值对比
uint8 Read;
for(iCnt=0; iCnt < CHECK_ADDR_RANGE; iCnt++)
{
GD25Q40_Read(&Read, iCnt, 1);
if(Read != Write)
{
LCD12864_DisStr(3, "Flash Error");
break;
}
}
// 写入的值与读出的值完全一样
if(iCnt >= CHECK_ADDR_RANGE)
{
LCD12864_DisStr(3, "Flash Check Success");
}
GD25Q40_EraseChip(); // 再次擦除
while(1);
return 0;
}
MT254X蓝牙4.0开发板Flash效果:
本文章转载自
http://www.deyisupport.com/question_answer/wireless_connectivity/bluetooth/f/103/t/69222.aspx
请勿用于商业