NVMe开发——PCIe复位

简介

PCIe中有4种复位机制,早期的3种被称为传统复位(Conventional Reset)。传统复位中的前2种又称为基本复位(Fundamental Resets),分别为冷复位(Cold Reset),暖复位(Warm Reset)。第3种复位为热复位(Hot Reset)。第4种复位被称为功能级复位(Function Level Reset),出现在PCIe 2.0规范中。

传统复位

2.1. 基本复位

基本复位由硬件处理,并且是复位整个设备,重新初始化所有硬件的逻辑、端口状态以及配置寄存器。唯一的例外是,有一组标识为"sticky"的寄存器位,因为要记录复位过程中的错误,所以其配套有辅助电源(Vaux)。如果主电源和辅助电源同时关闭,那么Stick寄存器也会复位。

两种基本复位的定义:

冷复位:启动设备主电源或重启设备主电源都会导致冷复位。

暖复位(可选):不关闭主电源下的触发。规范没有定义实现机制,厂商可自行选择是否添加此功能,并设计具体触发的机制,可以考虑通过检测电源状态来实现。

基本复位发生和退出时,正负电压端阻抗必须满足要求,发射端的阻抗和直流也必须满足要求,详见技术规范。

两种基本复位方法:

  1. 通过辅助边带信号PERST#(PCI Express Reset)触发。

  2. 如果未提供边带信号,则重启电源时,组件或插槽会自动产生复位。

2.2. PERST# 基本复位的产生

PERST#信号是边带信号,系统不一定设计有。芯片组可能提供PERST#信号,如下图ICH对外提供PERST#信号。当POWERGOOD信号触发时,ICH会发出PERST#信号。PERST#边带信号会接入所有PCIe设备。

当设备电源关闭,POWERGOOD信号触发,然后产生PERST#信号,这是一个冷复位。(此时设备电源也会同时开启)。

当设备电源开启,系统可以通过其他方式产生PERST#信号以实现暖复位。

2.3. 自主复位的产生

设备在主电源接通时,应该自己产生复位信号,然后对设备进行本地复位。如果设备检测到电源超出范围,也必须生成自主复位。

2.4. 链路从低功耗唤醒

当设备的主要电源被关闭作为电源管理策略的一部分时,如果设备设计用于发出唤醒信号,它可能能够请求恢复到完全供电状态。当电源恢复时,设备必须进行复位。系统的电源控制器可以通过激活PERST#引脚向设备发送复位信号,但如果没有这样做,或者设备不支持PERST#,则设备必须在感知到主电源重新连接时自主生成其自己的基本复位。

2.5. 热复位(带内复位)

热复位是通过在链路上发送特定的TS1消息来实现的。这些消息中的第5个符号的第0位被设置为1,以表示这是一个热复位消息。这些消息将在所有通道上广播,以确保所有链路邻居都能够接收到,并执行相应的操作以响应热复位。一旦完成发送,发送器和接收器将进入特定的状态以处理热复位。这个过程有助于在高速数据链路中进行重置操作,以确保链路的正确性和稳定性。

软件发起的热复位是通过在桥接设备的配置寄存器中设置特定的位来实现的。这个位被称为Secondary Bus Reset位。当此位被设置时,与该桥接设备相关联的所有设备都将接收到复位信号,并进行自我复位。这种复位操作通常由具有桥接功能的设备(例如Root Complex设备或交换机)执行,并且可以通过其控制寄存器进行触发。交换机在接收到热复位信号后将广播给其下游端口,并要求所有下游设备进行复位。这确保了整个链路中的所有设备都可以正确地响应热复位,并重新初始化其状态。

如上图,如果Root Compex或Switch被软件启用了热复位,那么Root Compex或Switch会对其所有下端设备发生热复位。

当热复位接收器检测到连续2个热复位的TS1消息埋,它会进入Hot Reset状态并持续2ms,然后退出检测状态,上行端口和下行端口都会进行初始化,然后再进入检测状态,然后开始免链路的训练。如果下游设备也是交换机或桥接器,它也会将Hot Reset消息转发给其下游端口。

2.6. 热复位方法

2.6.1. 次级总线复位

上级桥接设备的Secondary Bus Reset位于配置空间的Bridge Control寄存器中,可以通过软件修改达到热复位。软件对Secondary Bus Reset寄存器先写入0再写入1,即发出TS1消息,连续2次。

2.6.2. 链路禁用

通过在下游设备的链路控制寄存器中设置Link Disable位,软件可以禁用链路。当禁用链路时,下游组件会收到禁用信号并执行相应的操作,这也会导致它们进行热复位。禁用链路的操作将触发下游端口进入Recovery LTSSM状态,并开始发送具有Disable位设置的TS1消息。需要注意的是,只有在禁用链路后,才能对下游端口进行控制。因此,Link Disable位被保留给上行端口,例如终端设备或交换机上行端口。

