那曲檬骨新材料有限公司

電子發燒友App

硬聲App

0
  • 聊天消息
  • 系統消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術視頻
  • 寫文章/發帖/加入社區
會員中心
創作中心

完善資料讓更多小伙伴認識你,還能領取20積分哦,立即完善>

3天內不再提示
電子發燒友網>電子資料下載>嵌入式開發>Linux系統下MTD/CFI驅動介紹

Linux系統下MTD/CFI驅動介紹

2017-11-03 | rar | 0.3 MB | 次下載 | 1積分

資料介紹

 某些Intel的FLASH芯片(如StrataFlash系列)支持多分區,也就是各個分區可以同時進行操作。應該說這是不錯的特性,但是也會帶來些問題。記得當初移植Linux-2.4.21,掛JFFS2文件系統的時候,經常會報一些“Magic bitmask not found”之類的錯誤,跟進去發現FLASH讀出來的都是些0x80之類的數據,查看資料發現該款FLASH有分區的特性,而Linux的FLASH驅動只用一個狀態變量表示整個FLASH的狀態,這就會造成某個分區的實際狀態和系統記錄的不符,從而導致讀FLASH的時候該點實際上不處在讀狀態。當時的解決辦法是,每次讀的時候,不管記錄的狀態是什么,先進入讀狀態再說,當然這會帶來性能的下降,具體損失多少個時鐘周期就不算了。
  話說進入Linux-2.6.x的時代(具體是2.6.13),除了Lock/Unlock(Linux在擦/寫的時候不先Unlock,解決辦法就是初始化的時候先全部Unlock)這個老問題外,竟然多分區的錯誤沒有出現,驚訝之下決定好好研究下Linux的MTD/FLASH驅動。
  說驅動之前,先明確幾個編程要點:
  1:讀寫,要按照總線位寬讀寫,注意不是FLASH芯片位寬(例如背靠背)。
  2:尋址,程序要訪問的地址和FLASH芯片地址引腳得到的值是不一樣的,例如16位的FLASH芯片,對于CPU,0x00和0x01表示2個不同的字節,但是到了FLASH引腳得到的都是0,也就是都指向FLASH的第一個WORD。可以認為地址總線的bit0懸空,或者認為轉換總線, bit0上實際輸出的是bit1。這個解釋了要點1。
  3:芯片手冊提到偏移量都是基于WORD的,而WORD的位寬取決于芯片的位寬,因此在下命令的時候,實際偏移=手冊偏移*buswidth/8。
  4:芯片手冊提到的變量長度(典型如CFI信息)例如2,指的是,變量是個16bit數,但是讀的時候,要讀2個WORD,然后把每個WORD的低8位拼成1個16bit數。讀WORD再拼湊確實挺麻煩,尤其是讀取大結構的時候,不過參照cfi_util.c的cfi_read_pri函數的做法就簡單了。
  5:背靠背,也就是比方說2塊16位的芯片一起接在32位的總線上。帶來的就是尋址的問題,很顯然,首先要按32位讀寫;其次就是下命令的地址,實際偏移=手冊偏移*interleave*device_type/8,device_type=buswidth/interleave,而buswidth這個時候是32(總線位寬)。另外就是背靠背的時候,命令和返回的狀態碼是“雙份的”,例如2塊16位背靠背,讀命令是0x00ff00ff。
  如果不是想寫像Linux那么靈活的代碼(考慮各種接法/位寬/CFI獲取信息等),那事情就簡單很多,只要考慮要點1以及擦除塊的大小就好了,當然如果是背靠背接法,擦除塊的實際大小要乘個interleave。
  進入Linux代碼
  關于CHIP/MAP/MTD之間繞來繞去的關系現在還糊涂著呢,因此下面只是簡單的跟一下脈絡和各個編程要點。
  1:構造map_info結構,指定基址/位寬/大小等信息以及“cfi_probe”限定,然后調用do_map_probe()。
  2:do_map_probe()根據名字“cfi_probe”找到芯片驅動“cfi_probe.c”直接調用cfi_probe()。
  3:cfi_probe()直接調用mtd_do_chip_probe(),傳入cfi_probe_chip()函數指針。
  4:mtd_do_chip_probe()分2步,先調用genprobe_ident_chips()探測芯片信息,后調用check_cmd_set()獲取和初始化芯片命令集(多分區初始化就在里面)。
  5:genprobe_ident_chips()函數如果不考慮多芯片串連的情況,那只需看前面的genprobe_new_chip()調用,完成后cfi.chipshift=cfi.cfiq-》DevSize,2^chipshift=FLASH大小。
