基地址寄存器(BAR)在配置空間(Configuration Space)中的位置如下圖所示:

其中Type0 Header最多有6個(gè)BAR,而Type1 Header最多有兩個(gè)BAR。這就意味著,對(duì)于Endpoint來(lái)說(shuō),最多可以擁有6個(gè)不同的地址空間。但是實(shí)際應(yīng)用中基本上不會(huì)用到6個(gè),通常1~3個(gè)BAR比較常見(jiàn)。
主要注意的是,如果某個(gè)設(shè)備的BAR沒(méi)有被全部使用,則對(duì)應(yīng)的BAR應(yīng)被硬件全被設(shè)置為0,并且告知軟件這些BAR是不可以操作的。對(duì)于被使用的BAR來(lái)說(shuō),其部分低比特是不可以被軟件操作的,只有其高位才可以被軟件操作。而這些不可操作的低比特決定了當(dāng)前BAR支持的操作類型和可申請(qǐng)的地址空間的大小。
一旦BAR的值確定了(Have been programmed),其指定范圍內(nèi)的當(dāng)前設(shè)備中的內(nèi)部寄存器(或內(nèi)部存儲(chǔ)空間)就可以被訪問(wèn)了。當(dāng)該設(shè)備確認(rèn)某一個(gè)請(qǐng)求(Request)中的地址在自己的BAR的范圍內(nèi),便會(huì)接受這請(qǐng)求。
下面用幾個(gè)簡(jiǎn)單的例子來(lái)熟悉BAR的機(jī)制:
例1.32-bit Memory Address Space Request
如下圖所示,請(qǐng)求一個(gè)4KB的NP-MMIO一般需要以下三個(gè)步驟:

Step1:如圖中(1)所示,未初始化的BAR的低比特(11~4)都是0,高比特(31~12)都是不確定的值。所謂初始化,就是系統(tǒng)(軟件)向整個(gè)BAR都寫1,來(lái)確定BAR的可操作的最低位是哪一位。當(dāng)前可操作的最低位為12,因此當(dāng)前BAR可申請(qǐng)的地址空間大小為4KB(2^12)。如果可操作的最低位為20,則改BAR可申請(qǐng)的地址空間大小為1MB(2^20)。
Step2:完成初始化(寫1操作)之后,軟件便開始讀取BAR的值,來(lái)確定每一個(gè)BAR對(duì)應(yīng)的地址空間大小和類型。其中操作的類型一般由最低四位所決定,具體如上圖右側(cè)部分所示。
Step3:最后一步是,軟件向BAR的高比特寫入地址空間的起始地址(Start Address)。如圖中所示,為0xF9000000。
例2.64-bit Memory Address Space Request
下面是一個(gè)申請(qǐng)64MB NP-MMIO地址空間的例子,由于采用的是64-bit的地址,因此需要兩個(gè)BAR。具體如下圖所示:

例3.IO Address Space Request
下面是一個(gè)申請(qǐng)IO地址空間的例子,如下圖所示:

注:需要特別注意的是,軟件對(duì)BAR的檢測(cè)與操作(Evaluating)必須是順序執(zhí)行的,即先BAR0,然后BAR1,……,直到BAR5。當(dāng)軟件檢測(cè)到那些被硬件設(shè)置為全0的BAR,則認(rèn)為這個(gè)BAR沒(méi)有被使用。
注:無(wú)論是PCI還是PCIe,都沒(méi)有明確規(guī)定,第一個(gè)使用的BAR必須是BAR0。事實(shí)上,只要設(shè)計(jì)者原意,完全可以將BAR4作為第一個(gè)BAR,并將BAR0~BAR3都設(shè)置為不使用。
-
寄存器
+關(guān)注
關(guān)注
31文章
5608瀏覽量
129943 -
PCIe
+關(guān)注
關(guān)注
16文章
1459瀏覽量
88376
原文標(biāo)題:【博文連載】PCIe掃盲——基地址寄存器(BAR)詳解
文章出處:【微信號(hào):ChinaAET,微信公眾號(hào):電子技術(shù)應(yīng)用ChinaAET】歡迎添加關(guān)注!文章轉(zhuǎn)載請(qǐng)注明出處。
發(fā)布評(píng)論請(qǐng)先 登錄
從“能用”到“懂原理”:ARMv8寄存器架構(gòu)深度拆解
LAT1170+如何理解 RAMECC FAR 寄存器的值
【NCS隨筆】nRF54L15使用UICR寄存器保存數(shù)據(jù)
嵌入式系統(tǒng)必懂的 20 個(gè)寄存器
NVMe高速傳輸之?dāng)[脫XDMA設(shè)計(jì)32:寄存器功能驗(yàn)證與分析2
?SN74LVC595A 8位移位寄存器技術(shù)文檔總結(jié)
?SN74HCT595 8位移位寄存器技術(shù)解析與應(yīng)用指南
TPIC6595 8位功率移位寄存器技術(shù)文檔摘要
?TPIC6B595 8位功率移位寄存器技術(shù)文檔總結(jié)
SN74LV594A:2-5.5V帶輸出寄存器的8位移位寄存器技術(shù)解析
?TLC6C5912 12通道移位寄存器LED驅(qū)動(dòng)器技術(shù)文檔總結(jié)
?TLC6C5816-Q1 16位移位寄存器LED驅(qū)動(dòng)器技術(shù)文檔總結(jié)
使用寄存器點(diǎn)亮LED燈
第四章 什么是寄存器
如何用C語(yǔ)言操作寄存器——瑞薩RA系列FSP庫(kù)開發(fā)實(shí)戰(zhàn)指南(10)
幾個(gè)簡(jiǎn)單的例子來(lái)熟悉寄存器BAR的機(jī)制
評(píng)論