PCIE那些事之AER高级信息上报

2023-12-26 21:40
文章标签 高级 信息 上报 pcie aer

本文主要是介绍PCIE那些事之AER高级信息上报,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

本文总结了AER错误处理流程
在这里插入图片描述

什么是AER

AER 英文简称 Advanced Error Reporting 翻译中文是高级错误报告,是PCIE异常信息处理机制,用于报告PCIe 错误信息
错误信息主要分为两种 Correctable Errors 和Uncorrectable errors
其中 Correctable Errors包含非致命的错误和致命的错误
a.ERR_FATAL:致命错误,此错误类型影响了PCIe link链路。
b.ERR_NONFATAL:指影响了设备功能,但是PCIe link还是稳定的
Correctable Errors:可纠正错误是指错误发生后,硬件可以自动恢复。
Uncorrectable errors:错误发生后,影响设备功能,硬件不能自动恢复。

AER信息类型

如下列表所述,注意如果是链路出现了错误需要需要Upstream设备向Root来报告错误进行重新训练

在这里插入图片描述
AER错误需要EP和RC端同时打开才能使用
这些错误信息可以通过设备控制器进行使能或者禁止
在这里插入图片描述

设备可以通过设备状态寄存器查询AER探测状态
在这里插入图片描述
RC寄存器中可以控制是否enable AER功能
在这里插入图片描述

AER机制原理

ERROR Message通过port端口上报给Root Complex 最后通过中断方式通知CPU进行处理
在这里插入图片描述
PCIe Correctable Errors处理流程
AER Driver同时获取RC和EP的错误状态信息, 此时Errors已经被物理层或者数据链路层给修复,AER仅仅获取错误的状态
在这里插入图片描述

PCIE Uncorrectable errors处理流程
AER可以同时获取RC和EP的状态,并行recovery强制热复位修复,复位会重新训练链路,影响系统数据的传输
在这里插入图片描述

linux AER处理流程

在这里插入图片描述

linux内核通过aerdrv.c进行驱动管理,分为驱动层drv.c和核心层core.c
在这里插入图片描述

系统运行的时候会注册aerdriver设备驱动驱动,AER注册成功需要支持以下2个条件
1.kernel中需要开启AER功能配置
2.需要支持MSI中断

static int __init aer_service_init(void)
{if (!pci_aer_available() || aer_acpi_firmware_first())return -ENXIO;return pcie_port_service_register(&aerdriver);
}
device_initcall(aer_service_init);

aerdriver是设备驱动结构体

static struct pcie_port_service_driver aerdriver = {.name		= "aer",.port_type	= PCI_EXP_TYPE_ROOT_PORT,.service	= PCIE_PORT_SERVICE_AER,.probe		= aer_probe,.remove		= aer_remove,.error_resume	= aer_error_resume,.reset_link	= aer_root_reset,
};

调用aer_probe 填充pcie_dev资源,注册中断进行aer错误收集与处理,使能root aer功能

static int aer_probe(struct pcie_device *dev)
{int status;struct aer_rpc *rpc;struct device *device = &dev->port->dev;/* Alloc rpc data structure */rpc = aer_alloc_rpc(dev);if (!rpc) 

这篇关于PCIE那些事之AER高级信息上报的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

kotlin中的行为组件及高级用法

《kotlin中的行为组件及高级用法》Jetpack中的四大行为组件:WorkManager、DataBinding、Coroutines和Lifecycle,分别解决了后台任务调度、数据驱动UI、异... 目录WorkManager工作原理最佳实践Data Binding工作原理进阶技巧Coroutine

Win32下C++实现快速获取硬盘分区信息

《Win32下C++实现快速获取硬盘分区信息》这篇文章主要为大家详细介绍了Win32下C++如何实现快速获取硬盘分区信息,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 实现代码CDiskDriveUtils.h#pragma once #include <wtypesbase

Python如何实现PDF隐私信息检测

《Python如何实现PDF隐私信息检测》随着越来越多的个人信息以电子形式存储和传输,确保这些信息的安全至关重要,本文将介绍如何使用Python检测PDF文件中的隐私信息,需要的可以参考下... 目录项目背景技术栈代码解析功能说明运行结php果在当今,数据隐私保护变得尤为重要。随着越来越多的个人信息以电子形

深入解析Spring TransactionTemplate 高级用法(示例代码)

《深入解析SpringTransactionTemplate高级用法(示例代码)》TransactionTemplate是Spring框架中一个强大的工具,它允许开发者以编程方式控制事务,通过... 目录1. TransactionTemplate 的核心概念2. 核心接口和类3. TransactionT

C#实现系统信息监控与获取功能

《C#实现系统信息监控与获取功能》在C#开发的众多应用场景中,获取系统信息以及监控用户操作有着广泛的用途,比如在系统性能优化工具中,需要实时读取CPU、GPU资源信息,本文将详细介绍如何使用C#来实现... 目录前言一、C# 监控键盘1. 原理与实现思路2. 代码实现二、读取 CPU、GPU 资源信息1.

在C#中获取端口号与系统信息的高效实践

《在C#中获取端口号与系统信息的高效实践》在现代软件开发中,尤其是系统管理、运维、监控和性能优化等场景中,了解计算机硬件和网络的状态至关重要,C#作为一种广泛应用的编程语言,提供了丰富的API来帮助开... 目录引言1. 获取端口号信息1.1 获取活动的 TCP 和 UDP 连接说明:应用场景:2. 获取硬

SpringBoot使用Apache Tika检测敏感信息

《SpringBoot使用ApacheTika检测敏感信息》ApacheTika是一个功能强大的内容分析工具,它能够从多种文件格式中提取文本、元数据以及其他结构化信息,下面我们来看看如何使用Ap... 目录Tika 主要特性1. 多格式支持2. 自动文件类型检测3. 文本和元数据提取4. 支持 OCR(光学

C#实现获取电脑中的端口号和硬件信息

《C#实现获取电脑中的端口号和硬件信息》这篇文章主要为大家详细介绍了C#实现获取电脑中的端口号和硬件信息的相关方法,文中的示例代码讲解详细,有需要的小伙伴可以参考一下... 我们经常在使用一个串口软件的时候,发现软件中的端口号并不是普通的COM1,而是带有硬件信息的。那么如果我们使用C#编写软件时候,如

通过C#获取PDF中指定文本或所有文本的字体信息

《通过C#获取PDF中指定文本或所有文本的字体信息》在设计和出版行业中,字体的选择和使用对最终作品的质量有着重要影响,然而,有时我们可能会遇到包含未知字体的PDF文件,这使得我们无法准确地复制或修改文... 目录引言C# 获取PDF中指定文本的字体信息C# 获取PDF文档中用到的所有字体信息引言在设计和出

C#读取本地网络配置信息全攻略分享

《C#读取本地网络配置信息全攻略分享》在当今数字化时代,网络已深度融入我们生活与工作的方方面面,对于软件开发而言,掌握本地计算机的网络配置信息显得尤为关键,而在C#编程的世界里,我们又该如何巧妙地读取... 目录一、引言二、C# 读取本地网络配置信息的基础准备2.1 引入关键命名空间2.2 理解核心类与方法