关于Nand Flash行地址和列地址的计算
Nand Flash行地址和列地址的計算
不說廢話,直接上圖。
從圖中可以看出Nand Flash有2048Blocks,每個Block有64頁,每一頁含有2K的用戶可以使用的數據和64B的OOB。對于用戶來說這64B的數據時不用操作的,讀寫的時候也會忽略這部分。也就是說用戶在讀這一頁數據的時候只會發出11位地址,不會發出12位地址(12位地址包含了讀寫OOB)。
舉一個例子:
加入user想讀0x60000地址處的數據,那么:
由于地址和數據都是通過8位引腳發送的,所以:
第一個周期發送的地址是: 0x60000 & 0xff 或column_address & 0xff;
第二個周期發送的地址為:(0x60000 >> 8) & 0x07或(column_address >> 8) & 0x07;
第三個周期發送的地址為:(0x60000 >> 11) & 0xff,這里是右移11位,不是12位,或row_address & 0xff;
第四個周期發送的地址為:(0x60000 >> 19) & 0xff,或(row_address >> 8) & 0xff;
最后一個周期發送的地址為:(0x60000 >> 27) & 0x01,或(row_address >> 16) & 0x01。
注意:個人覺得關于地址的計算,應該用戶要讀取數據地址的從出發點考慮,用戶讀數據時是不關心OOB的,只關心正常讀取的數據。
總結
以上是生活随笔為你收集整理的关于Nand Flash行地址和列地址的计算的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: Android热修复技术总结
- 下一篇: 抄码机器手持抄码器那个好用进口抄码机进口