久久久久久久999_99精品久久精品一区二区爱城_成人欧美一区二区三区在线播放_国产精品日本一区二区不卡视频_国产午夜视频_欧美精品在线观看免费

 找回密碼
 立即注冊(cè)

QQ登錄

只需一步,快速開(kāi)始

搜索
查看: 3031|回復(fù): 0
收起左側(cè)

Nand flash驅(qū)動(dòng)工作原理

[復(fù)制鏈接]
ID:373920 發(fā)表于 2018-7-18 10:58 | 顯示全部樓層 |閱讀模式
在介紹具體如何寫(xiě)Nand Flash驅(qū)動(dòng)之前,我們先要了解,大概的,整個(gè)系統(tǒng),和Nand Flash相關(guān)的部分的驅(qū)動(dòng)工作流程,這樣,對(duì)于后面的驅(qū)動(dòng)實(shí)現(xiàn),才能更加清楚機(jī)制,才更容易實(shí)現(xiàn),否則就是,即使寫(xiě)完了代碼,也還是沒(méi)搞懂系統(tǒng)是如何工作的了。
讓我們以最常見(jiàn)的,Linux內(nèi)核中已經(jīng)有的三星的Nand Flash驅(qū)動(dòng),來(lái)解釋Nand Flash驅(qū)動(dòng)具體流程和原理。
此處是參考2.6.29版本的Linux源碼中的\drivers\mtd\nand\s3c2410.c,以2410為例。
1. 在nand flash驅(qū)動(dòng)加載后,第一步,調(diào)用對(duì)應(yīng)的init函數(shù) ---- s3c2410_nand_init: 去將nand flash驅(qū)動(dòng)注冊(cè)到Linux驅(qū)動(dòng)框架中。
2. 驅(qū)動(dòng)本身真正的開(kāi)始,是從probe函數(shù): s3c2410_nand_probe->s3c24xx_nand_probe,
在probe過(guò)程中:
clk_enable //打開(kāi)nand flash控制器的clock時(shí)鐘,
request_mem_region //去申請(qǐng)驅(qū)動(dòng)所需要的一些內(nèi)存等相關(guān)資源。
s3c2410_nand_inithw //去初始化硬件相關(guān)的部分,主要是關(guān)于時(shí)鐘頻率的計(jì)算,以及啟用nand flash控制器,使得硬件初始化好了,后面才能正常工作。
3. 需要多解釋一下的,是這部分代碼:
for (setno = 0; setno < nr_sets; setno++, nmtd++) {
pr_debug("initialising set %d (%p, info %p)\n", setno, nmtd, info);
/*調(diào)用init chip去掛載你的nand驅(qū)動(dòng)的底層函數(shù)到"nand flash的結(jié)構(gòu)體"中,以及設(shè)置對(duì)應(yīng)的"ecc mode",掛載ecc相關(guān)的函數(shù) */
s3c2410_nand_init_chip(info, nmtd, sets);
/* scan_ident,掃描nand 設(shè)備,設(shè)置nand flash的默認(rèn)函數(shù),獲得物理設(shè)備的具體型號(hào)以及對(duì)應(yīng)各個(gè)特性參數(shù),這部分算出來(lái)的一些值,對(duì)于nand flash來(lái)說(shuō),是最主要的參數(shù),比如nand flash的芯片的大小,塊大小,頁(yè)大小等。 */
nmtd->scan_res = nand_scan_ident(&nmtd->mtd, (sets) ? sets->nr_chips : 1);
if (nmtd->scan_res == 0) {
s3c2410_nand_update_chip(info, nmtd);
/*掃描的后一階段,經(jīng)過(guò)前面的scan_ident,我們已經(jīng)獲得對(duì)應(yīng)nand flash的硬件的各個(gè)參數(shù),
*然后就可以在scan tail中,根據(jù)這些參數(shù),去設(shè)置其他一些重要參數(shù),尤其是ecc的layout,即ecc是如何在oob中擺放的,
*最后,再去進(jìn)行一些初始化操作,主要是根據(jù)你的驅(qū)動(dòng),如果沒(méi)有實(shí)現(xiàn)一些函數(shù)的話,那么就用系統(tǒng)默認(rèn)的。 */
nand_scan_tail(&nmtd->mtd);
/*add partion,根據(jù)你的nand flash的分區(qū)設(shè)置,去分區(qū) */
s3c2410_nand_add_partition(info, nmtd, sets);
}
if (sets != NULL)
sets++;
}
4. 等所有的參數(shù)都計(jì)算好了,函數(shù)都掛載完畢,系統(tǒng)就可以正常工作了。
上層訪問(wèn)你的nand falsh中的數(shù)據(jù)的時(shí)候,通過(guò)MTD層,一層層調(diào)用,最后調(diào)用到你所實(shí)現(xiàn)的那些底層訪問(wèn)硬件數(shù)據(jù)/緩存的函數(shù)中。
回復(fù)

使用道具 舉報(bào)

本版積分規(guī)則

小黑屋|51黑電子論壇 |51黑電子論壇6群 QQ 管理員QQ:125739409;技術(shù)交流QQ群281945664

Powered by 單片機(jī)教程網(wǎng)

快速回復(fù) 返回頂部 返回列表
主站蜘蛛池模板: 欧美福利视频 | 日韩国产中文字幕 | 性做久久久久久久免费看 | 91福利在线视频 | 手机在线免费av | 69精品人人人人 | 成人国产网站 | 中文字幕精品一区久久久久 | 国产精品九九 | 国产精品入口夜色视频大尺度 | 精品日韩在线观看 | 日本在线网站 | 日本三极片 | 亚洲成人精品视频 | 福利视频一区二区 | 亚洲美女一区 | 91精品国产综合久久久久久 | 中文字幕av久久爽av | 蜜臀久久99精品久久久久久宅男 | 草逼com | 亚洲乱码在线观看 | 国产三级在线观看 | 午夜视频在线看 | 亚洲男人天堂av | 日本大尺度吃奶做爰久久久绯色 | 伊人网综合 | 中文字字幕 | 97久久精品人人澡人人爽 | 欧美日韩在线一区二区三区 | 日韩成人精品 | 精品国产91乱码一区二区三区 | 91精品91久久久中77777 | 亚洲视频在线播放 | 夜夜精品视频 | 91色网站| 欧美精品久久久久久久多人混战 | 国产伦精品一区二区三区在线 | 亚洲另类自拍 | 亚洲人成免费 | 三级视频在线观看 | 精品国产毛片 |