Link Control Register寄存器位于PCI Express Capability的Offset PXCAP + 10h: PXLC – PCI Express Link Control。

当上行端口识别到带有Disabled位设置的传入TS1消息时,物理层会向链路层发送LinkUp=0(false)信号,并使所有通道进入电气空闲状态。在经过2毫秒的超时后,上行端口将进入Detect状态,但下行端口将保持在Disabled LTSSM状态,直到被指示退出该状态(例如通过清除Link Disable位),因此链路将保持禁用状态,并且在未被解除禁用之前不会尝试进行训练。

功能层级复位

3.1. FLR

FLR(Function-Level Reset)功能允许软件仅重置多功能设备中的某一个功能,而无需对所有功能进行复位。为了确定是否支持FLR功能,软件可以检查设备能力寄存器中的Function-Level Reset Capability位。如果此位被设置,软件可以通过设置设备控制寄存器中的Initiate Function-Level Reset位来启动FLR操作。FLR的实现虽然推荐,但并非每个设备都支持该功能,因此在尝试使用FLR之前,软件应先确认设备是否支持该功能。

是否支持FLR,通过查看位于PCI Express Capability的Offset PXCAP + 4h: PXDCAP – PCI Express Device Capabilities。

设置FLR,通过设置于通过查看位于PCI Express Capability的Offset PXCAP + 8h: PXDC – PCI Express Device Control。

FLR重置功能的内部状态和寄存器,使其处于静止状态,但不会影响任何sticky位、硬件初始化的位或链路特定的寄存器(如Captured Power、ASPM Control、Max_Payload_Size或Virtual Channel寄存器)。如果已发送了一个未解除的Assert INTx中断消息,则必须发送相应的Deassert INTx消息,除非该中断由内部的另一个功能共享并且仍然处于已断言状态。当接收到FLR时,该功能的所有外部活动都需要停止。

3.2. 时间要求

  1. 与可能访问该功能的其他软件协调,确保在FLR期间不尝试访问该功能。

  2. 清除整个命令寄存器,使该功能处于静止状态。

  3. 确保先前请求的完成已通过轮询设备状态寄存器中的Transactions Pending位进行返回,直到该位被清除或等待足够长的时间以确保这些完成永远不会被返回。多长时间足够长呢?如果使用了完成超时,可以在发送FLR之前等待超时时间。如果禁用了完成超时,则至少等待100毫秒。

  4. 启动FLR并等待100毫秒。

  5. 设置功能的配置寄存器,并使其能够进行正常操作。

当FLR完成后,无论何时完成,都必须清除Transactions Pending位。

3.3. 复位退出

在退出复位状态后,链路训练和初始化必须在20毫秒内开始。由于复位信号是异步的,设备可能在不同的时间退出复位状态,但必须在此时间内开始进行训练。

为了允许复位组件执行内部初始化,系统软件必须在复位结束后至少等待100毫秒才能尝试发送配置请求到它们。如果软件在100毫秒等待时间之后向设备发起配置请求,但设备仍未完成自我初始化,它会返回带有CRS状态的完成。由于配置请求只能由CPU发起,因此完成将返回给根复杂性。作为响应,根复杂性可以自动重新发出配置请求,或者使失败对软件可见。规范还指出,如果启用了CRS软件可见性,则软件应仅使用100毫秒的等待周期,否则可能会导致长时间超时或处理器停滞。

在复位后,设备被允许有1.0秒(-0% / +50%)的时间来做出对配置请求的正确响应。因此,在判断一个无响应的设备是否损坏之前,系统必须小心等待那么长的时间。这个值继承自PCI,这种长时间延迟的原因可能是一些设备将配置空间实现为本地存储器,必须在配置软件能够正确查看之前进行初始化。它的初始化可能涉及从慢速串行EEPROM复制所需的信息,因此可能需要一些时间。

开发实践

Linux下和Windows下的PCIe复位,均是通过操作Capacity Register来实现的。Windows下操作Capacity Register可以通过rw-everything或内核驱动WinIo来实现。以下具体方法使用Linux。

4.1. 传统复位

能够软件操作的只有Hot Reset。两种Hot Reset的方法都需要在上行设备上进行设置。

获取上行设备路径:

michael@ubuntu22:~$ readlink /sys/bus/pci/devices/0000:0f:00.0
../../../devices/pci0000:00/0000:00:02.2/0000:0f:00.0
# 上面的内容即是DBF设备的完整路径,0000:00:02.2即是它的上行设备DBF

4.1.1. Secondary Bus Reset

