<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天內不再提示

PCIe是什么樣的一個體系架構?

Q4MP_gh_c472c21 ? 來源:人人都是極客 ? 作者:人人都是極客 ? 2021-01-12 16:50 ? 次閱讀

硬盤是大家都很熟悉的設備,一路走來,從HDD到SSD,從SATA到NVMe,作為NVMe SSD的前端接口,PCIe再次進入我們的視野。作為x86體系關鍵的一環,PCIe標準歷經PCI,PCI-X和PCIe,走過近30年時光。其中Host發現與查找設備的方式卻一脈沿襲,今天我們先來聊一聊PCIe設備在一個系統中是如何發現與訪問的。

首先我們來看一下在x86系統中,PCIe是什么樣的一個體系架構。下圖是一個PCIe的拓撲結構示例,PCIe協議支持256個Bus, 每條Bus最多支持32個Device,每個Device最多支持8個Function,所以由BDF(Bus,device,function)構成了每個PCIe設備節點的身份證號。

04641218-528d-11eb-8b86-12bb97331649.jpg

PCIe體系架構一般由root complex,switch,endpoint等類型的PCIe設備組成,在root complex和switch中通常會有一些embeded endpoint(這種設備對外不出PCIe接口)。這么多的設備,CPU啟動后要怎么去找到并認出它們呢? Host對PCIe設備掃描是采用了深度優先算法,其過程簡要來說是對每一個可能的分支路徑深入到不能再深入為止,而且每個節點只能訪問一次。我們一般稱這個過程為PCIe設備枚舉。枚舉過程中host通過配置讀事物包來獲取下游設備的信息,通過配置寫事物包對下游設備進行設置。 第一步,PCI Host主橋掃描Bus 0上的設備(在一個處理器系統中,一般將Root complex中與Host Bridge相連接的PCI總線命名為PCI Bus 0),系統首先會忽略Bus 0上的embedded EP等不會掛接PCI橋的設備,主橋發現Bridge 1后,將Bridge1 下面的PCI Bus定為 Bus 1,系統將初始化Bridge 1的配置空間,并將該橋的Primary Bus Number 和 Secondary Bus Number寄存器分別設置成0和1,以表明Bridge1 的上游總線是0,下游總線是1,由于還無法確定Bridge1下掛載設備的具體情況,系統先暫時將Subordinate Bus Number設為0xFF。

0484df70-528d-11eb-8b86-12bb97331649.jpg

第二步,系統開始掃描Bus 1,將會發現Bridge 3,并發現這是一個switch設備。系統將Bridge 3下面的PCI Bus定為Bus 2,并將該橋的Primary Bus Number 和 Secondary Bus Number寄存器分別設置成1和2,和上一步一樣暫時把Bridge 3 的Subordinate Bus Number設為0xFF。

04b89c52-528d-11eb-8b86-12bb97331649.jpg

第三步,系統繼續掃描Bus 2,將會發現Bridge 4。繼續掃描,系統會發現Bridge下面掛載的NVMe SSD設備,系統將Bridge 4下面的PCI Bus定為Bus 3,并將該橋的Primary Bus Number 和 Secondary Bus Number寄存器分別設置成2和3,因為Bus3下面掛的是端點設備(葉子節點),下面不會再有下游總線了,因此Bridge 4的Subordinate Bus Number的值可以確定為3。

04e2c1bc-528d-11eb-8b86-12bb97331649.jpg

第四步,完成Bus 3的掃描后,系統返回到Bus 2繼續掃描,會發現Bridge 5。繼續掃描,系統會發現下面掛載的NIC設備,系統將Bridge 5下面的PCI Bus設置為Bus 4,并將該橋的Primary Bus Number 和 Secondary Bus Number寄存器分別設置成2和4,因為NIC同樣是端點設備,Bridge 5的Subordinate Bus Number的值可以確定為4。

05067904-528d-11eb-8b86-12bb97331649.jpg

第五步,除了Bridge 4和Bridge 5以外,Bus2下面沒有其他設備了,因此返回到Bridge 3,Bus 4是找到的掛載在這個Bridge下的最后一個bus號,因此將Bridge 3的Subordinate Bus Number設置為4。Bridge 3的下游設備都已經掃描完畢,繼續向上返回到Bridge 1,同樣將Bridge 1的Subordinate Bus Number設置為4。

0546e20a-528d-11eb-8b86-12bb97331649.jpg

第六步,系統返回到Bus0繼續掃描,會發現Bridge 2,系統將Bridge 2下面的PCI Bus定為Bus 5。并將Bridge 2的Primary Bus Number 和 Secondary Bus Number寄存器分別設置成0和5, Graphics card也是端點設備,因此Bridge 2 的Subordinate Bus Number的值可以確定為5。 至此,掛在PCIe總線上的所有設備都被掃描到,枚舉過程結束,Host通過這一過程獲得了一個完整的PCIe設備拓撲結構。

05942f9c-528d-11eb-8b86-12bb97331649.jpg

