0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

PCIe是什么样的一个体系架构?

Q4MP_gh_c472c21 来源:人人都是极客 作者:人人都是极客 2021-01-12 16:50 次阅读

硬盘是大家都很熟悉的设备,一路走来,从HDD到SSD,从SATA到NVMe,作为NVMe SSD的前端接口,PCIe再次进入我们的视野。作为x86体系关键的一环,PCIe标准历经PCI,PCI-X和PCIe,走过近30年时光。其中Host发现与查找设备的方式却一脉沿袭,今天我们先来聊一聊PCIe设备在一个系统中是如何发现与访问的。

首先我们来看一下在x86系统中,PCIe是什么样的一个体系架构。下图是一个PCIe的拓扑结构示例,PCIe协议支持256个Bus, 每条Bus最多支持32个Device,每个Device最多支持8个Function,所以由BDF(Bus,device,function)构成了每个PCIe设备节点的身份证号。

04641218-528d-11eb-8b86-12bb97331649.jpg

PCIe体系架构一般由root complex,switch,endpoint等类型的PCIe设备组成,在root complex和switch中通常会有一些embeded endpoint(这种设备对外不出PCIe接口)。这么多的设备,CPU启动后要怎么去找到并认出它们呢? Host对PCIe设备扫描是采用了深度优先算法,其过程简要来说是对每一个可能的分支路径深入到不能再深入为止,而且每个节点只能访问一次。我们一般称这个过程为PCIe设备枚举。枚举过程中host通过配置读事物包来获取下游设备的信息,通过配置写事物包对下游设备进行设置。 第一步,PCI Host主桥扫描Bus 0上的设备(在一个处理器系统中,一般将Root complex中与Host Bridge相连接的PCI总线命名为PCI Bus 0),系统首先会忽略Bus 0上的embedded EP等不会挂接PCI桥的设备,主桥发现Bridge 1后,将Bridge1 下面的PCI Bus定为 Bus 1,系统将初始化Bridge 1的配置空间,并将该桥的Primary Bus Number 和 Secondary Bus Number寄存器分别设置成0和1,以表明Bridge1 的上游总线是0,下游总线是1,由于还无法确定Bridge1下挂载设备的具体情况,系统先暂时将Subordinate Bus Number设为0xFF。

0484df70-528d-11eb-8b86-12bb97331649.jpg

第二步,系统开始扫描Bus 1,将会发现Bridge 3,并发现这是一个switch设备。系统将Bridge 3下面的PCI Bus定为Bus 2,并将该桥的Primary Bus Number 和 Secondary Bus Number寄存器分别设置成1和2,和上一步一样暂时把Bridge 3 的Subordinate Bus Number设为0xFF。

04b89c52-528d-11eb-8b86-12bb97331649.jpg

第三步,系统继续扫描Bus 2,将会发现Bridge 4。继续扫描,系统会发现Bridge下面挂载的NVMe SSD设备,系统将Bridge 4下面的PCI Bus定为Bus 3,并将该桥的Primary Bus Number 和 Secondary Bus Number寄存器分别设置成2和3,因为Bus3下面挂的是端点设备(叶子节点),下面不会再有下游总线了,因此Bridge 4的Subordinate Bus Number的值可以确定为3。

04e2c1bc-528d-11eb-8b86-12bb97331649.jpg

第四步,完成Bus 3的扫描后,系统返回到Bus 2继续扫描,会发现Bridge 5。继续扫描,系统会发现下面挂载的NIC设备,系统将Bridge 5下面的PCI Bus设置为Bus 4,并将该桥的Primary Bus Number 和 Secondary Bus Number寄存器分别设置成2和4,因为NIC同样是端点设备,Bridge 5的Subordinate Bus Number的值可以确定为4。

05067904-528d-11eb-8b86-12bb97331649.jpg

第五步,除了Bridge 4和Bridge 5以外,Bus2下面没有其他设备了,因此返回到Bridge 3,Bus 4是找到的挂载在这个Bridge下的最后一个bus号,因此将Bridge 3的Subordinate Bus Number设置为4。Bridge 3的下游设备都已经扫描完毕,继续向上返回到Bridge 1,同样将Bridge 1的Subordinate Bus Number设置为4。

0546e20a-528d-11eb-8b86-12bb97331649.jpg

第六步,系统返回到Bus0继续扫描,会发现Bridge 2,系统将Bridge 2下面的PCI Bus定为Bus 5。并将Bridge 2的Primary Bus Number 和 Secondary Bus Number寄存器分别设置成0和5, Graphics card也是端点设备,因此Bridge 2 的Subordinate Bus Number的值可以确定为5。 至此,挂在PCIe总线上的所有设备都被扫描到,枚举过程结束,Host通过这一过程获得了一个完整的PCIe设备拓扑结构。

05942f9c-528d-11eb-8b86-12bb97331649.jpg

