《電子技術應用》
您所在的位置:首頁 > 通信與網絡 > 設計應用 > 基于SEP4O20的Linux NandFlash驅動設計
基于SEP4O20的Linux NandFlash驅動設計
電子科技
張黎明 凌 明
東南大學
摘要: 本文首先給出了NandFlash的硬件特點,分析了Linux MTD層(Memow Technology Device)的特性,基于東南大學國家ASIC中心自主設計的嵌入式微處理器芯片SEP4020,給出了Linux下NandFlash驅動的詳細設計方案。實驗結
Abstract:
Key words :

摘要:本文首先給出了NandFlash的硬件特點,分析了Linux MTD層(Memow Technology Device)的特性,基于東南大學國家ASIC中心自主設計的嵌入式微處理器芯片SEP4020,給出了Linux下NandFlash驅動的詳細設計方案。實驗結果表明,基于這種驅動方案的NandFlash能進行有效的文件管理和穩定、快速的讀寫功能,非常適合于嵌入式產品的應用。
關鍵詞:NandFlash;Linux;SEP4020微處理器

0 引言
    NandFlash是一種非易失性的存儲介質,它以極高的存儲密度,快速的讀寫速度以及低廉的價格,成為在嵌入式領域應用極為廣泛的存儲介質。但同時NandFlash更大的存儲容量以及更復雜的硬件接口也為軟件的設計提出了更高的要求。為了有效地管理復雜的存儲硬件以及提供更可靠高效的存儲環境,文章給出了在嵌入式Linux下的NandFlash的驅動設計,利用嵌入式Linux系統的高效完善以及Linux MTD子系統的對存儲介質的高度兼容,大大提高了NandFlash的使用效率,并降低了驅動開發的難度。
    本文以東南大學自主設計的東芯SEP4020微處理器的為基礎,分析NandFlash的內部結構和Linux MTD層的框架,并基于這些研究提出了NandFlash驅動的設計和實現。

1 NandFlash的硬件特點
    NAND器件是基于I/O接口的,這點不同于NOR閃存,基于Bus的RAM接口。NAND芯片以頁為單位讀寫,以塊為單位擦除,通過多個引腳傳送命令地址數據,使用較復雜的I/O接口來控制。以本文使用的東芝TC58512FT(64MNand)為例,分為4096塊,每塊有32頁,每頁有512B的數據區+16B的OOB(out of band)區。(4096×32×512B=64MB),均通過8跟IOM線串行控制,如圖l所示。


    同時由于工藝限制,NAND閃存中允許存在壞塊。NAND閃存的每一頁有16B(頁長度512B)的OOB區用來存放ECC校驗數據,ECC有效標志,壞塊標志等。所有這些決定了于NAND的存儲系統設計需要處理不同于其它類型閃存特有問題。

2 MTD的NAND結構
    Linux MTD層是Linux操作系統和存儲介質之間的一個適配層。MTD是Linux的一個子集,用來作為具體的硬件設備驅動和上層文件系統的橋梁。MTD層有兩個非常顯著的優異點:


    (1)簡化驅動的開發。設計基于MTD的驅動,所需要做的事情就是按照標準的公共接口函數的接口,根據微處理器NandFlash控制器的不同做適當的修改,而無需去理會字符(塊)設備驅動設計標準,因為所有這些復雜的與內核的交互接口機制mtd已經做好了,開發行的精力只需要集中在實現對物理設備的范圍控制。
    (2)NandFlash使用環境的獨立性。上層應用只需要訪問mtd抽象層提供的字符設備方式或者塊設備方式來訪問mtd設備,因此具體驅動對于上層應用來說是具有獨立性的,即使底層驅動修改了,上層擁有也不需要改動。并且由于mtd抽象層,上層應用就可以避免直接對具體硬件操作,而是對mtd操作,這樣,這些應用就不是建立在某個具體的設備上,更好地實現了通用性和兼容性。
    mtd抽象層用一個數組struct mtd_info*mtd_table[MAX_MTD_DEVICES]保存系統中所有的設備,mtd設備利用struct mtd_info這個結構來描述,該結構中描述了存儲設備的基本信息和具體操作所需要的內核函數,mtd系統的那個機制主要就是圍繞這個結構來實現的。
    下面簡單介紹下這個結構:

3 基于SEP4020的NandFlash驅動的實現
    SEP4020由東南大學國家專用集成電路系統工程技術研究中心設計,使用0.18μm標準CMOS的工藝設計,內嵌ARM720T內核,帶8kB指令數據Cache和全功能MMU,采用馮諾依曼結構的微處理。支持NandFlash的硬件ecc和軟件ecc,支持3級到5級地址,并提供512byte和2k bytes的頁支持(本文以3級地址,一頁為512byte為實現目標)。根據。NandFlash實際使用中大量操作均為對整頁的處理,本文利用片內dma搬運技術,提高對NandFlash的讀寫速度。
3.1 NandFlash讀函數的核心代碼
    //讀取數據,長度可能為528,512,16;但由于NandFlash的控制器只支持整頁的讀寫和//oob區的讀,而這里發送的命令是讀取數據,所以要整頁讀,數據長度為528。

3.2 NandFlash寫函數的核心代碼
    由于NandFlash本身只支持整頁的寫,而不支持直接對oob區的寫操作,而MTD上層需要對oob區進行一系列的操作,因此在對oob進行操作時需要先讀取該頁數據區,并將上層傳送的oob區數據一起組成一整頁,然后才能寫入NandFlash。

4 結束語
    本文以NandFlash芯片的特點入手,分析了LinuxMTD層架構及優點,給出了基于SEP4020微處理器的NandFlash驅動設計,并利用SEP4020內置的dma技術,提高了對NandFlash的讀寫速度。根據實驗表明,本文實現的NandFlash驅動提供的平均讀寫速度穩定在250kB/s,這樣的速度在一般的嵌入式應用中已經足夠。

