日本黄色一级经典视频|伊人久久精品视频|亚洲黄色色周成人视频九九九|av免费网址黄色小短片|黄色Av无码亚洲成年人|亚洲1区2区3区无码|真人黄片免费观看|无码一级小说欧美日免费三级|日韩中文字幕91在线看|精品久久久无码中文字幕边打电话

當前位置:首頁 > 智能硬件 > 智能硬件
[導讀]本文通過分析FLASH介質(zhì)的自身特性,并結(jié)合嵌入式系統(tǒng)的特點,設計實現(xiàn)于兼容性、可靠性以及開銷等方面都得到充分優(yōu)化的FLASH存儲系統(tǒng)。

摘要  作為一種新型的存儲介質(zhì),FLASH以其優(yōu)良的特性,在嵌入式領域中得到了廣泛的應用。本文通過分析FLASH介質(zhì)的自身特性,并結(jié)合嵌入式系統(tǒng)的特點,設計實現(xiàn)于兼容性、可靠性以及開銷等方面都得到充分優(yōu)化的FLASH存儲系統(tǒng)。
關鍵字  嵌入式系統(tǒng) 文件系統(tǒng) FLASH

1
引言
    FLASH(閃速存儲器)作為一種安全、快速的存儲體,具有體積小、容量大、成本低、掉電數(shù)據(jù)不丟失等一系列優(yōu)點,已成為嵌入式系統(tǒng)中數(shù)據(jù)和程序最主要的載體。由于FLASH在結(jié)構(gòu)和操作方式上與硬盤、E2ROM等其他存儲介質(zhì)有較大區(qū)別,使用FLASH時必須根據(jù)其自身特性,對存儲系統(tǒng)進行特殊設計,以保證系統(tǒng)的性能達到最優(yōu)。

2 FLASH
的特點
    FLASH是一種非易失性存儲器NVM(Non-Volatile Memory),根據(jù)結(jié)構(gòu)的不同可以將其分成NOR FLASH和NAND FLASH兩種。但不管哪一種都具有如下特點:

1.  區(qū)塊結(jié)構(gòu)
    FLASH在物理結(jié)構(gòu)上分成若干個區(qū)塊,區(qū)塊之間相互獨立。比如NOR FLASH把整個Memory分成若干個Sector,而NAND FLASH把整個Memory分成若干個Block;

2.  先擦后寫
     由于FLASH的寫操作只能將數(shù)據(jù)位從1寫成0,不能從0寫成1,所以在對存儲器進行寫入之前必須先執(zhí)行擦操作,將預寫入的數(shù)據(jù)位初始化為1。擦操作的最小單位是一個區(qū)塊,而不是單個字節(jié)。

3.  操作指令
    除了NOR FLASH的讀,F(xiàn)LASH的其它操作不能像RAM那樣,直接對目標地址進行總線操作。比如執(zhí)行一次寫操作,它必須輸入一串特殊的指令(NOR FLASH),或者完成一段時序(NAND FLASH)才能將數(shù)據(jù)寫入到FLASH中。

4.  位反轉(zhuǎn)
     由于FLASH固有的電器特性,在讀寫數(shù)據(jù)過程中,偶然會產(chǎn)生一位或幾位數(shù)據(jù)錯誤。這就是位反轉(zhuǎn)。位反轉(zhuǎn)無法避免,只能通過其他手段對結(jié)果進行事后處理。

5.  壞塊
    FLASH在使用過程中,可能導致某些區(qū)塊的損壞。區(qū)塊一旦損壞,將無法進行修復。如果對已損壞的區(qū)塊進行操作,可能會帶來不可預測的錯誤。尤其是NAND FLASH在出廠時就可能存在這樣的壞塊(已經(jīng)被標識出)。

3
關鍵設計
3.1  FLASH通用設計
    對于一個嵌入式系統(tǒng),設備的兼容性越好,系統(tǒng)可行性就越好,產(chǎn)品也就越有競爭力。所以,為了兼容不同類型的FLASH設備,對FLASH進行通用設計至關重要。
對于NOR FLASH,數(shù)據(jù)的讀操作可以通過獨立的數(shù)據(jù)總線和地址總線快速完成,然而NOR FLASH的其他操作需要通過特殊的指令來完成,更糟糕的是不同廠商生產(chǎn)的芯片這些指令互不相同。這就導致了設備的不兼容。

    對于NAND FLASH,也存在這樣的問題。NAND FLASH可以根據(jù)相同的指令讀取芯片的廠商號和設備號,從而通過識別設備號調(diào)用對應的時序流程實現(xiàn)操作。但是,系統(tǒng)中太多的判斷,會使得程序的結(jié)構(gòu)變得非常復雜。所以,在一定的條件下,NAND FLASH設備還是不兼容的。

    為了解決這一問題,一個較好的方法是將FLASH的各個操作指令以及結(jié)構(gòu)特性按照統(tǒng)一的格式存放到FLASH中固定位置。系統(tǒng)初始化時,將這個結(jié)構(gòu)讀入系統(tǒng),通過分析這個結(jié)構(gòu),可以獲得關于芯片所有相關信息,包括操作指令,區(qū)塊分布等等。這樣,系統(tǒng)可以輕松實現(xiàn)對不同型號FLASH的所有操作,極大地提高了設備的擴展性。

