哈哈哈哈哈操欧洲电影,久草网在线,亚洲久久熟女熟妇视频,麻豆精品色,久久福利在线视频,日韩中文字幕的,淫乱毛视频一区,亚洲成人一二三,中文人妻日韩精品电影

0
  • 聊天消息
  • 系統(tǒng)消息
  • 評論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會(huì)員中心
創(chuàng)作中心

完善資料讓更多小伙伴認(rèn)識你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

PCIe是什么樣的一個(gè)體系架構(gòu)?

Q4MP_gh_c472c21 ? 來源:人人都是極客 ? 作者:人人都是極客 ? 2021-01-12 16:50 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

硬盤是大家都很熟悉的設(shè)備,一路走來,從HDD到SSD,從SATA到NVMe,作為NVMe SSD的前端接口,PCIe再次進(jìn)入我們的視野。作為x86體系關(guān)鍵的一環(huán),PCIe標(biāo)準(zhǔn)歷經(jīng)PCI,PCI-X和PCIe,走過近30年時(shí)光。其中Host發(fā)現(xiàn)與查找設(shè)備的方式卻一脈沿襲,今天我們先來聊一聊PCIe設(shè)備在一個(gè)系統(tǒng)中是如何發(fā)現(xiàn)與訪問的。

首先我們來看一下在x86系統(tǒng)中,PCIe是什么樣的一個(gè)體系架構(gòu)。下圖是一個(gè)PCIe的拓?fù)浣Y(jié)構(gòu)示例,PCIe協(xié)議支持256個(gè)Bus, 每條Bus最多支持32個(gè)Device,每個(gè)Device最多支持8個(gè)Function,所以由BDF(Bus,device,function)構(gòu)成了每個(gè)PCIe設(shè)備節(jié)點(diǎn)的身份證號。

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

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

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

第二步,系統(tǒng)開始掃描Bus 1,將會(huì)發(fā)現(xiàn)Bridge 3,并發(fā)現(xiàn)這是一個(gè)switch設(shè)備。系統(tǒng)將Bridge 3下面的PCI Bus定為Bus 2,并將該橋的Primary Bus Number 和 Secondary Bus Number寄存器分別設(shè)置成1和2,和上一步一樣暫時(shí)把Bridge 3 的Subordinate Bus Number設(shè)為0xFF。

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

第三步,系統(tǒng)繼續(xù)掃描Bus 2,將會(huì)發(fā)現(xiàn)Bridge 4。繼續(xù)掃描,系統(tǒng)會(huì)發(fā)現(xiàn)Bridge下面掛載的NVMe SSD設(shè)備,系統(tǒng)將Bridge 4下面的PCI Bus定為Bus 3,并將該橋的Primary Bus Number 和 Secondary Bus Number寄存器分別設(shè)置成2和3,因?yàn)锽us3下面掛的是端點(diǎn)設(shè)備(葉子節(jié)點(diǎn)),下面不會(huì)再有下游總線了,因此Bridge 4的Subordinate Bus Number的值可以確定為3。

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

第四步,完成Bus 3的掃描后,系統(tǒng)返回到Bus 2繼續(xù)掃描,會(huì)發(fā)現(xiàn)Bridge 5。繼續(xù)掃描,系統(tǒng)會(huì)發(fā)現(xiàn)下面掛載的NIC設(shè)備,系統(tǒng)將Bridge 5下面的PCI Bus設(shè)置為Bus 4,并將該橋的Primary Bus Number 和 Secondary Bus Number寄存器分別設(shè)置成2和4,因?yàn)镹IC同樣是端點(diǎn)設(shè)備,Bridge 5的Subordinate Bus Number的值可以確定為4。

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

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

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

第六步,系統(tǒng)返回到Bus0繼續(xù)掃描,會(huì)發(fā)現(xiàn)Bridge 2,系統(tǒng)將Bridge 2下面的PCI Bus定為Bus 5。并將Bridge 2的Primary Bus Number 和 Secondary Bus Number寄存器分別設(shè)置成0和5, Graphics card也是端點(diǎn)設(shè)備,因此Bridge 2 的Subordinate Bus Number的值可以確定為5。 至此,掛在PCIe總線上的所有設(shè)備都被掃描到,枚舉過程結(jié)束,Host通過這一過程獲得了一個(gè)完整的PCIe設(shè)備拓?fù)浣Y(jié)構(gòu)。

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

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

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

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

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

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

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

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

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

