当前位置: 首页 > article >正文

Chapter 14: Link Initialization Training

Chapter 14: Link Initialization Training书籍: PCI Express Technology 3.0 (MindShare Press, 2012)页码: Book Pages 487-520 | PDF Pages 547-580学习日期: 2026-04-13本章概要本章描述 PCIe 链路初始化和训练过程包括 TS1/TS2 有序集、极性检测、Lane 反转、链路宽度协商、速度协商、均衡训练和合规性模式。14.1 链路训练概述为什么需要链路训练建立物理链路通信协商链路参数确保两端兼容训练阶段Detect: 检测链路伙伴Polling: 发送 TS1/TS2 建立同步Configuration: 协商 Lane 宽度、速度Equalization: 协商均衡设置 (Gen3)Configuration (continued): 完成配置L0: 正常工作状态14.2 TS1/TS2 有序集TS1 有序集用途: 链路初始化和协商内容:Link Number: 链路标识Lane Number: Lane 标识Speed Negotiation: 支持的速度Polarity: 极性Equalization: 均衡设置 (Gen3)TS2 有序集用途: 确认 TS1 协商结果内容: 类似 TS1特定值表示确认TS1/TS2 数量必须发送至少 1024 个 TS1/TS2如果未收到响应继续发送14.3 极性检测和反转极性检测差分信号可能反转接收机自动检测并纠正D 和 D- 交换Lane 反转某些系统 Lane 顺序可能反转TS1/TS2 协商检测反转自动调整 Lane 映射14.4 链路宽度协商宽度能力广告各自支持的宽度协商最大公共宽度支持: x1, x2, x4, x8, x12, x16, x32协商过程设备A: 支持 x4, x2, x1 设备B: 支持 x8, x4, x2, x1 → 协商结果: x214.5 速度协商速度能力Gen1: 2.5 GT/s (必须支持)Gen2: 5.0 GT/sGen3: 8.0 GT/s协商过程从 Gen1 (2.5 GT/s) 开始逐步协商到更高速度确认共同支持的速度Rate IDTS1/TS2 中的 Rate ID 字段指示支持的速度14.6 Gen3 均衡训练为什么需要均衡高频率信号衰减码间干扰需要 Tx/Rx 均衡均衡过程发射机预强调接收机 CTLE可选的 DFE (判决反馈均衡)协商通过 TS1/TS2 协商均衡系数双方确认均衡设置14.7 合规性模式合规性测试验证设备符合规范发送特定测试模式检测物理层问题合规性模式发送固定的比特模式用于眼图测试验证信号质量14.8 恢复状态 (Recovery)Recovery 状态链路需要重新训练时进入例如: 从低功耗状态恢复从 L0s/L1 恢复到 L0Recovery 过程进入 Recovery重新发送 TS1/TS3重新协商参数恢复到 L0关键知识点速记链路训练阶段: Detect → Polling → Configuration → Equalization → L0TS1 初始化TS2 确认从 Gen1 (2.5 GT/s) 开始协商极性和 Lane 反转自动检测均衡训练是 Gen3 特有的Recovery 状态用于重新训练合规性模式用于测试笔记结束

相关文章:

Chapter 14: Link Initialization Training

Chapter 14: Link Initialization & Training 书籍: PCI Express Technology 3.0 (MindShare Press, 2012) 页码: Book Pages 487-520 | PDF Pages 547-580 学习日期: 2026-04-13本章概要 本章描述 PCIe 链路初始化和训练过程,包括 TS1/TS2 有序集、极性检测、L…...

从MPLS到SRv6:为什么运营商都在悄悄升级这个不起眼的技术?

从MPLS到SRv6:运营商网络升级背后的技术革命 当你在手机上流畅观看4K视频时,或许不会想到这背后有一场持续了二十年的网络协议演进。全球运营商正在将承载网核心技术从MPLS悄然升级为SRv6,这场变革将直接影响未来十年互联网的传输效率与业务创…...