3.2  
雙模式文件系統(tǒng)設計
    嵌入式系統(tǒng)中文件數(shù)據(jù)的存放一般有兩種結(jié)構(gòu),一種是索引格式的線性結(jié)構(gòu),一種是非線性的鏈表式結(jié)構(gòu)。這兩種結(jié)構(gòu)各有優(yōu)缺點。比如對于系統(tǒng)配置、點陣字庫等一些具有固定結(jié)構(gòu)的系統(tǒng)數(shù)據(jù),索引結(jié)構(gòu)比鏈表式結(jié)構(gòu)更有效率。但對于經(jīng)常更新的用戶數(shù)據(jù),鏈表式結(jié)構(gòu)要比索引結(jié)構(gòu)更靈活。如果系統(tǒng)能將兩種結(jié)構(gòu)集成,勢必能將性能發(fā)揮到最優(yōu)。

    實現(xiàn)這種集成的方法是將設備定義成若干個分區(qū),每個分區(qū)相互獨立,不同分區(qū)可以使用不同的文件模式。這樣,不同類型的數(shù)據(jù)就可以根據(jù)自己的屬性選擇存放的分區(qū)。比如系統(tǒng)數(shù)據(jù)存放在使用索引線性結(jié)構(gòu)的分區(qū),用戶數(shù)據(jù)存放在使用鏈式非線性結(jié)構(gòu)的分區(qū)。

3.3
壞塊處理
     FLASH中的壞塊處理是一件很棘手的問題,如果沒有有效的管理,對系統(tǒng)的穩(wěn)定性會造成嚴重影響。一個可行的解決方法是生成一張壞塊表,壞塊表中記錄所有壞塊的塊號,并且按塊號從小到大排序,壞塊表在讀寫過程中動態(tài)更新。當讀寫數(shù)據(jù)時,遍歷壞塊表中的塊號,將文件的邏輯地址轉(zhuǎn)換成對應FLASH 物理地址,以保證所用的FLASH地址空間不存在壞塊。

4
系統(tǒng)實現(xiàn)
4.1 結(jié)構(gòu)定義

圖1 - 存儲結(jié)構(gòu)
     系統(tǒng)的存儲結(jié)構(gòu)如圖1所示,在FLASH的Block0位置存放整個系統(tǒng)最重要的數(shù)據(jù)——系統(tǒng)記錄SR(System Record)。選擇Block0的原因是一般FLASH出廠時,都能保證Block0是完好的,因此可以避免壞塊問題帶來的不便。SR其實就是一個定義好的數(shù)據(jù)結(jié)構(gòu),它包括媒質(zhì)信息和文件系統(tǒng)信息兩部分。媒質(zhì)信息包括FLASH存儲器的類型、容量、塊類型的大小和數(shù)量(BlockInfo)、FLASH 操作命令(CommandInfo)等。文件系統(tǒng)信息包括版本信息、各邏輯分區(qū)的起始地址(物理地址)和結(jié)束地址。FLASH設備可以被分成一個或多個邏輯分區(qū),每個邏輯分區(qū)采用的操作方式可以互不相同,如圖1中Device0分區(qū)采用的是線性文件系統(tǒng),Device1分區(qū)采用的是鏈式文件系統(tǒng)。如果采用的是線性文件系統(tǒng),在分區(qū)信息后面加入文件索引表INDEX起始地址、大小等信息;如果采用的是鏈式文件系統(tǒng),則加入文件系統(tǒng)頁大小、文件分配表FAT和文件登記表FRT所在的位置等信息。

    文件登記表FRT位于FAT后的頁中,存放著邏輯分區(qū)中文件的信息,如文件總數(shù)、每個文件的文件代號、位置、長度以及校驗模式。其中,校驗模式用來標識文件讀寫時采用差錯校驗的級別。不同類型的文件采用不同級別的校驗方式。0級不進行校驗,1級ECC校驗,2級逐個字節(jié)比較。

    對于線性文件系統(tǒng)分區(qū),所有文件順序存儲,讀取數(shù)據(jù)時,直接通過INDEX索引得到某個文件的邏輯起始地址,然后從這個地址開始順序搜索,獲取某個偏移位置下的n個連續(xù)Byte。鏈式文件系統(tǒng)是將地址空間分成若干個等分,即Sector,它是操作的最小單位;一個大文件可以分布在不連續(xù)的多個 Sector中,然后通過FAT表將它們連接起來;在FLASH介質(zhì)上實現(xiàn)鏈式文件系統(tǒng),Sector大小的選擇是一個關鍵,由于FLASH的寫操作,擦操作是以Page,Block為單位的,設小了使大塊結(jié)構(gòu)的FLASH寫操作復雜,設多了又浪費空間,因此最好的選擇是將Sector大小設為擦操作的最小單位16K。

    整個邏輯分區(qū)中,INDEX,FAT,FRT表中的內(nèi)容非常重要,一旦因為異常產(chǎn)生錯誤,可能會影響到所有文件;所以,這三個文件都做了備份處理,備份存放于不同的Block中。同時,在對他們處理時,改寫表中的更新狀態(tài)。0xff表示開始更新,0x00表示更新結(jié)束。在文件系統(tǒng)初始化時,讀取它們的更新狀態(tài),如果表中的更新狀態(tài)為0xff,說明該表存在操作異常,可用備份表更正。

