PCIe学习笔记(17)

延迟容忍报告(LTR)消息

LTR消息可选地用于报告有关其读/写服务延迟容忍度的设备行为。

(通过 LTR,PCIe 设备可以告知系统它们能容忍的最大响应延迟是多少,只要系统在这个时间之内对 PCIe 设备提出的请求做出响应即可。)

LTR消息的形成遵循以下规则:

•LTR消息的定义如表所示。

•LTR消息不包含数据负载(TLP类型是Msg)。

•Length字段保留。

•LTR消息必须使用默认的流量分类指示器(TC0)。实现LTR支持的接收器必须检查是否违反此规则。如果接收方确定某个TLP违反了此规则,则必须将该TLP作为畸形TLP处理。

◦这是一个与接收端口相关的报告错误

(LTR可参考PCIe LTR 基本知识-CSDN博客

优化缓冲区刷新/填充(OBFF)消息

(通过 OBFF,系统告知 PCIe 设备在哪些时间进行数据传输。OBFF 只是提供一个建议时间,PCIe 设备可以忽略 OBFF 信息,在它想要发请求的任意时刻发送请求(这样就导致功耗比较大,所以最好还是按照 OBFF 的建议来做)。有两种方式完成 OBFF 信息的交互:(1)通过向 Endpoint 发送消息(message);(2)控制 WAKE# 引脚。在两种方式都支持的情况下,优先选择 WAKE# 引脚的方式。只有在 WAKE# 引脚不能用的时候,再去选择发送消息(message)的方式。可参考:OBFF (Optimized Buffer Flush and Fill)_pcie obff-CSDN博客++)++

OBFF消息可用于向端点报告平台中心资源状态。OBFF消息的形成遵循以下规则:

•OBFF消息的定义如表2-33所示。

•OBFF消息不包含数据负载(TLP类型为Msg)。

•Length字段保留。

•请求端ID必须设置为发送端ID。

•OBFF消息必须使用缺省的流分类标识(TC0)。实现OBFF支持的接收方必须检查是否违反此规则。如果接收方确定某个TLP违反了此规则,则必须将该TLP作为畸形TLP处理。

这是一个与接收端口相关的报告错误

精确时间测量(PTM)消息

PTM消息定义如表所示。

•PTM Request和PTM Response Messages必须使用TLP类型的Msg,并且不能包含数据负载。Length字段是保留的。

•PTM ResponseD Message必须使用TLP类型MsgD,并且必须包含TLP报头第8到15字节的64位PTM Master Time字段和包含32位Propagation Delay字段的1 DW数据负载。

•请求者ID必须设置为发送端ID。

•PTM对话框被定义为由PTM请求和相应的PTM响应或PTM响应消息组成的匹配的消息对。

•PTM消息必须使用缺省的流分类指示器(TC0)。实现PTM的接收器必须检查是否违反此规则。如果接收方确定某个TLP违反了此规则,则必须将该TLP作为畸形TLP处理。

◦这是一个与接收端口相关的报告错误

Precision Time Measurement(PTM)是PCIE4.0 之后引入的功能。它可以让具有独立本地计时时钟的不同组件实现精确的时间协调。这是通过使用独立于本地时间时钟的共享PTM Master time实现的。PTM Root负责维护PTM Master time,并使组件能够计算其本地时间与PTMMaster time之间的关系。

可参考:【PCIE】Precision Time Measurement (PTM)_pcie ptm-CSDN博客

相关推荐
zhuyixiangyyds7 小时前
day21和day22学习Pandas库
笔记·学习·pandas
每次的天空7 小时前
Android学习总结之算法篇四(字符串)
android·学习·算法
jingjingjing11118 小时前
笔记:docker安装(ubuntu 20.04)
笔记·docker·容器
背影疾风8 小时前
C++学习之路:指针基础
c++·学习
DreamBoy@9 小时前
【408--考研复习笔记】操作系统----知识点速览
笔记
UpUpUp……9 小时前
特殊类的设计/单例模式
开发语言·c++·笔记·单例模式
苏克贝塔9 小时前
CMake学习--Window下VSCode 中 CMake C++ 代码调试操作方法
c++·vscode·学习
odoo中国10 小时前
深度学习 Deep Learning 第15章 表示学习
人工智能·深度学习·学习·表示学习
电星托马斯10 小时前
C++中顺序容器vector、list和deque的使用方法
linux·c语言·c++·windows·笔记·学习·程序人生
清晨朝暮10 小时前
【算法学习计划】贪心算法(下)
学习