别再让你的Elasticsearch裸奔了!手把手教你配置安全认证(附一键检测脚本)

Elasticsearch安全加固实战:从漏洞应急到生产级防护 那天凌晨三点,我被一阵急促的电话铃声惊醒。电话那头是值班同事颤抖的声音:"我们的用户数据被挂在暗网论坛了,黑客留下的日志显示是通过Elasticsearch未授权访问漏洞获取…...

从GMSK调制到CRC校验:手把手拆解一条AIS报文是如何‘炼成’并安全送达的

从GMSK调制到CRC校验:手把手拆解一条AIS报文是如何‘炼成’并安全送达的 在浩瀚的海域中,船舶自动识别系统(AIS)如同无形的空中交通管制员,确保着每艘船只的安全航行。这条看似简单的报文背后,隐藏着一套精…...

千问3.5-2B算法学习助手:从原理理解到代码实现

千问3.5-2B算法学习助手:从原理理解到代码实现 1. 为什么需要算法学习助手 算法是计算机科学的核心基础,但传统学习方式往往存在几个痛点:抽象概念难以直观理解、代码实现容易出错、复杂度分析不够直观。很多学习者会陷入"死记硬背&qu…...

[实战指南] 基于STM32 DCMI接口的OV2640图像采集与实时显示系统

1. OV2640摄像头基础解析 OV2640这颗200万像素的CMOS传感器,可以说是嵌入式视觉项目的性价比之选。我第一次用它做项目时,发现它最吸引人的特点是支持JPEG压缩输出——这意味着在1600x1200分辨率下,数据量能从3.8MB压缩到300KB左右&#xff0…...

如何快速掌握dnSpy BAML反编译:5个高效技巧让你轻松编辑WPF界面

如何快速掌握dnSpy BAML反编译:5个高效技巧让你轻松编辑WPF界面 【免费下载链接】dnSpy Unofficial revival of the well known .NET debugger and assembly editor, dnSpy 项目地址: https://gitcode.com/gh_mirrors/dns/dnSpy 还在为WPF应用程序的BAML二进…...

飞凌OK3568-C开发板音频调试实战:从DTS配置到amixer命令,搞定RK809 Codec录音放音

飞凌OK3568-C开发板音频调试实战:从DTS配置到amixer命令,搞定RK809 Codec录音放音 在嵌入式Linux开发中,音频功能的调试往往是让开发者头疼的环节之一。特别是当面对集成度高的PMIC芯片时,如何正确配置DTS、理解音频路径切换逻辑、…...

FPGA做PI控制,避开这3个坑:定点数、积分饱和与代码风格实战指南

FPGA实现PI控制的三大实战陷阱与避坑指南 当工程师们从MATLAB/Simulink的浮点仿真世界踏入FPGA的硬件实现领域时,往往会遭遇一系列意想不到的"暗礁"。我曾在一个电机控制项目中,花费整整两周时间才排查出一个由定点数溢出导致的PI控制器异常振…...

【OpenCV 实战指南】特征匹配:从暴力匹配到实战调优

1. 暴力匹配基础:从理论到OpenCV实现 第一次接触特征匹配时,我被这个看似简单实则精妙的技术深深吸引了。想象一下,你手上有两张不同角度拍摄的同一栋建筑的照片,如何让计算机自动找到两张照片中相同的窗户或装饰?这就…...

LaTeX Beamer进阶玩法:手把手教你定制专属高校/实验室主题模板(以清华、上交模板为例)

LaTeX Beamer进阶玩法:手把手教你定制专属高校/实验室主题模板 第一次站在学术会议讲台上时,我盯着投影仪上那套千篇一律的Beamer默认模板,突然意识到一个问题:为什么顶尖高校的教授们总能拿出那些让人眼前一亮的幻灯片&#xff1…...