4.2  
層次接口
      整個存儲系統(tǒng)分成三層,如圖2所示。

圖2 – 層次結(jié)構(gòu)


1.     操作系統(tǒng)層
    在整個存儲系統(tǒng)中,操作系統(tǒng)扮演的是使用者的角色。當需要數(shù)據(jù)時,它通過調(diào)用文件系統(tǒng)層提供的接口函數(shù)獲取數(shù)據(jù),它不關心數(shù)據(jù)的來源和正確性。

2.     文件系統(tǒng)層
     文件系統(tǒng)層的任務是實現(xiàn)它和操作系統(tǒng)層的函數(shù)接口。在實現(xiàn)方式上,線性文件系統(tǒng)和鏈式文件系統(tǒng)有較大區(qū)別。比如文件讀取mfread,線性文件系統(tǒng)直接讀取所要的字節(jié),而鏈式文件系統(tǒng)是每次先把對應的整個頁讀到文件緩沖區(qū),然后再把所需數(shù)據(jù)拷貝到讀到指定內(nèi)存。文件刪除mfdelete,線性文件系統(tǒng)需要重新整理,不然就會因為大量的數(shù)據(jù)空洞(由于空間太小,無法放入新文件的小塊區(qū)域)使得系統(tǒng)很快沒有可用空間。鏈式文件系統(tǒng)只需修改文件系統(tǒng)的 FAT和FRT,而不用做其他任何處理,當下次寫入操作用到該塊時,自動完成擦除。

3.     驅(qū)動層
     驅(qū)動層的任務是完成與FLASH之間的通訊協(xié)議,實現(xiàn)它和文件系統(tǒng)層的函數(shù)接口。接口函數(shù)包括頁面讀mPageRead,頁面寫 mPageWrite, 塊擦除mBlockErase, 隨機讀取mRnRead, 隨機寫入mRnWrite。mPageRead,mPageWrite,mBlockErase對整頁或塊進行操作,在鏈式文件系統(tǒng)中調(diào)用; mRnRead, mRnWrite對字節(jié)單位進行操作,在線性文件系統(tǒng)中調(diào)用。其中mRnWrite比較麻煩,以寫一個Byte為例,它的操作分三步,首先將目標塊中的所有數(shù)據(jù)讀到內(nèi)存Buffer中,然后將要寫入的數(shù)據(jù)更新到Buffer,擦除目標塊,最后將已更新的Buffer寫回到目標塊,這里的Buffer大小是一個Block。由于嵌入式系統(tǒng)的內(nèi)存資源比較緊張,系統(tǒng)采用了塊交換技術(shù)以降低成本,方法是在FLASH中搜索一個空閑塊,用它充當Buffer的角色。

5
結(jié)論
    通過上面的設計,所實現(xiàn)的存儲系統(tǒng)具有以下的特點:
1.  使用通用模式設計,增強了系統(tǒng)對FLASH設備的兼容性;
2.  使用雙模式文件結(jié)構(gòu)設計,使不同類型的數(shù)據(jù)處理效率同時達到最優(yōu);
3.  使用地址映射表,屏蔽了壞塊帶來的隱患,增強了系統(tǒng)的健壯性;
4.  對重要數(shù)據(jù)采用備份保護,保證不會因為斷電等異常導致系統(tǒng)的崩潰,增強了系統(tǒng)穩(wěn)定性;
5.  采用塊交換技術(shù),節(jié)約系統(tǒng)成本;
6.  進行分級差錯校驗,提高了系統(tǒng)的執(zhí)行效率;
因此,本文所設計的FLASH存儲系統(tǒng),非常適合于嵌入式系統(tǒng)的應用。
參考文獻
[1]     Mike Ficco.《如何在嵌入式電子設備中建立多媒體文件系統(tǒng)》.電子工程專輯,2004.02
[2]     董明,劉加,劉潤生.《適宜于嵌入式多媒體應用的Flash文件系統(tǒng)》.21IC,2003.3
[3]     賈東耀.《uClinux下Nor Flash的JFFS2文件系統(tǒng)構(gòu)建》.21IC,2004.12
[4]     吳雨俊.嵌入式系統(tǒng)中的線性Flash文件系統(tǒng)設計》.21IC,2004.12
本站聲明: 本文章由作者或相關機構(gòu)授權(quán)發(fā)布,目的在于傳遞更多信息,并不代表本站贊同其觀點,本站亦不保證或承諾內(nèi)容真實性等。需要轉(zhuǎn)載請聯(lián)系該專欄作者,如若文章內(nèi)容侵犯您的權(quán)益,請及時聯(lián)系本站刪除。
換一批
延伸閱讀

舍弗勒以"專注驅(qū)動技術(shù)的科技公司"為主題亮相IAA MOBILITY 2025(B3館B40展臺) 合并緯湃科技后首次亮相IAA MOBILITY,展示拓展后的汽車產(chǎn)品組合 憑借在軟件、...

關鍵字: 電氣 軟件 驅(qū)動技術(shù) BSP

香港2025年 9月12日 /美通社/ -- 全球領先的互聯(lián)網(wǎng)社區(qū)創(chuàng)建者 - 網(wǎng)龍網(wǎng)絡控股有限公司 ("網(wǎng)龍"或"本公司",香港交易所股票代碼:777)欣然宣布,其子公司My...

關鍵字: AI 遠程控制 控制技術(shù) BSP

深圳2025年9月11日 /美通社/ -- 2025 年 9 月 10 日,第 26 屆中國國際光電博覽會(簡稱 "CIOE 中國光博會")在深圳盛大開幕。本屆展會吸引力再創(chuàng)新高,全球超3800家優(yōu)質(zhì)...

關鍵字: 自動化 光電 CIO BSP

天津2025年9月11日 /美通社/ -- 國際能源署(IEA)數(shù)據(jù)顯示,2024 年全球數(shù)據(jù)中心電力消耗達 415 太瓦時,占全球總用電量的 1.5%,預計到 2030 年,這一數(shù)字將飆升至 945 太瓦時,近乎翻番,...

關鍵字: 模型 AI 數(shù)據(jù)中心 BSP

北京2025年9月11日 /美通社/ -- 國際9月11日上午,2025年中國國際服務貿(mào)易交易會(以下簡稱"服貿(mào)會")—體育賽事經(jīng)濟高質(zhì)量發(fā)展大會現(xiàn)場,北京經(jīng)濟技術(shù)開發(fā)區(qū)工委委員、管委會副主...

關鍵字: 5G BSP GROUP MOTOR

德國康佳特亮相上海工博會,展示多款應用就緒的嵌入式解決方案平臺

關鍵字: 嵌入式 傳感器 處理器

雙方攜手為客戶打造以存儲為核心的模塊化基礎架構(gòu),支持先進的多裸片架構(gòu)設計

關鍵字: 非易失性存儲 半導體 嵌入式

柏林2025年9月9日 /美通社/ -- 2025年9月5日,納斯達克上市公司優(yōu)克聯(lián)集團(NASDAQ: UCL)旗下全球互聯(lián)品牌GlocalMe,正式亮相柏林國際消費電子展(IFA 2025),重磅推出融合企...

關鍵字: LOCAL LM BSP 移動網(wǎng)絡

深圳2025年9月9日 /美通社/ -- PART 01活動背景 當技術(shù)的鋒芒刺穿行業(yè)壁壘,萬物互聯(lián)的生態(tài)正重塑產(chǎn)業(yè)疆域。2025年,物聯(lián)網(wǎng)產(chǎn)業(yè)邁入?"破界創(chuàng)造"與"共生進化"?的裂變時代——AI大模型消融感知邊界,...

關鍵字: BSP 模型 微信 AIOT

"出海無界 商機無限"助力企業(yè)構(gòu)建全球競爭力 深圳2025年9月9日 /美通社/ -- 2025年8月28日, 由領先商業(yè)管理媒體世界經(jīng)理人攜手環(huán)球資源聯(lián)合主辦、深圳?前海出海e站通協(xié)辦的...

關鍵字: 解碼 供應鏈 AI BSP
關閉