系统上电以后,host会自动完成上述的设备枚举过程。除一些专有系统外,普通系统只会在开机阶段进行进行设备的扫描,启动成功后(枚举过程结束),即使插入一个PCIe设备,系统也不会再去识别它。 在linux操作系统中,我们可以通过lspci –v -t命令来查询系统上电阶段扫描到的PCIe设备,执行结果会以一个树的形式列出系统中所有的pcie设备。如下图所示,其中黄色方框中的PCIe设备是北京忆芯科技公司(Bejing Starblaze Technology Co., LTD.)推出的STAR1000系列NVMe SSD主控芯片,图中显示的9d32是Starblaze在PCI-SIG组织的注册码,1000是设备系列号。

05d2894a-528d-11eb-8b86-12bb97331649.png

STAR1000设备的BDF也可以从上图中找出,其中bus是0x3C,device是0x00,function是0x0,BDF表示为3C:00.0,与之对应的上游端口是00:1d.0。 我们可以通过“lspci –xxx –s 3C:00.0”命令来列出该设备的PCIe详细信息(技术发烧友或数字控请关注该部分)。这些内容存储在PCIe配置空间,它们描述的是PCIe本身的特性。如下图所示(低位地址0x00在最左边),可以看到这是一个非易失性存储控制器,0x00起始地址是PCIe的Vendor ID和Device ID。Class code 0x010802表示这是一个NVMe存储设备。0x40是第一组capability的指针,如果你需要查看PCIe的特性,就需要从这个位置开始去查询,在每组特征的头字段都会给出下一组特性的起始地址。从0x40地址开始依次是power management,MSI中断,链路控制与状态,MSI-X中断等特性组。这儿特别列出了链路特征中的一个0x43字段,表示STAR1000设备是一个x4lane的链接,支持PCIe Gen3速率(8Gbps)。

05f95cc8-528d-11eb-8b86-12bb97331649.png

当然也可以使用lspci –vvv –s 3C:00.0命令来查看设备特性,初学者看到下面的列表也就一目了然了。

064affd8-528d-11eb-8b86-12bb97331649.jpg

Host在枚举设备的同时也会对设备进行配置,每个PCIe设备都会指定一段CPU memory访问空间,从上面的图中我们可以看到这个设备支持两段访问空间,一段的大小是1M byte,另一段的大小是256K byte,系统会分别指定它们的基地址。基地址配置完成以后,Host就可以通过地址来对PCIe memory空间进行访问了。 PCIe memory空间关联的是PCIe设备物理功能,对于STAR1000系列芯片而言,物理功能是NVMe,memory中存放的是NMVe的控制与状态信息,对于NMVe的控制以及工作状态的获取,都需要通过memory访问来实现。 下面以NVMe命令下发为例简单描述PCIe设备的memory访问。NVMe命令下发的基本操作是1)Host写doorbell寄存器,此时使用PCIe memory写请求。如下图所示,host发出一个memory write(MWr)请求,该请求经过switch到达要访问的NVMe SSD设备。

06816942-528d-11eb-8b86-12bb97331649.jpg

这个请求会被端点设备接收并执行2)NVMe读取命令操作。如下图所示,此时NVMe SSD作为请求者,发出一个memory read(MRd)请求,该请求经过Switch到达Host,Host作为完成者会返回一个完成事物包(CplD),将访问结果返回给NVMe SSD。

06a85944-528d-11eb-8b86-12bb97331649.jpg

这样,一个NVMe的命令下发过程就完成了。同样,NVMe的其他操作比如各种队列操作,命令与完成,数据传输都是通过PCIe memory访问的方式进行的,此处不再详述。 通过上面的描述,相信能够帮助大家了解PCIe的设备枚举和memory空间访问。以后会继续与大家探讨PCIe的其他内容,比如PCIe的协议分层,链路建立,功耗管理等等。目前PCIe协议还正在不断的快速演进中,2017年发布的PCIe Gen4标准,每条Serdes支持的速率已经达到16Gbps,Gen5也在加速制定中,其速率会再翻一倍达到32Gbps。Starblaze会紧跟技术的发展趋势,提供速率更高,性能更好更稳定的NVMe SSD系列产品

原文标题:原来PCIe这么简单,一定要看!

文章出处:【微信公众号:嵌入式ARM】欢迎添加关注!文章转载请注明出处。

责任编辑:haq

声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • 硬盘
    +关注

    关注

    3

    文章

    1235

    浏览量

    56345
  • PCIe
    +关注

    关注

    13

    文章

    1086

    浏览量

    80901

原文标题:原来PCIe这么简单,一定要看!

文章出处:【微信号:gh_c472c2199c88,微信公众号:嵌入式微处理器】欢迎添加关注!文章转载请注明出处。

