微波EDA网,见证研发工程师的成长!
首页 > 硬件设计 > 硬件工程师文库 > Nand-flash存储器工作原理及其操作实例(以K9F1208UOB为例)

Nand-flash存储器工作原理及其操作实例(以K9F1208UOB为例)

时间:09-11 来源: 点击:

0x0;//填0

  for(i=0;i《512;i++){

  #if ADS10==TRUE

  if(offset==-1) *srcPt++=rand()%0xff;//随机数填满

  #else

  if(offset==-1) srcPt++ =i%0xf;

  #endif

  else *srcPt++=i+offset;

  }

  写之前先进行擦除工作:

  if(NF8_EraseBIock(block)==FAIL) return;

  然后进行页写入操作:

  if(NF8_WritePage(block,page,srcPt)==FAIL) return;

  将用随机数填满的srcPt指向的数据写入到指定的页中。写入之后再读出验证:

  if(NF8_ReadPage(block,page,dstPt)==FAIL) return;

  Uart_Printf("Checking data. ");

  for(error=0,i=0;i《512;i++){

  if(*srcPt++!=*dstPt++){//比较操作

  Uart_Printf("Error:%d[W:%x,R:%x] ",i,*srcPt,*dstPt);

  error++;

  }

  }

  if(error!=0)

  {Uart_Printf("Fail to R/W test(%d)。 ",error);

  return(2);

  }

  else

  {Uart_Printf("R/W test OK. ");

  return(1);

  }

  其中NF8_ReadPage(block,page,dstPt)将读出的数据放入dstPt指向的地址空间里。最后将写入的数据和读出的数据比较,打印验证信息。

  步骤4:编译工程

  所有的函数都实现以后,通过ADS1.2进行编泽,生成可执行文件。在工程文件夹" andflash_testaandflash_test_DatakDebugRel"下,可以看到nandflash_test.bin可执行文件。

  步骤5:下载程序运行

  将串口线与硬件开发系统板串口和开发PC机的COM1连接好(主要用于回显),用USB线和开发PC 机的USB口相连后(主要用于数据的下载),打开DNW 软件,将串口设置为COM1,比特率设置为115200,USB下载地址设为0x30000000.

  使用DNW 将前面生成的可执行文件下载到内存中去运行。

  3 结束语

  本文主要讨论了Nand-flash存储器芯片的工作原理以及以三星公司基于ARM公司的ARM920T处理器核S3C2440A为平台举了一个测试实例,让读者对整个存储系统的软硬件设计过程有了一个较为全面的了解,便于在其它嵌入式系统设计中运用。

Copyright © 2017-2020 微波EDA网 版权所有

网站地图

Top