摘要:本文首先給出了NandFlash的硬件特點(diǎn),,分析了Linux MTD層(Memow Technology Device)的特性,,基于東南大學(xué)國(guó)家ASIC中心自主設(shè)計(jì)的嵌入式微處理器芯片SEP4020,,給出了Linux下NandFlash驅(qū)動(dòng)的詳細(xì)設(shè)計(jì)方案,。實(shí)驗(yàn)結(jié)果表明,,基于這種驅(qū)動(dòng)方案的NandFlash能進(jìn)行有效的文件管理和穩(wěn)定,、快速的讀寫(xiě)功能,非常適合于嵌入式產(chǎn)品的應(yīng)用,。
關(guān)鍵詞:NandFlash,;Linux;SEP4020微處理器
0 引言
NandFlash是一種非易失性的存儲(chǔ)介質(zhì),,它以極高的存儲(chǔ)密度,,快速的讀寫(xiě)速度以及低廉的價(jià)格,成為在嵌入式領(lǐng)域應(yīng)用極為廣泛的存儲(chǔ)介質(zhì),。但同時(shí)NandFlash更大的存儲(chǔ)容量以及更復(fù)雜的硬件接口也為軟件的設(shè)計(jì)提出了更高的要求,。為了有效地管理復(fù)雜的存儲(chǔ)硬件以及提供更可靠高效的存儲(chǔ)環(huán)境,文章給出了在嵌入式Linux下的NandFlash的驅(qū)動(dòng)設(shè)計(jì),利用嵌入式Linux系統(tǒng)的高效完善以及Linux MTD子系統(tǒng)的對(duì)存儲(chǔ)介質(zhì)的高度兼容,,大大提高了NandFlash的使用效率,,并降低了驅(qū)動(dòng)開(kāi)發(fā)的難度。
本文以東南大學(xué)自主設(shè)計(jì)的東芯SEP4020微處理器的為基礎(chǔ),,分析NandFlash的內(nèi)部結(jié)構(gòu)和Linux MTD層的框架,,并基于這些研究提出了NandFlash驅(qū)動(dòng)的設(shè)計(jì)和實(shí)現(xiàn)。
1 NandFlash的硬件特點(diǎn)
NAND器件是基于I/O接口的,,這點(diǎn)不同于NOR閃存,,基于Bus的RAM接口。NAND芯片以頁(yè)為單位讀寫(xiě),,以塊為單位擦除,,通過(guò)多個(gè)引腳傳送命令地址數(shù)據(jù),使用較復(fù)雜的I/O接口來(lái)控制,。以本文使用的東芝TC58512FT(64MNand)為例,,分為4096塊,每塊有32頁(yè),,每頁(yè)有512B的數(shù)據(jù)區(qū)+16B的OOB(out of band)區(qū),。(4096×32×512B=64MB),均通過(guò)8跟IOM線(xiàn)串行控制,,如圖l所示,。
同時(shí)由于工藝限制,NAND閃存中允許存在壞塊,。NAND閃存的每一頁(yè)有16B(頁(yè)長(zhǎng)度512B)的OOB區(qū)用來(lái)存放ECC校驗(yàn)數(shù)據(jù),,ECC有效標(biāo)志,壞塊標(biāo)志等,。所有這些決定了于NAND的存儲(chǔ)系統(tǒng)設(shè)計(jì)需要處理不同于其它類(lèi)型閃存特有問(wèn)題,。
2 MTD的NAND結(jié)構(gòu)
Linux MTD層是Linux操作系統(tǒng)和存儲(chǔ)介質(zhì)之間的一個(gè)適配層。MTD是Linux的一個(gè)子集,,用來(lái)作為具體的硬件設(shè)備驅(qū)動(dòng)和上層文件系統(tǒng)的橋梁,。MTD層有兩個(gè)非常顯著的優(yōu)異點(diǎn):
(1)簡(jiǎn)化驅(qū)動(dòng)的開(kāi)發(fā)。設(shè)計(jì)基于MTD的驅(qū)動(dòng),,所需要做的事情就是按照標(biāo)準(zhǔn)的公共接口函數(shù)的接口,,根據(jù)微處理器NandFlash控制器的不同做適當(dāng)?shù)男薷模鵁o(wú)需去理會(huì)字符(塊)設(shè)備驅(qū)動(dòng)設(shè)計(jì)標(biāo)準(zhǔn),,因?yàn)樗羞@些復(fù)雜的與內(nèi)核的交互接口機(jī)制mtd已經(jīng)做好了,,開(kāi)發(fā)行的精力只需要集中在實(shí)現(xiàn)對(duì)物理設(shè)備的范圍控制。
(2)NandFlash使用環(huán)境的獨(dú)立性,。上層應(yīng)用只需要訪(fǎng)問(wèn)mtd抽象層提供的字符設(shè)備方式或者塊設(shè)備方式來(lái)訪(fǎng)問(wèn)mtd設(shè)備,,因此具體驅(qū)動(dòng)對(duì)于上層應(yīng)用來(lái)說(shuō)是具有獨(dú)立性的,,即使底層驅(qū)動(dòng)修改了,上層擁有也不需要改動(dòng),。并且由于mtd抽象層,,上層應(yīng)用就可以避免直接對(duì)具體硬件操作,而是對(duì)mtd操作,,這樣,,這些應(yīng)用就不是建立在某個(gè)具體的設(shè)備上,更好地實(shí)現(xiàn)了通用性和兼容性,。
mtd抽象層用一個(gè)數(shù)組struct mtd_info*mtd_table[MAX_MTD_DEVICES]保存系統(tǒng)中所有的設(shè)備,,mtd設(shè)備利用struct mtd_info這個(gè)結(jié)構(gòu)來(lái)描述,該結(jié)構(gòu)中描述了存儲(chǔ)設(shè)備的基本信息和具體操作所需要的內(nèi)核函數(shù),,mtd系統(tǒng)的那個(gè)機(jī)制主要就是圍繞這個(gè)結(jié)構(gòu)來(lái)實(shí)現(xiàn)的,。
下面簡(jiǎn)單介紹下這個(gè)結(jié)構(gòu):
3 基于SEP4020的NandFlash驅(qū)動(dòng)的實(shí)現(xiàn)
SEP4020由東南大學(xué)國(guó)家專(zhuān)用集成電路系統(tǒng)工程技術(shù)研究中心設(shè)計(jì),使用0.18μm標(biāo)準(zhǔn)CMOS的工藝設(shè)計(jì),,內(nèi)嵌ARM720T內(nèi)核,,帶8kB指令數(shù)據(jù)Cache和全功能MMU,采用馮諾依曼結(jié)構(gòu)的微處理,。支持NandFlash的硬件ecc和軟件ecc,,支持3級(jí)到5級(jí)地址,并提供512byte和2k bytes的頁(yè)支持(本文以3級(jí)地址,,一頁(yè)為512byte為實(shí)現(xiàn)目標(biāo)),。根據(jù)。NandFlash實(shí)際使用中大量操作均為對(duì)整頁(yè)的處理,,本文利用片內(nèi)dma搬運(yùn)技術(shù),,提高對(duì)NandFlash的讀寫(xiě)速度,。
3.1 NandFlash讀函數(shù)的核心代碼
//讀取數(shù)據(jù),,長(zhǎng)度可能為528,512,,16,;但由于NandFlash的控制器只支持整頁(yè)的讀寫(xiě)和//oob區(qū)的讀,而這里發(fā)送的命令是讀取數(shù)據(jù),,所以要整頁(yè)讀,,數(shù)據(jù)長(zhǎng)度為528。
3.2 NandFlash寫(xiě)函數(shù)的核心代碼
由于NandFlash本身只支持整頁(yè)的寫(xiě),,而不支持直接對(duì)oob區(qū)的寫(xiě)操作,,而MTD上層需要對(duì)oob區(qū)進(jìn)行一系列的操作,因此在對(duì)oob進(jìn)行操作時(shí)需要先讀取該頁(yè)數(shù)據(jù)區(qū),,并將上層傳送的oob區(qū)數(shù)據(jù)一起組成一整頁(yè),,然后才能寫(xiě)入NandFlash,。
4 結(jié)束語(yǔ)
本文以NandFlash芯片的特點(diǎn)入手,分析了LinuxMTD層架構(gòu)及優(yōu)點(diǎn),,給出了基于SEP4020微處理器的NandFlash驅(qū)動(dòng)設(shè)計(jì),,并利用SEP4020內(nèi)置的dma技術(shù),提高了對(duì)NandFlash的讀寫(xiě)速度,。根據(jù)實(shí)驗(yàn)表明,,本文實(shí)現(xiàn)的NandFlash驅(qū)動(dòng)提供的平均讀寫(xiě)速度穩(wěn)定在250kB/s,這樣的速度在一般的嵌入式應(yīng)用中已經(jīng)足夠,。