nandflash驅動的讀寫操作實現過程

韋東山的視頻講了nandflash驅動的初始化過程,但是沒有講 '發生 ' 讀 系統調用'時 驅動的硬件操作過程.

我找了半天也沒找到相關的讀寫硬件操作在哪裏.

因爲太晚了,先在這裏記點筆記.打個開頭.

---------------------------------------------------------------------------------------------------------

首先韋東山的例程裏沒有設置nand_chip 結構體的 read_byte 等成員.

所以會在nand_scan()--->nand_set_defaults()中設置

if (!chip->read_byte)
chip->read_byte = busw ? nand_read_byte16 : nand_read_byte;

---------------------------------------------------------------------------------------------------------

在nand文件夾查找cmd_ctrl的調用,會發現,cmd_ctrl使用了以NAND_CMD_開頭的宏

這些宏對應了芯片的硬件操作命令.

讀系統調用要操作硬件必須使用這些宏,那麼找一個例子來搜索

NAND_CMD_READSTART

但是並沒有什麼發現,這個宏還是在命令相關的函數中使用..

在Sh_flctl.c中,有很多類似這樣的函數

flctl_cmdfunc

if (flctl->page_size) {
set_cmd_regs(mtd, command, (NAND_CMD_READSTART << 8)
| NAND_CMD_READ0);
set_addr(mtd, mtd->writesize, page_addr);

---------------------------------------------------------------------------------------------------------

再看chip->cmdfunc = nand_command;

chip->cmd_ctrl(mtd, page_addr, ctrl);
ctrl &= ~NAND_CTRL_CHANGE;
chip->cmd_ctrl(mtd, page_addr >> 8, ctrl);
/* One more address cycle for devices > 32MiB */

---------------------------------------------------------------------------------------------------------

雖然不知道具體調用哪個函數,但是應該是把需要操作的命令存在 int command中,第二週期的命令左移8位保存

然後再調用nand_chip 的讀寫函數



太晚了..眼睛痛,,明天繼續

發佈了30 篇原創文章 · 獲贊 21 · 訪問量 7萬+
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章