這個(gè)請求會(huì)被端點(diǎn)設(shè)備接收并執(zhí)行2)NVMe讀取命令操作。如下圖所示,此時(shí)NVMe SSD作為請求者,發(fā)出一個(gè)memory read(MRd)請求,該請求經(jīng)過Switch到達(dá)Host,Host作為完成者會(huì)返回一個(gè)完成事物包(CplD),將訪問結(jié)果返回給NVMe SSD。

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

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

原文標(biāo)題:原來PCIe這么簡單,一定要看!

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

責(zé)任編輯:haq

聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點(diǎn)僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請聯(lián)系本站處理。 舉報(bào)投訴
  • 硬盤
    +關(guān)注

    關(guān)注

    3

    文章

    1366

    瀏覽量

    60056
  • PCIe
    +關(guān)注

    關(guān)注

    16

    文章

    1474

    瀏覽量

    88888

原文標(biāo)題:原來PCIe這么簡單,一定要看!

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

收藏 人收藏
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

    評論

    相關(guān)推薦
    熱點(diǎn)推薦

    西格電力微電網(wǎng)總體架構(gòu)設(shè)計(jì):分層分布式控制體系構(gòu)建

    隨著分布式新能源規(guī)?;瘽B透、負(fù)荷需求多元化升級,微電網(wǎng)作為整合“源、儲(chǔ)、荷、網(wǎng)”多單元的新型能源系統(tǒng),其安全穩(wěn)定、高效經(jīng)濟(jì)運(yùn)行的核心訴求,對總體架構(gòu)設(shè)計(jì)與控制體系提出了更高要求。微電網(wǎng)總體架構(gòu)是系統(tǒng)
    的頭像 發(fā)表于 03-31 11:44 ?441次閱讀
    西格電力微電網(wǎng)總體<b class='flag-5'>架構(gòu)</b>設(shè)計(jì):分層分布式控制<b class='flag-5'>體系</b>構(gòu)建

    當(dāng)前VisionFive開發(fā)板上的JH7100 SoC對于NVDLA軟件站適配的情況是什么樣的?

    如題,想了解下當(dāng)前VisionFive開發(fā)板上的JH7100 SoC對于NVDLA軟件站適配的情況是什么樣的?
    發(fā)表于 03-31 07:44

    PCIE702-2】PCIe 開發(fā)板- XCKU115 FPGA開發(fā)板- 高性能數(shù)據(jù)預(yù)處理板

    PCIE702-2 是款基于 PCIE 總線架構(gòu)的 XCKU115 FPGA 高性 能數(shù)據(jù)預(yù)處理 平臺,該平臺具有 1 個(gè) FMC+(HP
    的頭像 發(fā)表于 03-02 14:20 ?232次閱讀
    【<b class='flag-5'>PCIE</b>702-2】<b class='flag-5'>PCIe</b> 開發(fā)板- XCKU115 FPGA開發(fā)板- 高性能數(shù)據(jù)預(yù)處理板

    PCIE732】光纖卡,具備PCIe接口的萬兆光纖卡

    PCIE732 是款基于 PCIE 總線架構(gòu) Kintex UltraScale FPGA 的 2 路 40G 光纖通道適配器,該板卡具有 1 個(gè)
    的頭像 發(fā)表于 02-05 15:46 ?316次閱讀
    【<b class='flag-5'>PCIE</b>732】光纖卡,具備<b class='flag-5'>PCIe</b>接口的萬兆光纖卡

    PCIE736】基于 PCIE X16 總線架構(gòu) 4 路 QSFP28 100G 光纖通道處理平臺(基于 VU3P FPGA)

    ?PCIE736是款基于PCIE總線架構(gòu)的4路QSFP28100G光纖通道適配器,該板卡具有1個(gè)PCIeGen3x16主機(jī)接口、
    的頭像 發(fā)表于 12-23 15:54 ?1060次閱讀
    【<b class='flag-5'>PCIE</b>736】基于 <b class='flag-5'>PCIE</b> X16 總線<b class='flag-5'>架構(gòu)</b> 4 路 QSFP28 100G 光纖通道處理平臺(基于 VU3P FPGA)

    PCIE725G】青翼凌云科技基于 PCIe x16 總線架構(gòu)的 JFM9VU9P FPGA 高性能數(shù)據(jù)預(yù)處理平臺(100%國產(chǎn)化)

    PCIE725G 是款基于 PCIe x16 總線架構(gòu)的高性能 FMC 接口信號處理平臺,該平臺支持采用 16nm 工藝 JFM9VU9P FPGA作為主處理器。該板卡支持 1
    的頭像 發(fā)表于 11-05 17:30 ?1189次閱讀
    【<b class='flag-5'>PCIE</b>725G】青翼凌云科技基于 <b class='flag-5'>PCIe</b> x16 總線<b class='flag-5'>架構(gòu)</b>的 JFM9VU9P FPGA 高性能數(shù)據(jù)預(yù)處理平臺(100%國產(chǎn)化)

    PCIE737】青翼凌云科技基于全高PCIe x8總線的KU115 FPGA高性能硬件加速卡

    PCIE737是款基于PCIE總線架構(gòu)的KU115 FPGA的12路光纖通道處理平臺,該板卡具有1個(gè)P
    的頭像 發(fā)表于 11-03 16:31 ?881次閱讀
    【<b class='flag-5'>PCIE</b>737】青翼凌云科技基于全高<b class='flag-5'>PCIe</b> x8總線的KU115 FPGA高性能硬件加速卡

    工業(yè)互聯(lián)網(wǎng)架構(gòu)是怎么

    工業(yè)互聯(lián)網(wǎng)架構(gòu)是支撐工業(yè)全要素、全產(chǎn)業(yè)鏈、全價(jià)值鏈互聯(lián)互通的核心框架,通過“數(shù)據(jù)+算力+模型”驅(qū)動(dòng)工業(yè)智能化轉(zhuǎn)型。其體系架構(gòu)通常分為 網(wǎng)絡(luò)層、平臺層、安全層 三大核心層級,并延伸至應(yīng)用生態(tài)與標(biāo)準(zhǔn)
    的頭像 發(fā)表于 10-18 09:37 ?813次閱讀

    PCIE723】青翼凌云科技基于 VU3P FPGA 的 100%全國產(chǎn)化高性能 PCIe 數(shù)據(jù)預(yù)處理載板

    PCIE723 是款基于國產(chǎn) 16nm 工藝 FM9VU3P FPGA 的 PCIE 總線架構(gòu)的全國產(chǎn)化高性能數(shù)據(jù)預(yù)處理平臺,板卡具有 1 個(gè)
    的頭像 發(fā)表于 09-24 12:03 ?1776次閱讀
    【<b class='flag-5'>PCIE</b>723】青翼凌云科技基于 VU3P FPGA 的 100%全國產(chǎn)化高性能 <b class='flag-5'>PCIe</b> 數(shù)據(jù)預(yù)處理載板

    PCIE731】青翼科技基于 PCIe 總線架構(gòu) XC7K325T FPGA 的 2 路 10G SFP+光纖處理平臺

    PCIE731 是款基于 PCIE 總線架構(gòu)的 2 路 10Gbps 光纖通道適 配器,該產(chǎn)品為半高全長 PCIe 卡,適合于目前主流半高
    的頭像 發(fā)表于 08-27 15:06 ?1219次閱讀
    【<b class='flag-5'>PCIE</b>731】青翼科技基于 <b class='flag-5'>PCIe</b> 總線<b class='flag-5'>架構(gòu)</b> XC7K325T FPGA 的 2 路 10G SFP+光纖處理平臺

    嵌入式接口通識知識之PCIe接口

    針腳是數(shù)據(jù)針腳。它用于低帶寬的設(shè)備如聲卡、網(wǎng)卡或其他不需要高速數(shù)據(jù)傳輸?shù)脑O(shè)備。2.PCIe x4:PCIe x4接口有四個(gè)數(shù)據(jù)通道,提供比x1接口更高的帶寬,插槽的長度為39mm,分為前后兩組,
    發(fā)表于 08-21 16:51

    nvme IP開發(fā)之PCIe

    體系架構(gòu) RC是PCIe體系樹形結(jié)構(gòu)中的根節(jié)點(diǎn)。RC主要負(fù)責(zé)配置PCIe總線上的所有設(shè)備,分配資源、處理傳輸請求,并管理數(shù)據(jù)流動(dòng)。在處理器系
    發(fā)表于 05-17 14:54
    罗田县| 甘泉县| 绥江县| 镇宁| 尼木县| 丹棱县| 德安县| 靖江市| 彰化县| 镇坪县| 禹城市| 高阳县| 贵南县| 许昌市| 万全县| 东莞市| 天镇县| 佛冈县| 藁城市| 镇平县| 富蕴县| 南安市| 墨竹工卡县| 哈巴河县| 阳信县| 阿合奇县| 遂川县| 汉阴县| 锡林郭勒盟| 壤塘县| 怀来县| 新泰市| 雷波县| 丹阳市| 文昌市| 崇文区| 会昌县| 宜宾县| 岐山县| 合作市| 互助|