# 获取Bridge Control寄存器
root@ubuntu22:~# setpci -s 00:02.2 3e.w
0012
root@ubuntu22:~# setpci -s 00:02.2 BRIDGE_CONTROL
0012
# 连续设置2个Reset, 0x52=0x12|0x40,即设置Secondary Bus Rset=1
root@ubuntu22:~# setpci -s 00:02.2 BRIDGE_CONTROL=0x52
root@ubuntu22:~# setpci -s 00:02.2 BRIDGE_CONTROL=0x52
# 还原
root@ubuntu22:~# setpci -s 00:02.2 BRIDGE_CONTROL=0x52
# 通知系统移除设备             /
root@ubuntu22:/home/michael# echo 1 > /sys/bus/pci/devices/0000:0f:00.0/remove
# Rescan
echo 1 > /sys/bus/pci/rescan

4.1.2. Link Disable Rset

# 获取Link Control Register
root@ubuntu22:~# setpci -s 00:02.2 CAP_EXP+10.b
40
# 连续设置2个Reset, 0x50=0x40|0x10,即设置Link Disable=1
root@ubuntu22:~# setpci -s 00:02.2 CAP_EXP+10.b=0x50
# 还原
sleep 1
root@ubuntu22:~# setpci -s 00:02.2 CAP_EXP+10.b=0x40
# 通知系统移除设备             /
root@ubuntu22:/home/michael# echo 1 > /sys/bus/pci/devices/0000:0f:00.0/remove
# Rescan
echo 1 > /sys/bus/pci/rescan

4.2. FLR

# 获取PXDCAP寄存器查看是否支持FLR
root@ubuntu22:/home/michael# setpci -s 0f:00.0 CAP_EXP+4.L
112c8da1
# 28Bit为1,支持FLR
# 连续设置2个Reset, 0x50=0x40|0x10,即设置Link Disable=1
root@ubuntu22:~# setpci -s 00:02.2 CAP_EXP+10.b=0x50
# 还原
sleep 1
root@ubuntu22:~# setpci -s 00:02.2 CAP_EXP+10.b=0x40
# 通知系统移除设备             /
root@ubuntu22:/home/michael# echo 1 > /sys/bus/pci/devices/0000:0f:00.0/remove
# Rescan
echo 1 > /sys/bus/pci/rescan

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/267211.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

SQL面试题(2)

第一题 创建trade_orders表: create table `trade_orders`( `trade_id` varchar(255) NULL DEFAULT NULL, `uers_id` varchar(255), `trade_fee` int(20), `product_id` varchar(255), `time` varchar(255) )ENGINE = InnoDB CHARACTER SET = utf8mb4 COLLATE = utf8mb4_0900_…

【机器学习基础】层次聚类-BIRCH聚类

🚀个人主页:为梦而生~ 关注我一起学习吧! 💡专栏:机器学习 欢迎订阅!相对完整的机器学习基础教学! ⭐特别提醒:针对机器学习,特别开始专栏:机器学习python实战…

如何将视频的声音转换成音频?视频提取音频的小妙招

在数字化时代,视频和音频是我们生活中不可或缺的元素。有时候,我们可能只需要视频中的音频部分,这时就需要将视频的声音转换成音频文件。那么,如何实现这一操作呢?本文将为您介绍几种简单而实用的小妙招。 方法一&…

朱元璋如何处理十万女俘让蒙古人险些灭绝

明太祖朱元璋的铁血手腕:十万女俘与蒙古人的灭顶之灾 在中国历史上,明太祖朱元璋以其卓越的领导才能和深谋远虑的政治智慧,开创了明朝的辉煌篇章。然而,在他登基称帝的背后,却隐藏着一段鲜为人知的残酷往事。今天&…

抽象类、模板方法模式

抽象类概述 在Java中abstract是抽象的意思,如果一个类中的某个方法的具体实现不能确定,就可以申明成abstract修饰的抽象方法(不能写方法体了),这个类必须用abstract修饰,被称为抽象类。 抽象方法定义&…

202435读书笔记|《半小时漫画中国史》——读点经济学与历史,生活更美好,趣味烧脑土地制度、商鞅变法、华丽丽的丝绸之路这里都有

202435读书笔记|《半小时漫画中国史》——读点经济学与历史,生活更美好,趣味烧脑土地制度、商鞅变法、华丽丽的丝绸之路这里都有 1. 土地政策、度量衡及税收2. 商鞅变法3. 西汉经济4. 西汉盐铁大辩论5. 西汉丝绸之路 《半小时漫画中国史:经济…

Day09:基础入门-算法逆向散列对称非对称JS源码逆向AESDESRSASHA

目录 算法加密-概念&分类&类型 加密解密-识别特征&解密条件 解密实例-密文存储&数据传输 思维导图 章节知识点: 应用架构:Web/APP/云应用/三方服务/负载均衡等 安全产品:CDN/WAF/IDS/IPS/蜜罐/防火墙/杀毒等 渗透命令&am…

