女人自慰AV免费观看内涵网,日韩国产剧情在线观看网址,神马电影网特片网,最新一级电影欧美,在线观看亚洲欧美日韩,黄色视频在线播放免费观看,ABO涨奶期羡澄,第一导航fulione,美女主播操b

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

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

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

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

SwM2_ChinaAET ? 來源:未知 ? 作者:李倩 ? 2018-05-09 09:25 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

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

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

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

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

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

例1.32-bit Memory Address Space Request

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

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

Step2:完成初始化(寫1操作)之后,軟件便開始讀取BAR的值,來確定每一個BAR對應的地址空間大小和類型。其中操作的類型一般由最低四位所決定,具體如上圖右側(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。當軟件檢測到那些被硬件設(shè)置為全0的BAR,則認為這個BAR沒有被使用。

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

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

    關(guān)注

    31

    文章

    5433

    瀏覽量

    124364
  • PCIe
    +關(guān)注

    關(guān)注

    16

    文章

    1340

    瀏覽量

    85109

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

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

收藏 人收藏
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

    評論

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

    使用寄存器點亮LED燈

    學習本章時,配合以上芯片手冊中的“19. I/O Ports”章節(jié)一起閱讀,效果會更佳,特別是涉及到寄存器說明的部分。本章內(nèi)容涉及到較多寄存器方面的深入內(nèi)容,對于初學者而言這些內(nèi)容豐富也較難理解,但非常有必要細讀研究、夯實基礎(chǔ)。
    的頭像 發(fā)表于 05-28 17:37 ?612次閱讀
    使用<b class='flag-5'>寄存器</b>點亮LED燈

    TPS80032寄存器手冊

    電子發(fā)燒友網(wǎng)站提供《TPS80032寄存器手冊.pdf》資料免費下載
    發(fā)表于 12-21 09:08 ?0次下載
    TPS80032<b class='flag-5'>寄存器</b>手冊

    Modbus協(xié)議的讀取保持寄存器

    功能碼用于讀取從設(shè)備保持寄存器的內(nèi)容,不支持廣播模式。消息頓中指定了需要讀取的保持寄存器的起始地址和數(shù)目。而保持寄存器中各地址的具體內(nèi)容和意義則由設(shè)備開發(fā)者自行規(guī)定。
    的頭像 發(fā)表于 10-30 10:54 ?3857次閱讀

    詳解寄存器模型鏡像值

    DUT的配置寄存器的值是實際值,reg_model有鏡像值、期望值的概念。
    的頭像 發(fā)表于 10-23 09:43 ?997次閱讀
    詳解<b class='flag-5'>寄存器</b>模型鏡像值

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

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

    什么是寄存器移位尋址

    寄存器移位尋址是一種特定的尋址方式,主要出現(xiàn)在某些處理架構(gòu)中,如ARM指令集。這種尋址方式在處理數(shù)據(jù)移動和操作時提供了極大的靈活性和效率。下面將從定義、工作原理、特點、應用場景以及與其他尋址方式的對比等方面對寄存器移位尋址進行
    的頭像 發(fā)表于 10-05 17:38 ?1056次閱讀

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

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

    微處理寄存器的作用

    微處理中的寄存器是計算機體系結(jié)構(gòu)中的核心組成部分,它們扮演著至關(guān)重要的角色。寄存器是一種高速的存儲單元,用于暫時存儲數(shù)據(jù)、指令和地址等信息,以便微處理能夠快速地訪問和處理這些數(shù)據(jù)。
    的頭像 發(fā)表于 10-05 15:07 ?1274次閱讀

    ARM處理寄存器組織及功能

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

    ARM寄存器的分類及功能

    ARM寄存器是ARM處理內(nèi)部的重要組成部分,它們在處理的運算、控制以及數(shù)據(jù)存儲等方面發(fā)揮著至關(guān)重要的作用。下面,我們將從ARM寄存器的定義、結(jié)構(gòu)、分類以及功能等多個方面進行詳細闡述
    的頭像 發(fā)表于 09-05 14:18 ?2914次閱讀

    通用寄存器是什么意思

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

    寄存器的類型和作用

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

    寄存器的輸入輸出方式

    寄存器的輸入輸出方式是數(shù)字電路設(shè)計中至關(guān)重要的部分,它決定了數(shù)據(jù)如何在寄存器中進出以及處理的效率。下面將詳細探討寄存器的幾種主要輸入輸出方式,包括并行輸入輸出、串行輸入輸出以及雙向輸入輸出,并會擴展到移位
    的頭像 發(fā)表于 09-05 14:09 ?2623次閱讀

    寄存器故障分析

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

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

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