系統上電以后,host會自動完成上述的設備枚舉過程。除一些專有系統外,普通系統只會在開機階段進行進行設備的掃描,啟動成功后(枚舉過程結束),即使插入一個PCIe設備,系統也不會再去識別它。 在linux操作系統中,我們可以通過lspci –v -t命令來查詢系統上電階段掃描到的PCIe設備,執行結果會以一個樹的形式列出系統中所有的pcie設備。如下圖所示,其中黃色方框中的PCIe設備是北京憶芯科技公司(Bejing Starblaze Technology Co., LTD.)推出的STAR1000系列NVMe SSD主控芯片,圖中顯示的9d32是Starblaze在PCI-SIG組織的注冊碼,1000是設備系列號。

05d2894a-528d-11eb-8b86-12bb97331649.png

STAR1000設備的BDF也可以從上圖中找出,其中bus是0x3C,device是0x00,function是0x0,BDF表示為3C:00.0,與之對應的上游端口是00:1d.0。 我們可以通過“lspci –xxx –s 3C:00.0”命令來列出該設備的PCIe詳細信息(技術發燒友或數字控請關注該部分)。這些內容存儲在PCIe配置空間,它們描述的是PCIe本身的特性。如下圖所示(低位地址0x00在最左邊),可以看到這是一個非易失性存儲控制器,0x00起始地址是PCIe的Vendor ID和Device ID。Class code 0x010802表示這是一個NVMe存儲設備。0x40是第一組capability的指針,如果你需要查看PCIe的特性,就需要從這個位置開始去查詢,在每組特征的頭字段都會給出下一組特性的起始地址。從0x40地址開始依次是power management,MSI中斷,鏈路控制與狀態,MSI-X中斷等特性組。這兒特別列出了鏈路特征中的一個0x43字段,表示STAR1000設備是一個x4lane的鏈接,支持PCIe Gen3速率(8Gbps)。

05f95cc8-528d-11eb-8b86-12bb97331649.png

當然也可以使用lspci –vvv –s 3C:00.0命令來查看設備特性,初學者看到下面的列表也就一目了然了。

064affd8-528d-11eb-8b86-12bb97331649.jpg

Host在枚舉設備的同時也會對設備進行配置,每個PCIe設備都會指定一段CPU memory訪問空間,從上面的圖中我們可以看到這個設備支持兩段訪問空間,一段的大小是1M byte,另一段的大小是256K byte,系統會分別指定它們的基地址?;刂放渲猛瓿梢院?,Host就可以通過地址來對PCIe memory空間進行訪問了。 PCIe memory空間關聯的是PCIe設備物理功能,對于STAR1000系列芯片而言,物理功能是NVMe,memory中存放的是NMVe的控制與狀態信息,對于NMVe的控制以及工作狀態的獲取,都需要通過memory訪問來實現。 下面以NVMe命令下發為例簡單描述PCIe設備的memory訪問。NVMe命令下發的基本操作是1)Host寫doorbell寄存器,此時使用PCIe memory寫請求。如下圖所示,host發出一個memory write(MWr)請求,該請求經過switch到達要訪問的NVMe SSD設備。

06816942-528d-11eb-8b86-12bb97331649.jpg

這個請求會被端點設備接收并執行2)NVMe讀取命令操作。如下圖所示,此時NVMe SSD作為請求者,發出一個memory read(MRd)請求,該請求經過Switch到達Host,Host作為完成者會返回一個完成事物包(CplD),將訪問結果返回給NVMe SSD。

06a85944-528d-11eb-8b86-12bb97331649.jpg

這樣,一個NVMe的命令下發過程就完成了。同樣,NVMe的其他操作比如各種隊列操作,命令與完成,數據傳輸都是通過PCIe memory訪問的方式進行的,此處不再詳述。 通過上面的描述,相信能夠幫助大家了解PCIe的設備枚舉和memory空間訪問。以后會繼續與大家探討PCIe的其他內容,比如PCIe的協議分層,鏈路建立,功耗管理等等。目前PCIe協議還正在不斷的快速演進中,2017年發布的PCIe Gen4標準,每條Serdes支持的速率已經達到16Gbps,Gen5也在加速制定中,其速率會再翻一倍達到32Gbps。Starblaze會緊跟技術的發展趨勢,提供速率更高,性能更好更穩定的NVMe SSD系列產品。

原文標題:原來PCIe這么簡單,一定要看!

文章出處:【微信公眾號:嵌入式ARM】歡迎添加關注!文章轉載請注明出處。

責任編輯:haq

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

    關注

    3

    文章

    1234

    瀏覽量

    56316
  • PCIe
    +關注

    關注

    13

    文章

    1083

    瀏覽量

    80867

原文標題:原來PCIe這么簡單,一定要看!

文章出處:【微信號:gh_c472c2199c88,微信公眾號:嵌入式微處理器】歡迎添加關注!文章轉載請注明出處。

