pci配置基地址_PCIe扫盲——基地址寄存器(BAR)详解
基地址寄存器(BAR)在配置空間(Configuration Space)中的位置如下圖所示:
其中Type0 Header最多有6個BAR,而Type1 Header最多有兩個BAR。這就意味著,對于Endpoint來說,最多可以擁有6個不同的地址空間。但是實際應用中基本上不會用到6個,通常1~3個BAR比較常見。
主要注意的是,如果某個設備的BAR沒有被全部使用,則對應的BAR應被硬件全被設置為0,并且告知軟件這些BAR是不可以操作的。對于被使用的BAR來說,其部分低比特位是不可以被軟件操作的,只有其高比特位才可以被軟件操作。而這些不可操作的低比特決定了當前BAR支持的操作類型和可申請的地址空間的大小。
一旦BAR的值確定了(Have been programmed),其指定范圍內的當前設備中的內部寄存器(或內部存儲空間)就可以被訪問了。當該設備確認某一個請求(Request)中的地址在自己的BAR的范圍內,便會接受這請求。
下面用幾個簡單的例子來熟悉BAR的機制:
例1.32-bit Memory Address Space Request
如下圖所示,請求一個4KB的NP-MMIO一般需要以下三個步驟:
Step1:如圖中(1)所示,未初始化的BAR的低比特(11~4)都是0,高比特(31~12)都是不確定的值。所謂初始化,就是系統(軟件)向整個BAR都寫1,來確定BAR的可操作的最低位是哪一位。當前可操作的最低位為12,因此當前BAR可申請的(最小)地址空間大小為4KB(2^12)。如果可操作的最低位為20,則該BAR可申請的(最小)地址空間大小為1MB(2^20)。
Step2:完成初始化(寫1操作)之后,軟件便開始讀取BAR的值,來確定每一個BAR對應的地址空間大小和類型。其中操作的類型一般由最低四位所決定,具體如上圖右側部分所示。
Step3:最后一步是,軟件向BAR的高比特寫入地址空間的起始地址(Start Address)。如圖中所示,為0xF9000000。
例2.64-bit Memory Address Space Request
下面是一個申請64MB P-MMIO地址空間的例子,由于采用的是64-bit的地址,因此需要兩個BAR。具體如下圖所示:
例3.IO Address Space Request
下面是一個申請IO地址空間的例子,如下圖所示:
注:需要特別注意的是,軟件對BAR的檢測與操作(Evaluating)必須是順序執行的,即先BAR0,然后BAR1,……,直到BAR5。當軟件檢測到那些被硬件設置為全0的BAR,則認為這個BAR沒有被使用。
注:無論是PCI還是PCIe,都沒有明確規定,第一個使用的BAR必須是BAR0。事實上,只要設計者原意,完全可以將BAR4作為第一個BAR,并將BAR0~BAR3都設置為不使用。
總結
以上是生活随笔為你收集整理的pci配置基地址_PCIe扫盲——基地址寄存器(BAR)详解的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 平阴玫瑰的功效与作用、禁忌和食用方法
- 下一篇: 树莓酒的功效与作用、禁忌和食用方法