收藏 人收藏

    评论

    相关推荐

    【RISC-V开放架构设计之道|阅读体验】本别出心裁的RISC-V架构之书(第章)

    的内容,虽然简单的两页指令汇总表格,但是其严谨的内容告诉我们,这是用来介绍RISC-V体系架构相关的专业书籍。 翻开书中的第章,为
    发表于 01-24 19:06

    【RISC-V开放架构设计之道|阅读体验】学习处理器体系架构本好书

    感谢电子发烧友论坛和电子工业出版社提供的试读机会。 《RISC-V开放架构设计之道》由RISC-V架构的作者、著名的计算机体系架构专家David Patterson亲自主笔撰写。Dav
    发表于 01-23 20:08

    ADIS16375的陀螺仪输出角度是什么样的角度?

    想知道ADIS16375这款IMU的输出角度是什么样的角度?是不是姿态角?其参考坐标系是什么?输出角的实时精度是多少?ADIS16365、ADIS16334、ADIS16445、ADIS16485这四款IMU能够输出角度吗?若果能,分别是
    发表于 12-29 06:17

    AD7779 DRDY引脚输出应该是什么样的波形?

    AD7779DRDY 引脚输出应该是什么样的波形,我测出来的是连续十五脉冲,后面是很长
    发表于 12-11 06:13

    SigmaStudio 3.9开发ADAU1701时里面的adi algorithms里有automatic EQ是什么样功能的EQ?

    SigmaStudio 3.9 开发ADAU1701时里面的adi algorithms里有automatic EQ是什么样功能的EQ?般用来做什么?还有加入此EQ后编译过不了,提示错误和请联系ADI,是什么原因?还没开放吗
    发表于 11-30 06:36

    多运放集成芯片未使用运放输入输出接口的端接方法是什么样的?

    我使用的OP4177集成四运放芯片,只使用了其中的两运放,另外两运放我把输入输出全部接地的时候,芯片发热严重,只把输入接地,输出悬空的时候,芯片不发热了,但是输出锁定到供电电压的上限+15V。我想询问下,多运放集成芯片未使
    发表于 11-21 08:22

    DC-500MHz,2000倍电压放大,该选择什么样的放大器?

    我想放大从电感线圈出来的脉冲信号,带宽大概DC-500MHz。信号很小,电压放大倍数需要2000倍左右,我应该选择什么样的放大器?提前感谢大家的帮助!!!
    发表于 11-21 08:21

    体验紫光PCIE之使用WinDriver驱动紫光PCIE

    开始和主机怎么交互起来都是问题。入门PCIE协议,会发现繁多也难懂——PCIE体系庞大足
    发表于 11-17 14:35

    浅谈城市综合管廊智慧配电运维管理平台体系架构

    摘要:智能化是综合管廊运维管理的发展方向,但多地先后建设的综合管廊运维管理平台都缺乏体系架构的统一标准。本文在分析综合管廊运维管理平台体系架构的研究现状的基础上,提出了一种5层智慧运维
    的头像 发表于 10-16 10:29 364次阅读
    浅谈城市综合管廊智慧配电运维管理平台<b class='flag-5'>体系</b><b class='flag-5'>架构</b>

    网络安全体系基础架构建设

    网络安全体系基础架构建设知识    
    的头像 发表于 09-11 09:36 1320次阅读
    网络安全<b class='flag-5'>体系</b>基础<b class='flag-5'>架构</b>建设

    ARM Cortex-A系列ARMv8-A程序员指南

    ARMv8-A是针对应用配置文件的最新代ARM架构。 在本书中,名称ARMv8用于描述整个体系结构,它现在包括32位执行状态和64位执行状态。 ARMv8引入了使用64位宽寄存器执行的能力,但提供
    发表于 08-22 07:22

    PCIe AMBA集成指南

    和AMBA ACE协议和ARM架构。 该文档涵盖以下主题: ·本文档中使用的术语说明。 ·针对PCIe事务的ARM内存类型使用指南。 ·如何遵守ARM处理元件(PE)的PCIe事务的ARM内存模型要求
    发表于 08-17 07:25

    ARMv8-M体系结构及其程序员模型简介

    Armv8体系结构有几个不同的配置文件。这些配置文件是体系结构的变体针对不同的市场和用例。Armv8-M体系结构就是其中之配置文件。 Arm定义了三
    发表于 08-08 06:18

    了解体系结构 - 介绍 Arm 体系结构

    。该体系结构为软件开发人员公开了通用的指令集和工作流程,也称为程序员模型。这有助于确保架构的不同实现之间的互操作性,以便软件可以在不同的 Arm 设备上运行。本指南为任何对此感兴趣
    发表于 08-01 14:35

    可以将多个PCIe设备连接到般的单个PCIe控制器吗?

    我们可以将多个 PCIe 设备 (IC) 连接到般的单个 PCIe 控制器(在我们的案例中更具体地说是 NXP LS20xxA 处理器)吗? 例如,将四不同的
    发表于 05-05 07:35