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

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

3天內不再提示

淺談閃存控制器架構

jf_pJlTbmA9 ? 來源:PMC ? 作者:PMC ? 2023-08-29 16:10 ? 次閱讀

分析閃存控制器的架構,首先得了解SSD。一般來說SSD的存儲介質分為兩種,一種是采用閃存(Flash芯片)作為存儲介質,另外一種是采用DRAM作為存儲介質。我們通常所說的SSD就是基于閃存的固態硬盤,其采用FLASH芯片作為存儲介質。SSD的基本組成結構包括Flash顆粒和Flash控制器,Flash控制器中有芯片,負責Flash的讀寫、磨損均衡、壽命監控等等。

Flash控制器的主要的工作任務包括三大方面:一是后端訪問Flash,管理后端Flash顆粒,包括各種參數控制和數據IO; 二是前端提供訪問接口和協議:實現對應的SAS/SATA target協議端或者NVMe協議端, 獲取Host發出的IO指令并解碼和生成內部私有數據結果等待執行;三是FTL層核心處理。下面我們具體來介紹一下Flash 控制器是怎樣做這幾件事的。

第一,后端訪問Flash的操作內容

后端訪問Flash首先必須提到的是閃存通道控制器。這個控制器里面有多個通道,每個通道掛多片Flash。它與后端Flash顆粒之間存在托管協議。數據寫入Flash的時候,除了主機發送的數據或者原始數據,其他數據都必須進行ECC校驗。ECC是通用的稱謂,里面有多種算法,其中包括糾錯率較低的BCH算法,LAPC低密度校驗碼等。數據讀出的時候,通過擾碼,加擾,解擾,看ECC是否出現錯誤,若有錯則在糾錯后將芯片發到內部,供后續的程序處理。因此,后端訪問Flash的主要任務即是管理后端Flash顆粒,包括各種參數控制和數據IO。

第二,前端提供訪問接口和協議

前端提供訪問接口和協議,跟主機驅動通信,利用標準格式輸配到系統里面,接收主機端發過來的指令,即完成、實現對應的SAS/SATA target協議端或者NVMe協議端,獲取Host發出的IO指令并解碼和生成內部私有數據結構等待執行。如果遵從NVMe標準,包括提交命令的方法、完成命令的處理方法等都定好了,包括各種隊列、隊列深度,Queue Pair的總體數量最大可以達到64K個,隊列深度也可達64K個,所以,系統里同時可能存在64K×64K IO排著,但是目前的系統是用不到這么多Queue的,因為底下的介質速度還不足以支撐。

第三,FTL層――核心層處理

核心層FTL層,是一款Flash控制器的關鍵競爭力所在。它既可以是純軟件算法,包括元數據管理,數據布局影射、磨損均衡、垃圾回收、緩存策略、片間RAID和掉電元數據一致性保障等內容。同時,它也可以在進行重復性工作時輔以硬加速引擎。這是非純軟件的,輔有硬加速的成分在里面。硬加速涉及到所使用的芯片。有的芯片支持硬加速,比如說鏈表的維護。這是因為做垃圾回收時需要要用到鏈表,拿傳統的軟件算法,插入一個或者追加一些項目,所耗費的CPU周期較大,此時用硬加速并行,再加上一些硬邏輯的加速,則可節省開銷。

Flash控制器的兩種策略和方式:

現有的Flash控制器可采用兩種方式:一種是少量的強核心加少量硬件加速。所謂強核心就是一個核心的性能高、頻率高,分支預判、并行度、單元數量、執行管道,各種參數都高于一般水平。核心強了以后,硬加速就不需要這么多了,可以用少量的硬加速。

另一種方式則是大量弱核心+大量硬加速。比如說16個核心,每個核心比較弱,但是能夠增加執行的并行度,有16個并發核心執行,跑16套處理程序,這是兩種架構。這是一種多核心協作架構模式,其協作方式可以是同構協作也可以是異構協作

