一区二区三区三上|欧美在线视频五区|国产午夜无码在线观看视频|亚洲国产裸体网站|无码成年人影视|亚洲AV亚洲AV|成人开心激情五月|欧美性爱内射视频|超碰人人干人人上|一区二区无码三区亚洲人区久久精品

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

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

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

幾個(gè)簡(jiǎn)單的例子來(lái)熟悉寄存器BAR的機(jī)制

SwM2_ChinaAET ? 來(lái)源:未知 ? 作者:李倩 ? 2018-05-09 09:25 ? 次閱讀

基地址寄存器(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都寫(xiě)1,來(lái)確定BAR的可操作的最低位是哪一位。當(dāng)前可操作的最低位為12,因此當(dāng)前BAR可申請(qǐng)的地址空間大小為4KB(2^12)。如果可操作的最低位為20,則改BAR可申請(qǐng)的地址空間大小為1MB(2^20)。

Step2:完成初始化(寫(xiě)1操作)之后,軟件便開(kāi)始讀取BAR的值,來(lái)確定每一個(gè)BAR對(duì)應(yīng)的地址空間大小和類型。其中操作的類型一般由最低四位所決定,具體如上圖右側(cè)部分所示。

Step3:最后一步是,軟件向BAR的高比特寫(xiě)入地址空間的起始地址(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è)置為不使用。

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

    關(guān)注

    31

    文章

    5402

    瀏覽量

    122873
  • PCIe
    +關(guān)注

    關(guān)注

    16

    文章

    1304

    瀏覽量

    84443

原文標(biāo)題:【博文連載】PCIe掃盲——基地址寄存器(BAR)詳解

文章出處:【微信號(hào):ChinaAET,微信公眾號(hào):電子技術(shù)應(yīng)用ChinaAET】歡迎添加關(guān)注!文章轉(zhuǎn)載請(qǐng)注明出處。

收藏 人收藏

    評(píng)論

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

    接口的控制與狀態(tài)寄存器什么作用

    接口的控制與狀態(tài)寄存器(Control and Status Registers,簡(jiǎn)稱CSR)是計(jì)算機(jī)系統(tǒng)中用于控制和監(jiān)控硬件設(shè)備操作的寄存器。它們是硬件設(shè)備與其驅(qū)動(dòng)程序之間的橋梁,允許軟件控制硬件
    的頭像 發(fā)表于 10-17 10:42 ?1263次閱讀

    寄存器間接尋址和寄存器尋址的區(qū)別

    寄存器間接尋址和寄存器尋址是計(jì)算機(jī)體系結(jié)構(gòu)中兩種重要的尋址方式,它們?cè)谥噶顖?zhí)行過(guò)程中起著關(guān)鍵作用。下面將從定義、原理、特點(diǎn)、應(yīng)用場(chǎng)景以及區(qū)別等方面對(duì)這兩種尋址方式進(jìn)行詳細(xì)闡述。
    的頭像 發(fā)表于 10-05 17:13 ?2990次閱讀

    ARM處理寄存器組織及功能

    ARM處理寄存器組織是其核心架構(gòu)的重要組成部分,對(duì)于理解ARM處理的運(yùn)行機(jī)制和性能特點(diǎn)具有重要意義。以下是對(duì)ARM處理
    的頭像 發(fā)表于 09-10 11:11 ?2321次閱讀

    通用寄存器是什么意思

    在計(jì)算機(jī)體系結(jié)構(gòu)中,通用寄存器是中央處理(CPU)內(nèi)部最為核心和基礎(chǔ)的組成部分之一。它們被設(shè)計(jì)為能夠存儲(chǔ)和傳輸各種類型的數(shù)據(jù)和指令,是CPU進(jìn)行數(shù)據(jù)處理和運(yùn)算的關(guān)鍵工具。通用寄存器不僅在程序的執(zhí)行過(guò)程中起著至關(guān)重要的作用,還直
    的頭像 發(fā)表于 09-05 14:13 ?1792次閱讀

    寄存器的類型和作用

    在計(jì)算機(jī)科學(xué)中,寄存器(Register)是一種高速存儲(chǔ)單元,它位于CPU內(nèi)部,與CPU的運(yùn)算單元和邏輯控制單元緊密相連。寄存器的主要作用是暫時(shí)存儲(chǔ)指令、操作數(shù)和地址等臨時(shí)數(shù)據(jù),以便CPU快速訪問(wèn)和處理。由于寄存器直接集成在CP
    的頭像 發(fā)表于 09-05 14:11 ?4094次閱讀

    寄存器故障分析

    寄存器故障分析是計(jì)算機(jī)硬件維護(hù)與系統(tǒng)穩(wěn)定性保障中的重要環(huán)節(jié)。寄存器作為計(jì)算機(jī)中的關(guān)鍵組成部分,負(fù)責(zé)存儲(chǔ)和傳輸數(shù)據(jù),其穩(wěn)定性和可靠性直接影響到整個(gè)計(jì)算機(jī)系統(tǒng)的性能。以下是對(duì)寄存器故障的全面分析,包括故障類型、故障現(xiàn)象、故障原因及診
    的頭像 發(fā)表于 08-29 11:26 ?1811次閱讀

    寄存器是什么意思?寄存器是如何構(gòu)成的?

    在計(jì)算機(jī)科學(xué)中,寄存器(Register)是一個(gè)高速存儲(chǔ)單元,它位于中央處理(CPU)內(nèi)部,用于存儲(chǔ)計(jì)算機(jī)程序執(zhí)行過(guò)程中所需要的數(shù)據(jù)、指令地址或狀態(tài)信息。寄存器是計(jì)算機(jī)體系結(jié)構(gòu)中至關(guān)重要的組成部分,對(duì)計(jì)算機(jī)的運(yùn)算速度和性能有著
    的頭像 發(fā)表于 08-02 18:23 ?6552次閱讀
    <b class='flag-5'>寄存器</b>是什么意思?<b class='flag-5'>寄存器</b>是如何構(gòu)成的?

    寄存器尋址和直接尋址的區(qū)別

    寄存器尋址和直接尋址是計(jì)算機(jī)指令系統(tǒng)中的兩種基本尋址方式。它們?cè)谥噶畹膱?zhí)行過(guò)程中起著至關(guān)重要的作用,決定了指令操作數(shù)的來(lái)源和目標(biāo)。下面我們將介紹這兩種尋址方式的特點(diǎn)、區(qū)別以及在實(shí)際應(yīng)用中的優(yōu)缺點(diǎn)
    的頭像 發(fā)表于 07-12 10:42 ?3693次閱讀

    寄存器尋址的實(shí)現(xiàn)方式

    在計(jì)算機(jī)體系結(jié)構(gòu)中,寄存器尋址是一種常見(jiàn)的尋址方式,它允許程序直接訪問(wèn)CPU內(nèi)部的寄存器。寄存器尋址可以提高程序的執(zhí)行效率,因?yàn)樗苊饬藢?duì)內(nèi)存的訪問(wèn)。 寄存器尋址的基本概念
    的頭像 發(fā)表于 07-12 10:36 ?1236次閱讀

    寄存器有哪幾種?可以實(shí)現(xiàn)什么功能?

    寄存器是計(jì)算機(jī)中用于存儲(chǔ)數(shù)據(jù)和指令的高速存儲(chǔ)設(shè)備,是計(jì)算機(jī)硬件的重要組成部分。寄存器的種類很多,不同的寄存器具有不同的功能。 通用寄存器(General-Purpose Registe
    的頭像 發(fā)表于 07-12 10:32 ?1876次閱讀

    寄存器分為基本寄存器和什么兩種

    寄存器是計(jì)算機(jī)中用于存儲(chǔ)數(shù)據(jù)的高速存儲(chǔ)單元,它們是CPU內(nèi)部的重要組成部分。寄存器可以分為基本寄存器和擴(kuò)展寄存器兩種類型。 一、基本寄存器
    的頭像 發(fā)表于 07-12 10:31 ?1951次閱讀

    移位寄存器中使用的儲(chǔ)存單元是什么

    移位寄存器是一種常見(jiàn)的數(shù)字電路組件,用于存儲(chǔ)和傳輸數(shù)字信號(hào)。在移位寄存器中,存儲(chǔ)單元是其核心組成部分,負(fù)責(zé)存儲(chǔ)數(shù)字信號(hào)的每一位。本文將介紹移位寄存器中使用的存儲(chǔ)單元。 移位寄存器概述
    的頭像 發(fā)表于 07-12 10:21 ?694次閱讀

    移位寄存器右移是怎么移位的

    移位寄存器是一種在數(shù)字電路和計(jì)算機(jī)科學(xué)中廣泛使用的存儲(chǔ)設(shè)備,它可以用來(lái)存儲(chǔ)和傳輸數(shù)據(jù)。在移位寄存器中,數(shù)據(jù)可以通過(guò)移位操作來(lái)實(shí)現(xiàn)數(shù)據(jù)的傳輸和處理。移位寄存器的移位操作有兩種基本形式:左移和右移。本文
    的頭像 發(fā)表于 07-12 10:14 ?2429次閱讀

    雙向移位寄存器的工作原理、特點(diǎn)及應(yīng)用

    移位寄存器在數(shù)據(jù)轉(zhuǎn)換、數(shù)據(jù)傳輸和臨時(shí)數(shù)據(jù)存儲(chǔ)等方面具有廣泛的應(yīng)用。本文將詳細(xì)闡述雙向移位寄存器的原理,包括其結(jié)構(gòu)、工作機(jī)制和應(yīng)用場(chǎng)景。
    的頭像 發(fā)表于 05-24 16:52 ?3149次閱讀

    寄存器和內(nèi)存的區(qū)別

    在計(jì)算機(jī)體系結(jié)構(gòu)中,寄存器和內(nèi)存是兩個(gè)至關(guān)重要的組成部分。它們各自承擔(dān)著不同的角色,共同確保計(jì)算機(jī)系統(tǒng)的正常運(yùn)行。本文將對(duì)寄存器和內(nèi)存進(jìn)行詳細(xì)的介紹,包括它們的定義、功能以及二者之間的主要區(qū)別。
    的頭像 發(fā)表于 05-12 17:11 ?3355次閱讀