前面的文章中介紹過,每一個PCIe設(shè)備可以只有一個功能(Function),即Fun0。也可以擁有最多8個功能,即多功能設(shè)備(Multi-Fun)。不管這個PCIe設(shè)備擁有多少個功能,其每一個功能都有一個唯一獨(dú)立的配置空間(Configuration Space)與之對應(yīng)。
和PCI總線一樣,PCIe總線中的每一個功能(Function)都有一個唯一的標(biāo)識符與之對應(yīng)。這個標(biāo)識符就是BDF(Bus,Device,F(xiàn)unction),PCIe的配置軟件(即Root的應(yīng)用層,一般是PC)應(yīng)當(dāng)有能力識別整個PCIe總線系統(tǒng)的拓?fù)溥壿嫞约捌渲械拿恳粭l總線(Bus),每一個設(shè)備(Device)和每一項(xiàng)功能(Function)。
在BDF中,Bus Number占用8位,Device Number占用5位,F(xiàn)unction Number占用3位。顯然,PCIe總線最多支持256個子總線,每個子總線最多支持32個設(shè)備,每個設(shè)備最多支持8個功能。
PCIe總線采用的是一種深度優(yōu)先(Depth First Search)的拓?fù)?a href="http://m.xsypw.cn/v/tag/2562/" target="_blank">算法,且Bus0總是分配給Root Complex。Root中包含有集成的Endpoint和多個端口(Port),每個端口內(nèi)部都有一個虛擬的PCI-to-PCI橋(P2P),并且這個橋也應(yīng)有設(shè)備號和功能號。
需要注意的是,每個設(shè)備必須要有功能0(Fun0),其他的7個功能(Fun1~Fun7)都是可選的。
一個簡單的例子如下圖所示:
注:關(guān)于PCIe總線的拓?fù)溥壿嫊诤竺娴奈恼轮羞M(jìn)行詳細(xì)地介紹。
前面的關(guān)于PCI總線的文章介紹過PCI總線的配置空間,PCIe總線為了兼容這些PCI設(shè)備,幾乎完整的保留了PCI總線的配置空間。并將配置空間擴(kuò)展到4KB,用于支持一些PCIe總線中新的功能,如PCI Express Capability、Power Management和MSI/MSI-X等。
下圖是從PCI總線中繼承過來的配置空間:
下圖是PCIe新增的配置空間的示意圖:
-
總線
+關(guān)注
關(guān)注
10文章
2956瀏覽量
89475 -
PCIe
+關(guān)注
關(guān)注
16文章
1329瀏覽量
84839
原文標(biāo)題:【博文連載】PCIe掃盲——BDF與配置空間
文章出處:【微信號:ChinaAET,微信公眾號:電子技術(shù)應(yīng)用ChinaAET】歡迎添加關(guān)注!文章轉(zhuǎn)載請注明出處。
發(fā)布評論請先 登錄
請問Quartus Ⅱ中怎么把.vhd文件加到.bdf文件(.bdf文件放在頂層)中?
ALTERA FPGA 配置芯片剩余空間使用的問題
VHDL由.bdf文件轉(zhuǎn)換成.bsf文件出錯
關(guān)于qutartus中bdf文件的問題,求解!
Quartus II 9.0 Bdf 無法打開
重啟TouchGFX后,.bdf字體不起作用怎么解決?
PCI設(shè)備配置空間研究

Device Studio應(yīng)用實(shí)例之BDF(上)
Device Studio應(yīng)用實(shí)例之BDF(下)
STM32CubeIDE實(shí)用技巧之配置堆空間

納祥科技30V 30A雙N溝道MOSFET NX7011,PIN TO PIN AP20G02BDF

評論