1.同構協作就是每個核心做的事都是完全一樣的,處理的步驟完全一樣。如果你的控制器陣列里面有16個IO,有16個核心,每個核心都能處理一個IO,這是同構協作。

2.異構協作則是多個核心做不同的事情。處理同一個IO,第一個IO第一步,第一個核心處理,這個核心處理完以后,把這個IO扔到下一個核心,再處理下一步,等這個核心空出來以后,處理下一個IO的第一步,這就是所謂的流水線了,所謂的異構就是如此。
產品實例:PMC的FlashtecTM NVMe 控制器

這是PMC的控制器,首先它有一個片上網絡,網絡承載16個CPU核心,每個核心里面有一個類似網卡的控制器,網卡連到網絡上,多個CPU之間連起來。簡單說就是4口路由器或者交換機連起來的網絡,多個CPU之間連起來,此外還有硬加速模塊。另外還包括以下幾部分:

RAM控制器,因為芯片上需要有一定量的RAM放臨時數據,寫放大,讀出來寫進去,都要走RAM;

PCIe控制器,這個是跟前端PCIe對等的控制器,IO指令從這兒接收過來;

后端Flash控制器,通過一定數量的通道連Flash顆粒,

加速器(包括緩沖加速器),每做一個操作,都需要有相應的內存,把數據拷到內存里面,內存的維護很費時費力。比如在X86上運行的Linux,其管理內存時需要耗費很多的計算量。對于閃存,精打細算,必須把性能做到極致,因此需用到硬加速。

鏈表加速器,用鏈表來記錄一些信息,哪塊空著,哪塊被應用,這塊用軟件維護很費力,所以需要在這里作加速;

XOR加速器,XOR要用硬加速

最后,來看一下軟件的并行度。16個核心,PMC提供的參考的固件,當然SSD廠商會開發自己的固件,把自己優化的東西放進去,優化的算法放進去?;旧习诉@么一些程序,每個IO讀的地址可能有重疊,重疊就需要有一個鎖定協調,有管命令解析的,有管啟動的,有管日志的,有管磨損均衡的,有管查表的,有管寫數據的,管前端的PCIe Manager,還有負責boot loader的核心,初始化的配置,需要由它處理,data manager,這是主程序,分析IO指令需要干什么,生成一堆的后續步驟下發下去。其實每一塊都可以跑在一個核心上,同一個角色可以復制多份,充分并行。16個核心,達到16份程序并行的運行,16個流水線的Stage,這樣就可以屏蔽處理過程中的時延。
審核編輯:彭菁

聲明:本文內容及配圖由入駐作者撰寫或者入駐合作網站授權轉載。文章觀點僅代表作者本人,不代表電子發燒友網立場。文章及其配圖僅供工程師學習之用,如有內容侵權或者其他違規問題,請聯系本站處理。 舉報投訴
  • 閃存
    +關注

    關注

    16

    文章

    1701

    瀏覽量

    114342
  • 控制器
    +關注

    關注

    112

    文章

    15439

    瀏覽量

    173097
  • FlaSh
    +關注

    關注

    10

    文章

    1567

    瀏覽量

    146904
  • 接口
    +關注

    關注

    33

    文章

    7889

    瀏覽量

    149095