别再搞混了!Ubuntu 20.04上`ssh`和`sshd`服务的区别,以及systemctl的正确操作姿势

Ubuntu 20.04中SSH服务管理的深度解析:从混淆到精通 在Linux系统管理中,SSH服务无疑是日常操作中最常打交道的组件之一。但许多中级用户甚至部分资深开发者,在面对Ubuntu系统中ssh和sshd的命名差异时,仍会陷入困惑。这种困惑不仅体…...

灵活的使用ap_ctlr_none实现功能(二)

一、h文件设计 #ifndef FRAME_TOP_H_ #define FRAME_TOP_H_ //#include "ap_int.h" #include "hls_stream.h" #include "ap_axi_sdata.h" // 定义带边带信号的 AXI4-Stream 数据类型 // 数据宽度 24 位(RGB888),用户自定义宽度为 1(用于 …...

从电机控制到新能源并网:深入浅出图解Clark/Park变换的工程应用场景

从电机控制到新能源并网:深入浅出图解Clark/Park变换的工程应用场景 坐标变换技术就像电力电子领域的"瑞士军刀",在不同应用场景中展现出惊人的适应性。第一次接触Clark和Park变换时,许多工程师都会被矩阵运算吓退,但真…...

高通Ride平台镜像刷写实战:从QFIL到Fastboot的路径选择与避坑指南

1. 高通Ride平台镜像刷写入门指南 第一次接触高通Ride平台的开发者,往往会被各种刷写工具搞得晕头转向。作为一个在这个领域摸爬滚打多年的老手,我完全理解这种困惑。记得我第一次刷写Ride平台时,花了整整两天时间才搞明白QFIL和Fastboot的区…...

MATLAB text函数进阶:从基础标注到动态交互式文本应用

1. MATLAB text函数基础回顾与核心功能 第一次接触MATLAB的text函数时,我完全被它简单的语法迷惑了——看起来就是个在图上写字的工具,直到有次需要给实验数据添加动态注释,才发现这个函数藏着不少玄机。text函数最基础的用法确实就是在指定坐…...

【编译原理实战】语法制导翻译:从SDD/SDT理论到抽象语法树构建

1. 语法制导翻译:编译器背后的隐形推手 第一次接触语法制导翻译(Syntax-Directed Translation)时,我正试图给自制的脚本语言添加类型检查功能。当时手动维护符号表的痛苦经历让我意识到:需要一套系统化的方法将语法结构…...

别再死记硬背了!用‘网络拓扑’和‘交换技术’的故事,5分钟搞懂计算机网络核心概念

用‘拓扑家族’和‘快递员’的故事,5分钟解锁计算机网络核心逻辑 想象一下,如果计算机网络中的设备能开口说话,星形拓扑的中心交换机可能会抱怨:"每天处理这么多请求,我的CPU都要冒烟了!"而总线拓…...

别再傻傻分不清!5分钟搞懂NPN和PNP三极管的电流流向与电压偏置(附实战电路图)

电子工程师必看:NPN与PNP三极管的实战应用指南 三极管作为电子电路中最基础的放大与开关元件,其核心原理往往被初学者视为"拦路虎"。特别是NPN与PNP两种类型的电流流向差异,常常成为电路设计中的"隐形陷阱"。想象一下&am…...

3分钟学会:如何将B站缓存视频完美合并为MP4并保留弹幕?