2024年2月最新微信域名检测拦截接口源码

这段PHP代码用于检测指定域名列表中的域名是否被封。代码首先定义了一个包含待检测域名的数组 $domainList,然后遍历该数组,对每个域名发送HTTP请求并检查响应内容以判断域名是否被封。 具体步骤如下: 1. 定义待检测的域名列表。 2. 遍历域名…

将法律条文很美观的复制到word上

前言 目前很多法律条款都没有现成的PDF或者word格式的供大家下载,这个时候呢,领导又要求你帮他搞定,这就很。。。。 步骤 复制全部条款到word中使用wps的排版功能,将空格和空段落全部移除 3. 设置好你需要的格式 标题&#xff…

python毕设选题 - 大数据商城人流数据分析与可视化 - python 大数据分析

文章目录 0 前言课题背景分析方法与过程初步分析:总体流程:1.数据探索分析2.数据预处理3.构建模型 总结 最后 0 前言 🔥 这两年开始毕业设计和毕业答辩的要求和难度不断提升,传统的毕设题目缺少创新和亮点,往往达不到…

Flink SQL 中的流式概念:状态算子

博主历时三年精心创作的《大数据平台架构与原型实现:数据中台建设实战》一书现已由知名IT图书品牌电子工业出版社博文视点出版发行,点击《重磅推荐:建大数据平台太难了!给我发个工程原型吧!》了解图书详情,…

git安装与使用4.3

一、git的安装 1、下载git包 下载git包url:https://git-scm.com/download/win 下载包分为:64位和32位 2、点击安装包 2、选择安装路径 3、 点击下一步 4、点击next 5、点击next 6、点击next 7、 8、 9、 10、 11、 12、在桌面空白处,右键…

k8s 存储卷详解与动静部署详解

目录 一、Volume 卷 1.1 卷类型 emptyDir : hostPath: persistentVolumeClaim (PVC): configMap 和 secret: 二、 emptyDir存储卷 2.1 特点 2.2 用途: 2.3 示例 三、 hostPath存储卷 3.1 特点 3.2 用途 …

137.乐理基础-协和音程、不协和音程

内容参考于: 三分钟音乐社 上一个内容:136.旋律音程、和声音程、自然音程、变化音程 上一个内容里练习的答案: 所有音程都可以分成协和音程与不协和音程两大类 协和音程又分三个小类: 第一个小类叫极完全协和音程,就…

【Linux深入剖析】进程控制 | 进程程序替换--长篇深层次讨论

📙 作者简介 :RO-BERRY 📗 学习方向:致力于C、C、数据结构、TCP/IP、数据库等等一系列知识 📒 日后方向 : 偏向于CPP开发以及大数据方向,欢迎各位关注,谢谢各位的支持 目录 1.进程创建1.1 fork函…

《汇编语言》- 读书笔记 - 第13章-int 指令

《汇编语言》- 读书笔记 - 第13章-int 指令 13.1 int 指令13.2 编写供应用程序调用的中断例程中断例程:求一 word 型数据的平方主程序中断处理程序执行效果 中断例程:将一个全是字母,以0结尾的字符串,转化为大写主程序中断处理程序…

【JavaEE】_Spring MVC项目之建立连接

目录 1. Spring MVC程序编写流程 2. 建立连接 2.1 RequestMapping注解介绍 2.2 RequestMapping注解使用 2.2.1 仅修饰方法 2.2.2 修饰类与方法 2.3 关于POST请求与GET请求 2.3.1 GET请求 2.3.2 POST请求 2.3.3 限制请求方法 1. Spring MVC程序编写流程 1. 建立连接&…

TCP为什么要三次握手?

TCP三次握手协议是为了在不可靠的互联网环境中可靠地建立起一个连接,三次握手可以确保两端的发送和接收能力都是正常的。 那么,为什么是三次而不是二次或四次握手呢? 为什么不是二次握手? 如果是二次握手,即客户端发…

Qt5.9.9交叉编译(带sqlite3、OpenSSL)

1、交叉编译工具链 这里ARM平台是ARM CortexA9的,一般交叉编译工具链demo板厂商都会提供,若未提供或想更换新版本的交叉编译工具链可参考以下方式获取。 1.1 下载适用于ARM CortexA9的交叉编译工具链 Linaro Releases下载gcc4的最新版xxxx-i686_arm-li…

蓝桥杯-单片机组基础7-存储器映射扩展与PWM脉冲调制(附小蜜蜂课程代码)

蓝桥杯单片机组备赛指南请查看这篇文章:戳此跳转蓝桥杯备赛指南文章 本文章针对蓝桥杯-单片机组比赛开发板所写,代码可直接在比赛开发板上使用。 型号:国信天长4T开发板(绿板),芯片:IAP15F2K6…