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

當前位置:首頁 > 嵌入式 > 嵌入式硬件
[導讀]嵌入式 Nand 中oob、bbt、ecc含義小結(jié)

芯片內(nèi)部存儲布局及存儲操作特點:

一片Nandflash為一個設(shè)備(device), 其數(shù)據(jù)存儲分層為:

1 (Device) =4096 (Blocks)

1 (Block) -= 32 (Pages/Rows)頁與行是相同的意思,叫法不一樣

1(Page) = 528 (Bytes) =數(shù)據(jù)塊大小(512Bytes) + OOB 塊大小(16Bytes)

在每一頁中,最后16個字節(jié)(又稱OOB)用于NandFlash命令執(zhí)行完后設(shè)置狀態(tài)用,剩余512個字節(jié)又分為前半部分和后半部分??梢酝ㄟ^NandFlash命令00h/01h/50h分別對前半部、后半部、OOB進行定位通過

Nand Flash內(nèi)置的指針指向各自的首地址。

存儲操作特點:

1.擦除操作的最小單位是塊。

2. NandFlash芯片每一位(bit)只能從1變?yōu)?,而不能從0變?yōu)?,所以在對其進行寫入操作之前要一定將相應塊擦除(擦除即是將相應塊得位全部變?yōu)?).

3.OOB部分的第六字節(jié)(即517字節(jié))標志是否是壞塊,如果不是壞塊該值為FF,否則為壞塊。

4.除OOB第六字節(jié)外,通常至少把OOB的前3個字節(jié)存放Nand Flash硬件ECC碼。

BBT:bad blocktable,即壞塊表。各家對nand的壞塊管理方法都有差異。比如專門用nand做存儲的,會把bbt放到block0,因為第0塊一定是好的塊。但是如果nand本身被用來boot,那么第0塊就要存放程序,不能放bbt了。

有的把bbt放到最后一塊,當然,這一塊不能為壞塊。

有的bbt中用2個bits表示1個block的狀態(tài),所以1個字節(jié)可以表示4個blocks。

bbt的大小跟nand大小有關(guān),nand越大,需要的bbt也就越大。

所以具體代碼具體分析。

ECC:

NANDFlash出錯的時候一般不會造成整個Block或是Page不能讀取或是全部出錯,而是整個Page(例如512Bytes)中只有一個或幾個bit出錯。一般使用一種比較專用的校驗——ECC。ECC能糾正單比特錯誤和檢測雙比特錯誤,而且計算速度很快,但對1比特以上的錯誤無法糾正,對2比特以上的錯誤不保證能檢測。

ECC一般每256字節(jié)原始數(shù)據(jù)生成3字節(jié)ECC校驗數(shù)據(jù),這三字節(jié)共24比特分成兩部分:6比特的列校驗和16比特的行校驗,多余的兩個比特置1.

當往NANDFlash的page中寫入數(shù)據(jù)的時候,每256字節(jié)我們生成一個ECC校驗和,稱之為原ECC校驗和,保存到PAGE的OOB(out-of-band)數(shù)據(jù)區(qū)中。其位置就是eccpos[]。

校驗的時候,根據(jù)上述ECC生成原理不難推斷:將從OOB區(qū)中讀出的原ECC校驗和新ECC校驗和按位異或,若結(jié)果為0,則表示不存在錯(或是出現(xiàn)了ECC無法檢測的錯誤);若3個字節(jié)異或結(jié)果中存在11個比特位為1,表示存在一個比特錯誤,且可糾正;若3個字節(jié)異或結(jié)果中只存在1個比特位為1,表示OOB區(qū)出錯;其他情況均表示出現(xiàn)了無法糾正的錯誤。

本站聲明: 本文章由作者或相關(guān)機構(gòu)授權(quán)發(fā)布,目的在于傳遞更多信息,并不代表本站贊同其觀點,本站亦不保證或承諾內(nèi)容真實性等。需要轉(zhuǎn)載請聯(lián)系該專欄作者,如若文章內(nèi)容侵犯您的權(quán)益,請及時聯(lián)系本站刪除( 郵箱:macysun@21ic.com )。
換一批
延伸閱讀
關(guān)閉