学习日记-韦linux视频一二期在上的移植7支持nand_第1页
学习日记-韦linux视频一二期在上的移植7支持nand_第2页
免费预览已结束,剩余2页可下载查看

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

210学习--支持S5PV210NANDFLASH2440S5PV210ECC校验功能ECCECC校验相关的寄存器的介绍,在给出代码之前,我先讲讲对NANDFLASH的一些理解。(建议大家先看二期里面NAND驱动的相关章节,关于NAND的硬件原理,讲得非常详细)NANDFlash的数据是以bit的方式保存在memorycell,一般来说,一个cell中只能一个bit(即SLCNAND)cell816bitlinebyte(x8)或word(x16),NANDDeviceLinePage,(NANDFlashNANDFlash是每32个page形成一个Block(32*528B)。具体一片flash上有多少个Block视需要所定。使用的三星k9f1208U0M4096个block4096*(32*528B)=66MB2MB是用来保存ECC64MB。地址:ColumnAddress(StartingAddressoftheRegister)列地址,地址的低8位;PageAddress:页地址;BlockAddressNANDFlashI/O[7:0]8位。NANDFlash512byte9bit512byteNAND512byte1sthalfPageRegister2ndhalfPageRegister,各自的由地址指针命令来选择,A[7:0]就是所谓的columnaddress(列地址),在进行擦除操作时不需要用到它,为什么?因为是以块为单位擦除;32page5bitA[13:9],即该page在块内的相对地址。A8512byte1sthalfpage2ndhalfpage,0表1st,12nd;BlockA14以上的bit来表示。例如64MB(512Mb)的NANDflash(实际中,由于存在sparearea,故都大于这个值),共4096block,因12bitA[25:14]128MB(1Gbit)528byte/pageNANDFlashblockaddress用A[26:14]pageaddressblcokaddress|pageaddressinblock。NANDFlash的地址表示为:BlockAddress|PageAddressinblock|halfpagepointer|ColumnAddress。地址传送顺序是ColumnAddress,PageAddress,BlockAddress。第1步是传递columnaddress,就是NAND_ADDR[7:0],不需移位即可传递到I/O[7:0]上,而halfpagepointerA8halfpageA8的值是不2NAND_ADDR9位,将NAND_ADDR[16:9]传到I/O[7:0]上;3步将NAND_ADDR[24:17]I/O上;4步将NAND_ADDR[25]I/O因此,整个地址传递过程需要4步才能完成,即4-stepaddressing。如果NANDFlash32MB(256Mbit)以下,那么,blockadress最只到bit24,因此寻址只需要3步。(具体参考手册x16NANDflashpagemainarea256word,512byte1sthalfpage2ndhalfpage之分了,所以,bit8就变得没有意义了,也就是这个时候,A8x8器件相同。除了这一点之外,x16的NAND以210开发板上面的1G的NANDFLASGK9K8G08U0A为例:每页=2).643).8192给舍弃了2).A12-A17263).A18到A281columnaddressNAND_ADDR[7:0],不需移位即可传递到I/O[7:0]上;22K,故要对地址做以下操作:(addr>>8&0x7*80x7,A8~A10A11*/3NAND_ADDR11NAND_ADDR[19:12]I/O[7:0]上;4NAND_ADDR19位,将NAND_ADDR[27:20]I/O上;5NAND_ADDR27位,将NAND_ADDR[28]I/O大家在看到这里后,也许还有人在纠结到底是怎么到NAND硬件本身的具置的?我只能告发出,NAND下面我给出NAND2440的没多大区别,void{设置时间参数(HCLK_PSYS667MHz/5 =1 =TWRPH0[11:8]:TWRPH0= 7.5ns*2=TWRPH1[7:4]:TWRPH1=17.5ns*2=AddrCycle[11=52440NFCONF|=1<<12|1<<8|NFCONF|=/*NAND*/NFCONT|=(1<<0)|(1<<1);/*设置相应管脚用于NandFlash控制器*/MP0_3CON=0x /*NANDFlash*/}nandread mand(intargc,char*{if(strcmp(argv[0],"nand")==0)nand(argc,argv);}然后nand()函数中会进一步判断从而调用nand_read()等函数我就不列出代码了大家看我共享的代码,就明白,放在了"Tiny210学习_代码" md命令:WY_BOOT#WY_BOOT#WY_BOOT#mdmand :00EACEEDCE4F284F781CF81F395E9CDE :6B7DCBCFD4F870DB9F07E61FnandreadWY_BOOTWY_BOOT#

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论