飞飞学飞的个人空间 https://blog.eetop.cn/1585176 [收藏] [复制] [分享] [RSS]

空间首页 动态 记录 日志 相册 主题 分享 留言板 个人资料

日志

PCIe 配置空间结构深度解析

已有 161 次阅读| 2025-5-19 07:11 |个人分类:PCIe每日一问|系统分类:芯片设计| PCIe, Linux, x86, PCIe, Linux, PCIe, Linux, PCIe, Linux, PCIe, Linux, PCIe, Linux, PCIe

此文章摘抄自微信公众号"芯塾科技",如有侵权,请联系删除,谢谢!

1.png



1.PCIe每日一问简介

1.文章坚持实际工作中有所帮助---实际工作中遇到问题可查阅。

2.章节内容规划具有连贯性。lspci-setpci-PCIe Configuration Space--next。

3.文章以文字和视频形式发布,建议大家视频和文章结合查阅。

4.视频发布:公众号、B站、抖音,搜寻“芯塾科技”可观看。

5.文章发布: 公众号、CSDN、知乎、B站,搜寻“芯塾科技”可浏览。



2.PCIe 配置空间结构深度解析

1.Q1:什么是PCIe配置空间?

2.PCIe配置空间是 PCI/PCIe 设备的一组标准化寄存器,用于存储设备的硬件信息、资源需求和功能配置。

3.PCIe配置空间是PCI/PCIe 设备与系统(如操作系统或 BIOS)之间交互的核心机制,支持设备的发现、资源分配和功能控制

4.Q2:PCIe配置空间结构?

5.PCIe配置空间为4KB大小,采用链表管理。

本文解析PCIe配置空间的结构,从PCI到PCIe的演变。



3.PCI Configuration Space Header  

1.PCI协议规定64字节为PCI Configuration Space Header,  结构如下图所示。

2.png

2.PCI Configuration Space Header 前16字节定义都是一样, 对于所有PCI设备。

3.PCI Configuration Space Header 后48字节(10h-3fh),根据设备类型(端点设备、桥设备、根复合体等), 存在Type 0(端点设备)和 Type 1(桥设备)两种格式。

4.PCI Configuration Space Header 后48字节,存在Type 0/ Type 1格式通过PCI Configuration Space Header “header Type Register(0eh)”寄存器指示。

3.png
5.Type0/Type1格式

4.png




4.PCI Capability Space 


1.PCI Configuration Space Header(前 64 字节)仅支持固定功能,无法满足不断扩展的需求(如电源管理、MSI中断等)

2.PCI 2.1 标准引入能力寄存器,允许设备在配置空间中动态声明支持的可选功能

3.PCI能力寄存器通过链表管理,每个能力结构包含一个能力ID和一个指向下一个能力结构的指针

5.png

5.png4.PCI Configuration Space Header “Capability Pointer”寄存器指向能力寄存器的起始位置。

7.png

8.png

5.PCI能力寄存器8位ID由PCI-SIG分配。

9.png



5.PCI Configuration Space 


1.PCI配置空间由PCI Configuration Space Header和PCI Capability Space构成。

2.PCI配置空间大小为256 Byte,配置寄存器的布局是标准化的,64 Byte PCI Configuration Space Header,192 Byte PCI Capability Space。

3.PCI设备256Byte配置空间,前64字节是标准化的,其余的则是与设备相关的。

10.png




6.PCIe Configuration Space 


1.PCIe配置空间为4096 Byte(4KB空间)PCI配置空间为256 Byte

2.PCIe Configuration Space分为 PCI 兼容区域<256 Byte>、 PCIe 扩展配置空间。

3.PCIePCI Capability 新增PCIe Capability寄存器。

4.PCIe Configuration Space结构。

11.png


7.PCIe Capability Register


1.PCIe 在 PCI 兼容配置空间(前 256 字节)中定义了PCIe  Capability Register。

2.PCIe设备需要支持PCIe Capability Register。

3.PCIe Capability Register结构。


12.png

4.PCIe Capability ID

13.png


8.PCIe Extended Capability Space 


1.PCIe扩展能力寄存器位于设备配置空间的0x1000xfff字段,以链表形式管理。

14.png2.PCIe扩展能力寄存器格式。15.png16.png3.PCe扩展能力寄存器16位ID由PCI-SIG分配。17.png



9.Summary


1.PCI Configuration Space Header

2.PCI Capability Space 

3.PCI Configuration Space  

5.PCIe Capability Register

5.PCIe Extended Capability Space

6.PCIe Configuration Space

18.png




---------------------------------------------------------

---------------------------------------------------------

文章坚持-工作中查阅可解决实际问题

您的点赞-收藏-转发-评论是我们坚持原创的动力

欢迎关注微信公众号"芯塾科技"

视频发布平台:B站/公众号/抖音,可搜索"芯塾科技"观看





点赞

全部作者的其他最新日志

评论 (0 个评论)

facelist

您需要登录后才可以评论 登录 | 注册

  • 关注TA
  • 加好友
  • 联系TA
  • 12

    周排名
  • 0

    月排名
  • 0

    总排名
  • 0

    关注
  • 2

    粉丝
  • 0

    好友
  • 0

    获赞
  • 0

    评论
  • 136

    访问数
关闭

站长推荐 上一条 /1 下一条

小黑屋| 手机版| 关于我们| 联系我们| 隐私声明| EETOP 创芯网
( 京ICP备:10050787号 京公网安备:11010502037710 )

GMT+8, 2025-5-20 07:09 , Processed in 0.019507 second(s), 8 queries , Gzip On, MemCached On.

eetop公众号 创芯大讲堂 创芯人才网
返回顶部