此內容為AET網站原創,未經授權禁止轉載。
亚洲一区二区欧美_亚洲丝袜一区_99re亚洲国产精品_日韩亚洲一区二区
亚洲图片你懂的| 欧美暴力喷水在线| 亚洲成人资源网| 午夜欧美精品久久久久久久| 一区二区三区视频在线| 日韩视频第一页| 亚洲精品永久免费| 亚洲精品久久久久久久久| 最新国产成人在线观看| 亚洲欧洲精品天堂一级| 亚洲国产成人av在线| 在线成人av| 亚洲国产mv| 亚洲理伦在线| 一本色道精品久久一区二区三区| 亚洲国产高清自拍| 亚洲人成网站777色婷婷| 亚洲精品国产欧美| 亚洲精品一区二区在线| 日韩亚洲在线| 亚洲无限av看| 午夜久久tv| 亚洲电影一级黄| 亚洲三级视频在线观看| 9国产精品视频| 亚洲免费一级电影| 欧美一区二区三区婷婷月色| 久久成人免费视频| 久久综合国产精品台湾中文娱乐网| 狼人天天伊人久久| 欧美精品aa| 国产精品igao视频网网址不卡日韩| 国产精品裸体一区二区三区| 国产区欧美区日韩区| 国产中文一区| 亚洲国产小视频在线观看| 亚洲精品影院| 亚洲欧美日韩一区二区三区在线观看 | 影音先锋国产精品| 伊人成人开心激情综合网| 亚洲人体偷拍| 亚洲一区二区三区精品视频| 欧美中文字幕第一页| 99re亚洲国产精品| 欧美一区二区日韩一区二区| 美女免费视频一区| 欧美视频在线观看 亚洲欧| 欧美日韩综合在线| 国产一级揄自揄精品视频| 亚洲高清久久| 亚洲在线第一页| 亚洲人www| 亚洲欧美日韩专区| 牛夜精品久久久久久久99黑人 | 欧美图区在线视频| 国产真实乱子伦精品视频| 亚洲人成亚洲人成在线观看| 亚洲一区二区三区精品在线观看| 久久精品99久久香蕉国产色戒| 99riav1国产精品视频| 欧美在线视频网站| 欧美精品一区二区三区在线看午夜| 国产精品欧美一区喷水| 136国产福利精品导航| 亚洲一级在线| 日韩西西人体444www| 久久精品亚洲精品| 欧美日韩国产精品一卡| 国内精品视频在线观看| 一本色道久久综合亚洲精品婷婷| 久久激情视频| 午夜精品亚洲一区二区三区嫩草| 牛牛国产精品| 国产日韩欧美在线播放不卡| 亚洲精品国产精品乱码不99按摩| 欧美一区1区三区3区公司| 一区二区三区产品免费精品久久75 | 亚洲高清久久| 亚洲视频电影图片偷拍一区| 久久久国产精品亚洲一区| 欧美日韩在线大尺度| 亚洲高清在线观看一区| 久久av在线看| 欧美一级淫片aaaaaaa视频| 欧美日韩国产三区| 亚洲第一狼人社区| 久久国产66| 久久都是精品| 国产精品女主播| 99re8这里有精品热视频免费| 亚洲高清一区二| 久久激五月天综合精品| 国产精品日韩欧美大师| 亚洲乱码精品一二三四区日韩在线| 亚洲高清不卡在线| 久久琪琪电影院| 国产欧美一区二区精品忘忧草 | 亚洲一级特黄| 亚洲新中文字幕| 欧美激情一二三区| 亚洲大胆女人| 亚洲国产导航| 久久男人资源视频| 国产日韩欧美三区| 亚洲欧美日韩天堂| 性8sex亚洲区入口| 欧美亚日韩国产aⅴ精品中极品| 亚洲精品一区二区三区四区高清 | 亚洲欧美日韩一区二区在线| 欧美三级网址| 日韩视频免费大全中文字幕| 亚洲精品一区二区三区av| 免费在线成人| 在线成人黄色| 亚洲国产一二三| 麻豆国产精品va在线观看不卡| 黄色av日韩| 久久精品欧美日韩精品| 久久蜜桃资源一区二区老牛| 国产一区二区成人久久免费影院| 亚洲欧美日韩在线高清直播| 先锋影音国产一区| 国产麻豆成人精品| 午夜一区在线| 久久色在线播放| 极品中文字幕一区| 91久久夜色精品国产网站| 欧美成人午夜激情视频| 91久久黄色| 一二三四社区欧美黄| 欧美性大战久久久久久久| 亚洲婷婷免费| 欧美一区二区三区四区高清 | 亚洲一区二区三区高清| 欧美视频二区| 亚洲综合三区| 久久乐国产精品| 在线观看日韩国产| 亚洲精品日韩在线| 欧美肉体xxxx裸体137大胆| 一区二区三区精品视频在线观看| 亚洲一区免费| 国产日韩欧美一区| 亚洲激情视频网站| 欧美精品一区二区三区高清aⅴ| 亚洲最新色图| 欧美在线视频免费| 精品成人一区二区三区| 99国产精品久久久久久久久久 | 亚洲欧美在线一区二区| 久久久久久一区| 亚洲第一偷拍| 亚洲一区国产| 国产亚洲欧洲一区高清在线观看 | 久久精品人人| 亚洲国产高清高潮精品美女| 亚洲午夜女主播在线直播| 国产精品羞羞答答xxdd| 亚洲国产美女| 欧美性淫爽ww久久久久无| 欧美一区三区三区高中清蜜桃 | 亚洲视频在线视频| 国产欧美精品日韩区二区麻豆天美| 久久不射网站| 欧美日韩国产精品专区| 午夜欧美大片免费观看 | 狠狠色丁香婷婷综合久久片| 日韩一二在线观看| 国产欧美日本在线| 亚洲另类视频| 国产三级精品三级| 99精品欧美一区二区三区综合在线| 国产精品久久久久久久久借妻 | 久久在线观看视频| 99国产精品久久久久老师 | 老牛影视一区二区三区| av成人福利| 免费精品99久久国产综合精品| 一本大道久久a久久精品综合 | 麻豆精品国产91久久久久久| 在线午夜精品| 欧美成人精品| 午夜视频在线观看一区| 欧美精品aa| 欧美中文字幕视频| 欧美午夜女人视频在线| 亚洲精品国产精品乱码不99按摩| 国产精品人人爽人人做我的可爱 | 国产一区二区日韩精品欧美精品 | 亚洲免费一区二区| 亚洲国产成人久久综合一区| 欧美中文在线字幕| 亚洲美女av电影| 麻豆精品国产91久久久久久| 亚洲在线观看视频网站| 欧美精品一区二区三区久久久竹菊| 欧美在线视频播放| 国产精品免费看久久久香蕉| 亚洲免费观看视频| 伊人春色精品|