收藏 人收藏

    評論

    相關推薦

    移動機械控制器 車載智能控制器 CAN總線控制器

    控制器機械
    長沙碩博電子科技股份有限公司
    發布于 :2024年06月13日 17:02:51

    為什么無法通過modus ide恢復和閃存控制器?

    我面臨著將生成的 ELF 文件導入 modus ide 的問題。 之后,設置配置調試 elf 文件,沒有出錯,但無法通過 modus ide 恢復和閃存控制器。
    發表于 05-31 08:57

    如何在TC36x微控制器中實現冗余閃存?

    我需要在英飛凌 TC36x 微控制器中實現冗余閃存。 實施過程中我需要做哪些事情?
    發表于 05-30 07:36

    智能單燈控制器,路燈單燈控制器,助力智慧路燈桿解決方案

    控制器
    計訊物聯
    發布于 :2024年05月08日 14:44:52

    淺談母聯控制器

    WQ7C母聯控制器是一種具有自動化測量、LCD顯示、數字通訊為一體的智能化母聯控制模塊。
    的頭像 發表于 04-23 14:43 ?236次閱讀
    <b class='flag-5'>淺談</b>母聯<b class='flag-5'>控制器</b>

    16和32位RISC閃存控制器TMS570LS0914數據表

    電子發燒友網站提供《16和32位RISC閃存控制器TMS570LS0914數據表.pdf》資料免費下載
    發表于 03-20 14:41 ?0次下載
    16和32位RISC<b class='flag-5'>閃存</b>微<b class='flag-5'>控制器</b>TMS570LS0914數據表

    汽車區域控制器架構趨勢下的SmartFET應用

    汽車市場正在轉向區域控制器架構的趨勢方向,而汽車區域控制器架構正朝著分布式、集成化、智能化的方向發展,以實現更高效的數據處理、功能整合與自動駕駛支持。
    的頭像 發表于 03-19 10:41 ?542次閱讀
    汽車區域<b class='flag-5'>控制器</b><b class='flag-5'>架構</b>趨勢下的SmartFET應用

    #控制器 #閥門# 無線傳輸# 脈沖閥門控制器灌溉控制器

    控制器無線傳輸
    pgz1234
    發布于 :2023年10月10日 11:03:13

    STM32L0內核、系統架構、閃存保護介紹

    目標 ? STM32L0突出顯示 ? 核心M0+與M0和M3/4 ? 系統架構 ? 內存映射和引導模式 ? 閃存程序和數據EEPROM ? 內存保護 ? 可用的主要文檔
    發表于 09-12 06:58

    STM32F7x6系統架構_FLASH_RCC和PWR

    STM32 F7 概述? STM32總線架構和存儲映射? 總線架構? 存儲映射? Cache? STM32F7性能? Boot模式? 片上閃存
    發表于 09-11 08:29

    STM32F7系統架構和存儲映射

    STM32 F7 概述? STM32總線架構和存儲映射? 總線架構? 存儲映射? Cache? STM32F7性能? Boot模式? 片上閃存
    發表于 09-08 06:53

    NuMicro M2351系列微控制器的安全特色與應用

    的的微控制器。M2351 系列微控制器運行頻率可高達 64 MHz,內建 512 KB 雙區塊 (Dual Bank) 架構閃存 (Flash),可支持 Over-The-Air (
    發表于 08-28 06:24

    三星24年生產第9代V-NAND閃存 SK海力士25年量產三層堆棧架構321層NAND閃存

    三星24年生產第9代V-NAND閃存 SK海力士25年量產三層堆棧架構321層NAND閃存 存儲領域的競爭愈加激烈,三星電子計劃在2023年正式生產第9代V-NAND閃存,三星第9代V
    發表于 08-21 18:30 ?362次閱讀

    AMBA通用閃存總線協議規范

    AMBA通用閃存總線(GFB)通過在系統和閃存之間提供簡單的接口,簡化了子系統中嵌入式閃存控制器的集成。GFB存在于Flash控制器的管理
    發表于 08-11 07:55

    控制器架構的優點有哪些

    控制器架構優點 域控制器是以以太網為骨干網,面向服務的架構,按功能劃分的集中化加速軟硬件分離,節約整機成本,具體優點包括: 1.服務附加值提升 實現整車OTA功能后,整車廠可以通過系
    的頭像 發表于 07-25 17:53 ?1378次閱讀
    亚洲欧美日韩精品久久_久久精品AⅤ无码中文_日本中文字幕有码在线播放_亚洲视频高清不卡在线观看
    <acronym id="s8ci2"><small id="s8ci2"></small></acronym>
    <rt id="s8ci2"></rt><rt id="s8ci2"><optgroup id="s8ci2"></optgroup></rt>
    <acronym id="s8ci2"></acronym>
    <acronym id="s8ci2"><center id="s8ci2"></center></acronym>