[PCIe] Hot reset and FLR reset Performing in linux

2023-10-29 14:20
文章标签 linux reset hot pcie performing flr

本文主要是介绍[PCIe] Hot reset and FLR reset Performing in linux,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

“热重置”是通过PCI Express链路触发的常规重置。当链路被迫进入电气空闲状态时,或通过发送带有热复位bit的TS1和TS2有序集来触发热复位。软件可以通过设置然后清除设备上游桥接端口的PCI配置空间中桥接控制寄存器中的辅助总线复位位来启动热复位。(下图Bridge Control Register->Secondary Bus Reset)

Secondary Bus Reset - Setting this bit triggers a hot reset on the corresponding PCI Express Port.
Software must ensure a minimum reset duration (Trst). Software and systems must honor
first-access-following-reset timing requirements defined in Section 6.6 ., unless the Readiness
Notifications mechanism (see Section 6.23 ) is used or if the Immediate Readiness bit in the relevant
Function’s Status register is Set.
Port configuration registers must not be changed, except as required to update Port status.
Default value of this bit is 0b.

“功能级别重置”(FLR)是仅影响PCI Express设备的单个功能的重置。它不得重置整个PCIe设备。 PCIe规范不需要实现功能级别的重置。通过将PCI配置空间中PCI Express功能结构中功能的设备控制寄存器中的启动功能级别复位位置1,可以启动功能级别复位。

Linux以/sys/bus/pci/devices/$dev/reset的形式公开功能级别的重置功能。向该文件写入1将启动相应功能的功能级复位。请注意,这仅影响设备的特定功能,而不影响整个设备,并且不要求设备按照PCIe规范实施功能级别的重置。

我不知道触发热重置的任何“较好”方法(没有sysfs条目)。但是,可以通过以下脚本使用setpci进行操作(其实就是写下游端口配置空间的Bridge Control Register->Secondary Bus Reset):

#!/bin/bashdev=$1if [ -z "$dev" ]; thenecho "Error: no device specified"exit 1
fiif [ ! -e "/sys/bus/pci/devices/$dev" ]; thendev="0000:$dev"
fiif [ ! -e "/sys/bus/pci/devices/$dev" ]; thenecho "Error: device $dev not found"exit 1
fiport=$(basename $(dirname $(readlink "/sys/bus/pci/devices/$dev")))if [ ! -e "/sys/bus/pci/devices/$port" ]; thenecho "Error: device $port not found"exit 1
fiecho "Removing $dev..."echo 1 > "/sys/bus/pci/devices/$dev/remove"echo "Performing hot reset of port $port..."bc=$(setpci -s $port BRIDGE_CONTROL)echo "Bridge control:" $bcsetpci -s $port BRIDGE_CONTROL=$(printf "%04x" $(("0x$bc" | 0x40)))
sleep 0.01
setpci -s $port BRIDGE_CONTROL=$bc
sleep 0.5echo "Rescanning bus..."echo 1 > "/sys/bus/pci/devices/$port/rescan"

 

这篇关于[PCIe] Hot reset and FLR reset Performing in linux的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/301229

相关文章

Linux内核定时器使用及说明

《Linux内核定时器使用及说明》文章详细介绍了Linux内核定时器的特性、核心数据结构、时间相关转换函数以及操作API,通过示例展示了如何编写和使用定时器,包括按键消抖的应用... 目录1.linux内核定时器特征2.Linux内核定时器核心数据结构3.Linux内核时间相关转换函数4.Linux内核定时

Linux镜像文件制作方式

《Linux镜像文件制作方式》本文介绍了Linux镜像文件制作的过程,包括确定磁盘空间布局、制作空白镜像文件、分区与格式化、复制引导分区和其他分区... 目录1.确定磁盘空间布局2.制作空白镜像文件3.分区与格式化1) 分区2) 格式化4.复制引导分区5.复制其它分区1) 挂载2) 复制bootfs分区3)

Linux服务器数据盘移除并重新挂载的全过程

《Linux服务器数据盘移除并重新挂载的全过程》:本文主要介绍在Linux服务器上移除并重新挂载数据盘的整个过程,分为三大步:卸载文件系统、分离磁盘和重新挂载,每一步都有详细的步骤和注意事项,确保... 目录引言第一步:卸载文件系统第二步:分离磁盘第三步:重新挂载引言在 linux 服务器上移除并重新挂p

Linux下屏幕亮度的调节方式

《Linux下屏幕亮度的调节方式》文章介绍了Linux下屏幕亮度调节的几种方法,包括图形界面、手动调节(使用ACPI内核模块)和外接显示屏调节,以及自动调节软件(CaliseRedshift和Reds... 目录1 概述2 手动调节http://www.chinasem.cn2.1 手动屏幕调节2.2 外接显

Linux(centos7)虚拟机没有IP问题及解决方案

《Linux(centos7)虚拟机没有IP问题及解决方案》文章介绍了在CentOS7中配置虚拟机网络并使用Xshell连接虚拟机的步骤,首先,检查并配置网卡ens33的ONBOOT属性为yes,然后... 目录输入查看ZFhrxIP命令:ip addr查看,没有虚拟机IP修改ens33配置文件重启网络Xh

linux实现对.jar文件的配置文件进行修改

《linux实现对.jar文件的配置文件进行修改》文章讲述了如何使用Linux系统修改.jar文件的配置文件,包括进入文件夹、编辑文件、保存并退出编辑器,以及重新启动项目... 目录linux对.jar文件的配置文件进行修改第一步第二步 第三步第四步总结linux对.jar文件的配置文件进行修改第一步进

linux ssh如何实现增加访问端口

《linuxssh如何实现增加访问端口》Linux中SSH默认使用22端口,为了增强安全性或满足特定需求,可以通过修改SSH配置来增加或更改SSH访问端口,具体步骤包括修改SSH配置文件、增加或修改... 目录1. 修改 SSH 配置文件2. 增加或修改端口3. 保存并退出编辑器4. 更新防火墙规则使用uf

Linux join命令的使用及说明

《Linuxjoin命令的使用及说明》`join`命令用于在Linux中按字段将两个文件进行连接,类似于SQL的JOIN,它需要两个文件按用于匹配的字段排序,并且第一个文件的换行符必须是LF,`jo... 目录一. 基本语法二. 数据准备三. 指定文件的连接key四.-a输出指定文件的所有行五.-o指定输出

Linux jq命令的使用解读

《Linuxjq命令的使用解读》jq是一个强大的命令行工具,用于处理JSON数据,它可以用来查看、过滤、修改、格式化JSON数据,通过使用各种选项和过滤器,可以实现复杂的JSON处理任务... 目录一. 简介二. 选项2.1.2.2-c2.3-r2.4-R三. 字段提取3.1 普通字段3.2 数组字段四.

Linux kill正在执行的后台任务 kill进程组使用详解

《Linuxkill正在执行的后台任务kill进程组使用详解》文章介绍了两个脚本的功能和区别,以及执行这些脚本时遇到的进程管理问题,通过查看进程树、使用`kill`命令和`lsof`命令,分析了子... 目录零. 用到的命令一. 待执行的脚本二. 执行含子进程的脚本,并kill2.1 进程查看2.2 遇到的