收藏 人收藏

    評論

    相關推薦

    【RISC-V開放架構設計之道|閱讀體驗】本別出心裁的RISC-V架構之書(第章)

    的內容,雖然簡單的兩頁指令匯總表格,但是其嚴謹的內容告訴我們,這是用來介紹RISC-V體系架構相關的專業書籍。 翻開書中的第章,為
    發表于 01-24 19:06

    【RISC-V開放架構設計之道|閱讀體驗】學習處理器體系架構本好書

    感謝電子發燒友論壇和電子工業出版社提供的試讀機會。 《RISC-V開放架構設計之道》由RISC-V架構的作者、著名的計算機體系架構專家David Patterson親自主筆撰寫。Dav
    發表于 01-23 20:08

    ADIS16375的陀螺儀輸出角度是什么樣的角度?

    想知道ADIS16375這款IMU的輸出角度是什么樣的角度?是不是姿態角?其參考坐標系是什么?輸出角的實時精度是多少?ADIS16365、ADIS16334、ADIS16445、ADIS16485這四款IMU能夠輸出角度嗎?若果能,分別是
    發表于 12-29 06:17

    AD7779?DRDY引腳輸出應該是什么樣的波形?

    AD7779DRDY 引腳輸出應該是什么樣的波形,我測出來的是連續十五脈沖,后面是很長
    發表于 12-11 06:13

    SigmaStudio 3.9開發ADAU1701時里面的adi algorithms里有automatic EQ是什么樣功能的EQ?

    SigmaStudio 3.9 開發ADAU1701時里面的adi algorithms里有automatic EQ是什么樣功能的EQ?般用來做什么?還有加入此EQ后編譯過不了,提示錯誤和請聯系ADI,是什么原因?還沒開放嗎
    發表于 11-30 06:36

    多運放集成芯片未使用運放輸入輸出接口的端接方法是什么樣的?

    我使用的OP4177集成四運放芯片,只使用了其中的兩運放,另外兩運放我把輸入輸出全部接地的時候,芯片發熱嚴重,只把輸入接地,輸出懸空的時候,芯片不發熱了,但是輸出鎖定到供電電壓的上限+15V。我想詢問下,多運放集成芯片未使
    發表于 11-21 08:22

    DC-500MHz,2000倍電壓放大,該選擇什么樣的放大器?

    我想放大從電感線圈出來的脈沖信號,帶寬大概DC-500MHz。信號很小,電壓放大倍數需要2000倍左右,我應該選擇什么樣的放大器?提前感謝大家的幫助?。?!
    發表于 11-21 08:21

    體驗紫光PCIE之使用WinDriver驅動紫光PCIE

    開始和主機怎么交互起來都是問題。入門PCIE協議,會發現繁多也難懂——PCIE體系龐大足
    發表于 11-17 14:35

    淺談城市綜合管廊智慧配電運維管理平臺體系架構

    摘要:智能化是綜合管廊運維管理的發展方向,但多地先后建設的綜合管廊運維管理平臺都缺乏體系架構的統一標準。本文在分析綜合管廊運維管理平臺體系架構的研究現狀的基礎上,提出了一種5層智慧運維
    的頭像 發表于 10-16 10:29 ?363次閱讀
    淺談城市綜合管廊智慧配電運維管理平臺<b class='flag-5'>體系</b><b class='flag-5'>架構</b>

    網絡安全體系基礎架構建設

    網絡安全體系基礎架構建設知識 ? ?
    的頭像 發表于 09-11 09:36 ?1317次閱讀
    網絡安全<b class='flag-5'>體系</b>基礎<b class='flag-5'>架構</b>建設

    ARM Cortex-A系列ARMv8-A程序員指南

    ARMv8-A是針對應用配置文件的最新代ARM架構。 在本書中,名稱ARMv8用于描述整個體系結構,它現在包括32位執行狀態和64位執行狀態。 ARMv8引入了使用64位寬寄存器執行的能力,但提供
    發表于 08-22 07:22

    PCIe AMBA集成指南

    和AMBA ACE協議和ARM架構。 該文檔涵蓋以下主題: ·本文檔中使用的術語說明。 ·針對PCIe事務的ARM內存類型使用指南。 ·如何遵守ARM處理元件(PE)的PCIe事務的ARM內存模型要求
    發表于 08-17 07:25

    ARMv8-M體系結構及其程序員模型簡介

    Armv8體系結構有幾個不同的配置文件。這些配置文件是體系結構的變體針對不同的市場和用例。Armv8-M體系結構就是其中之配置文件。 Arm定義了三
    發表于 08-08 06:18

    了解體系結構 - 介紹 Arm 體系結構

    。該體系結構為軟件開發人員公開了通用的指令集和工作流程,也稱為程序員模型。這有助于確保架構的不同實現之間的互操作性,以便軟件可以在不同的 Arm 設備上運行。本指南為任何對此感興趣
    發表于 08-01 14:35

    可以將多個PCIe設備連接到般的單個PCIe控制器嗎?

    我們可以將多個 PCIe 設備 (IC) 連接到般的單個 PCIe 控制器(在我們的案例中更具體地說是 NXP LS20xxA 處理器)嗎? 例如,將四不同的
    發表于 05-05 07:35
    亚洲欧美日韩精品久久_久久精品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>