?
下載該資料的人也在下載 下載該資料的人還在閱讀
更多 >

評論

查看更多

下載排行

本周

  1. 1AN158 GD32VW553 Wi-Fi開發指南
  2. 1.51MB   |  2次下載  |  免費
  3. 2嵌入式軟件開發符合ISO 26262 功能安全標準
  4. 1.61 MB  |  1次下載  |  免費
  5. 3AN148 GD32VW553射頻硬件開發指南
  6. 2.07MB   |  1次下載  |  免費
  7. 4PZT驅動開關電路
  8. 0.09 MB   |  1次下載  |  免費
  9. 5模擬電路仿真實現
  10. 2.94MB   |  1次下載  |  免費
  11. 6PCB繪制基礎知識
  12. 2.44MB   |  1次下載  |  免費
  13. 7EE-38:ADSP-2181 IDMA端口-周期竊取時序
  14. 75.0KB   |  次下載  |  免費
  15. 8EE-82:使用ADSP-2181 DSP的IO空間對另一個ADSP-2181進行IDMA引導
  16. 86.86KB   |  次下載  |  免費

本月

  1. 1ADI高性能電源管理解決方案
  2. 2.43 MB   |  452次下載  |  免費
  3. 2免費開源CC3D飛控資料(電路圖&PCB源文件、BOM、
  4. 5.67 MB   |  139次下載  |  1 積分
  5. 3基于STM32單片機智能手環心率計步器體溫顯示設計
  6. 0.10 MB   |  132次下載  |  免費
  7. 4美的電磁爐維修手冊大全
  8. 1.56 MB   |  24次下載  |  5 積分
  9. 5如何正確測試電源的紋波
  10. 0.36 MB   |  19次下載  |  免費
  11. 6感應筆電路圖
  12. 0.06 MB   |  10次下載  |  免費
  13. 7LZC3106G高性能諧振控制器中文手冊
  14. 1.29 MB   |  9次下載  |  1 積分
  15. 8萬用表UT58A原理圖
  16. 0.09 MB   |  9次下載  |  5 積分

總榜

  1. 1matlab軟件下載入口
  2. 未知  |  935121次下載  |  10 積分
  3. 2開源硬件-PMP21529.1-4 開關降壓/升壓雙向直流/直流轉換器 PCB layout 設計
  4. 1.48MB  |  420062次下載  |  10 積分
  5. 3Altium DXP2002下載入口
  6. 未知  |  233088次下載  |  10 積分
  7. 4電路仿真軟件multisim 10.0免費下載
  8. 340992  |  191367次下載  |  10 積分
  9. 5十天學會AVR單片機與C語言視頻教程 下載
  10. 158M  |  183335次下載  |  10 積分
  11. 6labview8.5下載
  12. 未知  |  81581次下載  |  10 積分
  13. 7Keil工具MDK-Arm免費下載
  14. 0.02 MB  |  73810次下載  |  10 積分
  15. 8LabVIEW 8.6下載
  16. 未知  |  65988次下載  |  10 積分
百家乐怎么完才能嬴| 如何看百家乐官网的玩法技巧和规则| 在线百家乐策略| 百家乐官网园sun811.com| 喜力百家乐的玩法技巧和规则| 百家乐官网获胜秘决百家乐官网获胜秘诀| 大发888娱乐城官网下载| 百家乐官网存200送200| 康保县| 威尼斯人娱乐城 老品牌值得您信赖| 百家乐官网玩的技巧| 星际娱乐城| 最新百家乐双面数字筹码| 百家乐官网赢退输进有哪些| 迪威网上娱乐| 百家乐PK| 单机百家乐官网小游戏| 新田县| 百家乐官网首选| 大家赢娱乐城| 免费百家乐预测工具| 赌场百家乐官网作弊| 双峰县| 太阳城线上娱乐城| 百家乐路单破解方法| 网络百家乐官网公式打法| 六合彩现金网| 微信百家乐群二维码| 博久百家乐论坛| 足球百家乐官网网上投注| 棋牌王中王| 正品百家乐地址| 足球百家乐官网投注网出租 | 赌场风云国语| 大发888娱乐城取款| 网上百家乐有人赢过嘛| 百家乐官网官网站| 百家乐官网稳赢赌法| 广发百家乐的玩法技巧和规则| 百家乐视频看不到| 百家乐官网现金网开户平台 |