【PCI】基地址寄存器(BAR)

一、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的可操作的最低位是哪一位。如上图当全写1读出寄存器的值可操作的最低位为12,因此当前BAR可申请的(最小)地址空间大小为4KB(2^12),如果可操作的最低位为20 如果可操作的最低位为20,则该BAR可申请的(最小)地址空间大小为1MB。
Step2:完成初始化(写1操作)之后,软件便开始读取BAR的值,来确定每一个BAR对应的地址空间大小和类型。其中操作的类型一般由最低四位所决定,具体如上图右侧部分所示。
Step3:最后一步是,软件向 BAR 的高比特写入地址空间的起始地址(Start Address)。如图中所示,为 0xF9000000。注意:使用的是 OS 侧 DDR 预留的物理地址而不是虚拟地址。

示例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都设置为不使用。

  • 22
    点赞
  • 22
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值