前面的文章中介紹過,每一個PCIe設(shè)備可以只有一個功能(Function),即Fun0。也可以擁有最多8個功能,即多功能設(shè)備(Multi-Fun)。不管這個PCIe設(shè)備擁有多少個功能,其每一個功能都有一個唯一獨立的配置空間(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)和每一項功能(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://wenjunhu.com/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行詳細(xì)地介紹。
前面的關(guān)于PCI總線的文章介紹過PCI總線的配置空間,PCIe總線為了兼容這些PCI設(shè)備,幾乎完整的保留了PCI總線的配置空間。并將配置空間擴展到4KB,用于支持一些PCIe總線中新的功能,如PCI Express Capability、Power Management和MSI/MSI-X等。
下圖是從PCI總線中繼承過來的配置空間:
下圖是PCIe新增的配置空間的示意圖:
-
總線
+關(guān)注
關(guān)注
10文章
2881瀏覽量
88096 -
PCIe
+關(guān)注
關(guān)注
15文章
1239瀏覽量
82665
原文標(biāo)題:【博文連載】PCIe掃盲——BDF與配置空間
文章出處:【微信號:ChinaAET,微信公眾號:電子技術(shù)應(yīng)用ChinaAET】歡迎添加關(guān)注!文章轉(zhuǎn)載請注明出處。
發(fā)布評論請先 登錄
相關(guān)推薦
評論