3分钟学会:如何将B站缓存视频完美合并为MP4并保留弹幕? 【免费下载链接】BilibiliCacheVideoMerge 🔥🔥Android上将bilibili缓存视频合并导出为mp4,支持安卓5.0 ~ 13,视频挂载弹幕播放(Android consolidate…...

Netty实战避坑:ChannelInboundHandlerAdapter和SimpleChannelInboundHandler到底怎么选?别再乱用了

Netty处理器选择实战:ChannelInboundHandlerAdapter与SimpleChannelInboundHandler深度解析 在构建高性能网络应用时,Netty作为Java领域最成熟的NIO框架之一,其处理器(Handler)的设计直接影响着系统的稳定性和资源利用…...

猫抓浏览器扩展架构深度解析:现代Web资源嗅探技术实现方案

猫抓浏览器扩展架构深度解析:现代Web资源嗅探技术实现方案 【免费下载链接】cat-catch 猫抓 浏览器资源嗅探扩展 / cat-catch Browser Resource Sniffing Extension 项目地址: https://gitcode.com/GitHub_Trending/ca/cat-catch 猫抓(cat-catch)作为一款专业…...

Unity Gaussian Splatting:如何为你的3D项目注入实时点云渲染能力?

Unity Gaussian Splatting:如何为你的3D项目注入实时点云渲染能力? 【免费下载链接】UnityGaussianSplatting Toy Gaussian Splatting visualization in Unity 项目地址: https://gitcode.com/gh_mirrors/un/UnityGaussianSplatting 你是否曾面对…...

ZonyLrcToolsX:一键下载四大音乐平台歌词的终极解决方案

ZonyLrcToolsX:一键下载四大音乐平台歌词的终极解决方案 【免费下载链接】ZonyLrcToolsX ZonyLrcToolsX 是一个能够方便地下载歌词的小软件。 项目地址: https://gitcode.com/gh_mirrors/zo/ZonyLrcToolsX ZonyLrcToolsX是一款功能强大的跨平台歌词下载工具&…...

相控阵天线(四):直线阵列天线低副瓣综合实战对比与Python实现(切比雪夫、泰勒、Villeneuve)

1. 直线阵列天线低副瓣综合方法概述 天线工程师在设计相控阵系统时,最头疼的问题之一就是如何控制副瓣电平。想象一下,你正在调试一部雷达,主波束已经准确指向目标,但旁边那些不受控制的副瓣却在不断产生虚假信号,就像…...

S32K144时钟配置避坑指南:手把手教你用S32DS的clock_manager组件搞定外设时钟(附代码)

S32K144时钟配置实战:从原理到避坑的完整指南 第一次接触S32K144的时钟系统时,我被它的灵活性震惊了——但随之而来的是配置时的迷茫。记得有一次调试FlexCAN模块,程序莫名其妙地进入复位中断循环,花了整整两天才发现是时钟门控没…...

Cityscapes不够用?试试IDD数据集:针对印度复杂路况的语义分割实战与模型调优

突破Cityscapes局限:IDD数据集在印度复杂路况下的语义分割实战指南 当自动驾驶技术从实验室走向全球市场时,开发者们很快发现一个残酷的现实:在德国街道上表现优异的模型,到了印度班加罗尔的混乱交通中可能寸步难行。Cityscapes数…...

别再只用root了!用Hydra+自定义字典,教你安全测试Linux SSH弱密码(附完整命令)

企业级Linux SSH安全防护实战:从弱密码检测到系统加固 在数字化办公环境中,SSH作为Linux服务器远程管理的核心通道,其安全性直接关系到企业数据资产的命脉。根据2023年全球网络安全审计报告,约37%的服务器入侵事件源于SSH弱密码或…...

51单片机printf重定向避坑指南:为什么你的printf卡死了?

51单片机printf重定向避坑指南:为什么你的printf卡死了? 当你第一次在51单片机项目中使用printf函数时,可能会遇到一个令人困惑的现象:程序莫名其妙地卡死了,没有任何输出。这种情况在初学者中非常常见,而问…...

Arduino 运行异常的 7 个典型诱因与规避策略

1. 函数调用过载引发的崩溃 Arduino最常见的崩溃场景之一就是函数调用堆栈溢出。这个问题特别容易出现在递归函数设计中,我曾经在一个温控项目中就踩过这个坑。当时为了计算温度变化趋势,我写了个递归函数,结果设备运行不到半小时就自动重启。…...