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

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

3天内不再提示

聊聊PCIe设备在系统如何发现与访问?

架构师技术联盟 来源:SSDFans 作者:SSDFans 2022-12-09 10:04 次阅读

硬盘是大家都很熟悉的设备,一路走来,从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设备节点的身份证号。

368f45d4-770f-11ed-8abf-dac502259ad0.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。

36aafb30-770f-11ed-8abf-dac502259ad0.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。

36c543a0-770f-11ed-8abf-dac502259ad0.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。

36e145fa-770f-11ed-8abf-dac502259ad0.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。

36fab12a-770f-11ed-8abf-dac502259ad0.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。

37145530-770f-11ed-8abf-dac502259ad0.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设备拓扑结构。

37737146-770f-11ed-8abf-dac502259ad0.jpg

系统上电以后,host会自动完成上述的设备枚举过程。除一些专有系统外,普通系统只会在开机阶段进行进行设备的扫描,启动成功后(枚举过程结束),即使插入一个PCIe设备,系统也不会再去识别它。

linux操作系统中,我们可以通过lspci –v -t命令来查询系统上电阶段扫描到的PCIe设备,执行结果会以一个树的形式列出系统中所有的pcie设备。如下图所示,其中黄色方框中的PCIe设备是北京忆芯科技公司(Bejing Starblaze Technology Co., LTD.)推出的STAR1000系列NVMe SSD主控芯片,图中显示的9d32是Starblaze在PCI-SIG组织的注册码,1000是设备系列号。

3791ca56-770f-11ed-8abf-dac502259ad0.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)。

37a6fc6e-770f-11ed-8abf-dac502259ad0.png

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

37c204f0-770f-11ed-8abf-dac502259ad0.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设备。

3812ffa4-770f-11ed-8abf-dac502259ad0.jpg

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

384be396-770f-11ed-8abf-dac502259ad0.jpg

这样,一个NVMe的命令下发过程就完成了。同样,NVMe的其他操作比如各种队列操作,命令与完成,数据传输都是通过PCIe memory访问的方式进行的,此处不再详述。

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

审核编辑:汤梓红

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

    关注

    20

    文章

    2851

    浏览量

    117194
  • PCIe
    +关注

    关注

    15

    文章

    1217

    浏览量

    82424
  • nvme
    +关注

    关注

    0

    文章

    217

    浏览量

    22580

原文标题:聊聊PCIe设备在系统如何发现与访问?

文章出处:【微信号:架构师技术联盟,微信公众号:架构师技术联盟】欢迎添加关注!文章转载请注明出处。

收藏 人收藏

    评论

    相关推荐

    windows xp无法正常扫描和安装驱动PCIE设备

    求教:应用环境:主机:x86型CPU主板操作系统:win xp设备:IDT生产的PCIE-SRIO桥片 TSI721总线:PCIE 2.0问题描述:1、windows启动后,用wind
    发表于 12-13 11:30

    如何使用pcie链接从外部处理器访问bram?

    嗨,我能够我们的定制板上连接到virtex 7 fpga。我的块级设计具有用于pcie的轴桥作为终点和axi bram。但我无法使用pcie链接从外部处理器访问bram。任何人都可以
    发表于 04-22 09:31

    如何访问内部寄存器空间或PCIe

    你好,我我的项目中使用XC7VX485T virtex FPGA,并尝试以2.5 GT / s建立PCIe通信,具有X4通道宽度。我知道我需要使用AXI流来访问集成块核心。但我的问题是如何访
    发表于 08-26 07:14

    PCIe的技术原理详细说明

    PCIe,走过近30年时光。其中Host发现与查找设备的方式却一脉沿袭,今天我们先来聊一聊PCIe设备
    发表于 05-25 09:22

    PCIe设备的低功耗状态

    PCIe设备的低功耗状态要求系统驱动程序显式地将设备置于低功耗状态,从而PCIe链路则可以依次变为低功耗链路状态。
    发表于 12-28 06:18

    PCIe设备的低功耗状态要求

    PCIe设备的低功耗状态要求系统驱动程序显式地将设备置于低功耗状态,从而PCIe链路则可以依次变为低功耗链路状态。
    发表于 01-03 08:00

    无法访问s32v234板中的PCIe是怎么回事?

    尝试访问两块 s32v234 板上的 PCIe 设备,但未成功。 U-Boot 中,pci 命令(例如枚举)会收到“pci_bus_to_hose() failed
    发表于 03-31 06:40

    PCIe设备一个系统中是如何发现访问

    PCIe体系架构一般由root complex,switch,endpoint等类型的PCIe设备组成,root complex和switch中通常会有一些embeded endpo
    的头像 发表于 03-11 15:28 1.9w次阅读
    <b class='flag-5'>PCIe</b><b class='flag-5'>设备</b><b class='flag-5'>在</b>一个<b class='flag-5'>系统</b>中是如何<b class='flag-5'>发现</b>与<b class='flag-5'>访问</b>的

    PCIe的技术原理详细说明

    PCIe,走过近30年时光。其中Host发现与查找设备的方式却一脉沿袭,今天我们先来聊一聊PCIe设备
    发表于 01-09 10:41 3.8w次阅读
    <b class='flag-5'>PCIe</b>的技术原理详细说明

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

    PCIe,走过近30年时光。其中Host发现与查找设备的方式却一脉沿袭,今天我们先来聊一聊PCIe设备
    的头像 发表于 01-12 16:50 4904次阅读

    聊聊PCIe Bus(PCIe总线)

    PCIe接口从2001年发展至今,协议的完整性上已经建立足够高的"护城河",重新定义一个接口协议性能上超越PCIe,短期内一方面没有企业会有这个动力,另一方面技术的维度,也没有可预
    发表于 04-13 11:10 4854次阅读

    PCI/PCIe最容易访问设备是什么

    最容易访问设备是什么 是内存! 要读写内存,知道它的地址就可以: volatile unsigned int *p = 某个地址; unsigned int val;*p = val; /* 写
    的头像 发表于 07-30 09:35 570次阅读
    PCI/<b class='flag-5'>PCIe</b>最容易<b class='flag-5'>访问</b>的<b class='flag-5'>设备</b>是什么

    访问PCI/PCIe设备的流程

    和 PCI/PCIe 地址空间怎么转换? 假设 CPU 发出的 addr_cpu,是用来访问 PCI 设备的,转换关系为: addr_pci = addr_cpu + off set
    的头像 发表于 07-30 09:44 1555次阅读

    PCIe相关问题解答

    CPU 发起的,访问PCIe设备配置空间的数据流。这种数据流主要是BIOS/Linux PCIe driver 对设备进行初始化、资源分配时
    的头像 发表于 09-15 09:39 1599次阅读
    <b class='flag-5'>PCIe</b>相关问题解答

    pcie设备驱动程序安装步骤

    设备能够正常工作的重要步骤。 1. 准备工作 开始安装PCIe设备驱动程序之前,需要做一些准备工作: 确认设备兼容性 :确保你的
    的头像 发表于 11-13 10:32 179次阅读