欧美性猛交xxxx免费看_牛牛在线视频国产免费_天堂草原电视剧在线观看免费_国产粉嫩高清在线观看_国产欧美日本亚洲精品一5区

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

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

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

幾個簡單的例子來熟悉寄存器BAR的機(jī)制

SwM2_ChinaAET ? 來源:未知 ? 作者:李倩 ? 2018-05-09 09:25 ? 次閱讀

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

其中Type0 Header最多有6個BAR,而Type1 Header最多有兩個BAR。這就意味著,對于Endpoint來說,最多可以擁有6個不同的地址空間。但是實際應(yīng)用中基本上不會用到6個,通常1~3個BAR比較常見。

主要注意的是,如果某個設(shè)備的BAR沒有被全部使用,則對應(yīng)的BAR應(yīng)被硬件全被設(shè)置為0,并且告知軟件這些BAR是不可以操作的。對于被使用的BAR來說,其部分低比特是不可以被軟件操作的,只有其高位才可以被軟件操作。而這些不可操作的低比特決定了當(dāng)前BAR支持的操作類型和可申請的地址空間的大小。

一旦BAR的值確定了(Have been programmed),其指定范圍內(nèi)的當(dāng)前設(shè)備中的內(nèi)部寄存器(或內(nèi)部存儲空間)就可以被訪問了。當(dāng)該設(shè)備確認(rèn)某一個請求(Request)中的地址在自己的BAR的范圍內(nèi),便會接受這請求。

下面用幾個簡單的例子來熟悉BAR的機(jī)制:

例1.32-bit Memory Address Space Request

如下圖所示,請求一個4KB的NP-MMIO一般需要以下三個步驟:

Step1:如圖中(1)所示,未初始化的BAR的低比特(11~4)都是0,高比特(31~12)都是不確定的值。所謂初始化,就是系統(tǒng)(軟件)向整個BAR都寫1,來確定BAR的可操作的最低位是哪一位。當(dāng)前可操作的最低位為12,因此當(dāng)前BAR可申請的地址空間大小為4KB(2^12)。如果可操作的最低位為20,則改BAR可申請的地址空間大小為1MB(2^20)。

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

Step3:最后一步是,軟件向BAR的高比特寫入地址空間的起始地址(Start Address)。如圖中所示,為0xF9000000。

例2.64-bit Memory Address Space Request

下面是一個申請64MB NP-MMIO地址空間的例子,由于采用的是64-bit的地址,因此需要兩個BAR。具體如下圖所示:

例3.IO Address Space Request

下面是一個申請IO地址空間的例子,如下圖所示:

注:需要特別注意的是,軟件對BAR的檢測與操作(Evaluating)必須是順序執(zhí)行的,即先BAR0,然后BAR1,……,直到BAR5。當(dāng)軟件檢測到那些被硬件設(shè)置為全0的BAR,則認(rèn)為這個BAR沒有被使用。

注:無論是PCI還是PCIe,都沒有明確規(guī)定,第一個使用的BAR必須是BAR0。事實上,只要設(shè)計者原意,完全可以將BAR4作為第一個BAR,并將BAR0~BAR3都設(shè)置為不使用。

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

    關(guān)注

    31

    文章

    5372

    瀏覽量

    121318
  • PCIe
    +關(guān)注

    關(guān)注

    15

    文章

    1266

    瀏覽量

    83277

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

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

收藏 人收藏

    評論

    相關(guān)推薦

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

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

    ARM處理寄存器組織及功能

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

    通用寄存器是什么意思

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

    寄存器的類型和作用

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

    寄存器故障分析

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

    干貨滿滿:ARM的內(nèi)核寄存器講解

    內(nèi)核寄存器與外設(shè)寄存器: 內(nèi)核寄存器與外設(shè)寄存器是完全不同的概念。內(nèi)核寄存器是指 CPU 內(nèi)部的寄存器
    發(fā)表于 04-17 11:47 ?4380次閱讀
    干貨滿滿:ARM的內(nèi)核<b class='flag-5'>寄存器</b>講解

    如何根據(jù)自己設(shè)計中的寄存器配置總線定義來生成一套寄存器配置模版

    無論是FPGA還是ASIC,系統(tǒng)設(shè)計中總會存在配置寄存器總線的使用,我們會將各種功能、調(diào)試寄存器掛載在寄存器總線上使用。
    的頭像 發(fā)表于 03-04 13:56 ?1273次閱讀
    如何根據(jù)自己設(shè)計中的<b class='flag-5'>寄存器</b>配置總線定義來生成一套<b class='flag-5'>寄存器</b>配置模版