IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 嵌入式 -> PCIE控制器——设备地址空间访问——配置空间 -> 正文阅读

[嵌入式]PCIE控制器——设备地址空间访问——配置空间

每一个PCI设备都有一个256 byte的配置寄存器空间,它分为64 byte的头标区(如下图所示,固定不变)和192 byte 的设备关联区(设备自己独有)

一、各类型设备的配置空间

RC设备、桥设备和EP的配置空间略有不同。同时,各家IP厂商的PCIe控制器实现不同,但配置空间寄存器含义均相同。

  • RC设备

  • EP设备
    在这里插入图片描述

二、通用配置空间

下图所示为所用PCIe设备均配有的寄存器。
在这里插入图片描述

  • Device ID和Vendor ID (只读)
    Vender ID代表PCI设备的生产厂商,Device ID代表这个厂商所生产的具体设备。
    Device ID和Vendor ID是区分不同设备的关键,OS和UEFI在很多时候就是通过匹配他们来找到不同的设备驱动(Class Code有时也起一定作用)。为了保证其唯一性,Vendor ID应当向PCI特别兴趣小组(PCI SIG)申请而得到。

  • BAR寄存器

在PCI设备复位后,该寄存器存放PCI设备需要使用的基址空间大小,该组寄存器保存PCI设备使用的地址空间的基地址以及用来定义PCI需要的配置空间大小,其中基地址保存的是该设备在PCI总线域中的地址。

这些PCI总线地址空间需要在初始化时就映射为存储器域的存储器地址空间,方便处理器访问。系统软件对PCI总线进行配置时,首先获得BAR寄存器的初始化信息,之后根据处理器系统的配置,将合理的基地址写入到响应的BAR寄存器中,这个过程在BIOS运行阶段和OS启动阶段完成。系统软件还可以使用该寄存器获得PCI设备使用的BAR空间的长度,其方法是向BAR寄存器写入0xFFFF_FFFF后在读取该寄存器。

每个PCI设备在BAR中描述自己需要占用多少地址空间,BIOS或者OS通过所有设备的这些信息构建一张完整的关系图,描述系统中资源的分配//情况,然后在合理的将地址空间配置给每个PCI设备。
BAR在bit0来表示该设备是映射到memory还是IO,bar的bit0是readonly的,也就是说,设备寄存器是映射到memory还是IO是由设备制造商决定的,其他人无法修改。
参考链接:BAR寄存器初始化

  • Revision ID和Class Code寄存器 (只读)
    Revision ID记载PCI设备的版本号,可以被认为是Device ID寄存器的扩展
    Class Code寄存器记载PCI设备的分类,用于系统软件识别当前PCI设备的分类。该寄存器由Base Class Code、Sub class code和interface三个字段组成。Base Class Code将PCI设备分类为显卡、网卡、PCI桥等设备;Sub class code对这些设备进一步细分;inteface定义为编程接口。

  • Header Type寄存器(只读)
    共8bit。系统软件使用该寄存器区分不同类型的PCI配置空间。

  1. 第7位为1表示当前PCI设备为多功能设备、为0表示单功能设备
  2. 第6-0位表示当前配置空间的类型,为0表示该设备使用PCI Agent设备的配置空间,普通PCI设备都使用该配置头; 为1表示使用PCI桥的配置空间,PCI桥使用这种配置头;为2表示使用cardbus桥片的配置空间。
  • cache line size
    记录host处理器使用的cache line长度

  • Capabilities pointer
    该寄存器存放capabilites寄存器组的基地址,该寄存器组存放域PCI设备相关的扩展配置信息。该寄存器对PCI设备可选,但PCIe总线规范要求其设备必须支持Capabilities结构,该寄存器组用于实现厂商自定义的PCIe设备功能。
    该寄存器存放Capabilities结构链表的头指针。在一个PCIe设备中,可能含有多个Capability结构,这些寄存器组成一个链表,其结构如图:

  • interript line寄存器
    记录当前PCI设备使用的中断向量号,在系统软件对该设备配置时写入。

  • Interrupt pin
    这个寄存器保存PCI设备使用的中断引脚。PCI 总线提供了四个中断引脚: INTA#、 INTB#、
    INTC#和INTD#。InterruptPin寄存器为1时表示使用INTA#引脚向中断控制器提交中断请
    求,为2表示使用INTB#, 为3表示使用INTC#, 为4表示使用INTD#。
    如果PCI设备只有一个子设备时,该设备只能使用INTA#;如果有多个子设备时,可以使用INTB ~ D#信号。如果PCI设备不使用这些中断引脚,向处理器提交中断请求时,该寄
    存器的值必须为0。值得注意的是,虽然在PCIe设备中并不含有INTA ~ D#信号,但是依然
    可以使用该寄存器,因为PCle设备可以使用INTx中断消息,模拟PCI设备的INTA ~ D#信号

三、RC设备特有配置寄存器

如下图所示是RC设备的配置空间:

在这里插入图片描述

  • Subsystem ID和Subsystem Vender ID寄存器
    与Device iD和Vender ID类似,是这二者的补充
  • Expansion ROM base address
    有些PCI设备在CPU未运行OS前,就需要完成基本的初始化设置,如显卡、键盘、硬盘等。为此,PCI设备需要提供一段ROM程序,而处理器在boot阶段运行这段程序从而初始化这些设备,该寄存器即记载ROM程序的基地址。

PCIe的各种特性如Max Payload、Complete Timeout(CTO)等等都通过这个链表链接在一起,Capabilities ID由PCIe spec规定。链表的好处是如果你不关心这个Capabilities(或不知道怎么处理),直接跳过,处理关心的即可,兼容性比较好。另外扩展性也强,新加的功能不会固定放在某个位置,淘汰的功能删掉即好。

三、扩展配置空间

  嵌入式 最新文章
基于高精度单片机开发红外测温仪方案
89C51单片机与DAC0832
基于51单片机宠物自动投料喂食器控制系统仿
《痞子衡嵌入式半月刊》 第 68 期
多思计组实验实验七 简单模型机实验
CSC7720
启明智显分享| ESP32学习笔记参考--PWM(脉冲
STM32初探
STM32 总结
【STM32】CubeMX例程四---定时器中断(附工
上一篇文章      下一篇文章      查看所有文章
加:2022-02-07 13:52:33  更:2022-02-07 13:52:49 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/8 4:19:30-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码