【最新技术早知道】PCIe Gen5 还没用上,Gen6 就来了?PCIe 6.0 系列文章之:《PCIe 6.0,到底 6 在哪?》


🔥点击查看精选 PCIe 系列文章🔥
🔥点击进入【芯片设计验证】社区,查看更多精彩内容🔥


📢 声明

  • 🥭 作者主页:【MangoPapa的CSDN主页】。
  • ⚠️ 本文首发于CSDN,转载或引用请注明出处 https://blog.csdn.net/weixin_40357487/article/details/120714950
  • ⚠️ 本文为非盈利性质,目的为 个人学习记录知识分享。因个人能力受限,存在协议解读不正确的可能。若您参考本文进行产品设计或进行其他事项并造成了不良后果,本人不承担相关法律责任。
  • ⚠️ 若本文所采用图片或相关引用侵犯了您的合法权益,请联系我进行删除。
  • 😄 欢迎大家指出文章错误,欢迎同行与我交流 ~
  • 📧 邮箱:mangopapa@yeah.net



— 0️⃣ PCIe 6.0 概述 —

✨ 0. PCIe 6.0 概述

  2019 年 5 月中旬 PCI-SIG 正式发布了 PCIe 5.0 的 1.0 版本后,便马不停蹄长驱直入进入了 PCIe 6.0 的预研阶段,并在 4 个半月后发布了 PCIe 6.0 的 0.3 版本。时隔两年,现如今 PCIe 6.0 的 0.9 版本已经发布,PCIe 6.0 正式版倚马可待(预计 2021 年底发布)。 (最新消息:确定了 2022 Q1 发布 )

  跟 PCIe 5.0 相比,PCIe 6.0 主要有以下变化:

  • 单 Lane 传输速率由 32 GT/s 变为 64 GT/s;
  • 传输信号由 NRZ 两电平变为 PAM4 四电平;
  • 编码方式由 128b/130b 变为 FLIT 编码;
  • 引入了 FEC 前向纠错机制,并维持既有的 Retry 重传机制;
  • LTSSM 新增加了 L0p 低功耗状态,允许部分 Lane Electric Idle、部分 Lane Active;
  • 新加了几种机制:DOE、CMA、DMWr、IDE。


— 1️⃣ 速率 64 GT/s —

✨ 1. 速率 64 GT/s

  单条传输线传输速率变为 64 GT/s 似乎在大家的预期之内,毕竟从 PCIe Gen1 到 Gen5 每次都是速率 Double。从 Gen5 的 32 GT/s 到 Gen6,按照惯性思维这次也该 64 GT/s 了。唯一让大家吃惊的是,Gen6 来得属实太快了。千千万万 PCIe 从业者,用都还没用过 PCIe 5.0,PCIe 6.0 便跃然眼前。



— 2️⃣ PAM4 信号 —

✨ 2. PAM4 信号

  传输信号采用 PAM4 四电平信号有点出乎人的意料,毕竟从 Gen1 到 Gen5 一直用得是 NRZ 二电平信号。不过想想 PAM4 也合情合理,再用 NRZ,这高频 Clock 就太难了。接下来再怎么搞我有点头疼,用 PAM16 也太难了吧,眼图都要瞎掉了。



— 3️⃣ FLIT 编码 —

✨ 3. FLIT 编码

  FLIT Mode,流控单元模式,是一种1b/1b的编码方式。之前是以 TLP 为单位进行事务传输,PCIe 6.0 以 FLIT 为单位进行事务传输,每个 FLIT 有 256 B 数据(格式如 式1),每 B 数据占用 4 UI。以 x8 为例,一次 FLIT 传输的格式如图 1 所示。

1 FLIT = 236 B TLP + 6 B DLP + 8 B CRC + 6 B FEC = 256 B

(式1)

  每个 FLIT 可以包含多笔 TLP,每笔 TLP 也可以拆分到多笔 FLIT。FLIT 中有 6 B DLP 数据(非DLLP),其中前 2 B 是留给 FLIT ACK / NAK / Replay 用的,取代了 Gen5 中采用 DLLP 的 ACK / NAK 机制。以 x16为例,由于不需额外规划 DLLP 的发送,这种在 FLIT 中加入 DLP 的 ACK / NAK 机制把相关时延从 ms 级降到了50 ns 以内,成效可观。只要开启了 FLIT Mode,即便数据速率从Gen6 调到 Gen1 ~ Gen5,仍然采用 FLIT 编码方式。

x8 FLIT 格式

图1 x8 FLIT 格式


— 4️⃣ 纠错 —

✨ 4. 纠错

  PCIe 6.0 引入了 FEC 前向纠错机制,并维持既有的 Retry 重传机制。在 PCIe Gen5 中,当 CRC 校验检测到 TLP 传输出错时,采用 Retry 机制进行重传。考虑到重传时延 <300 ns 且重传概率低于 10^-5,其对传输性能影响甚微。在 PCIe Gen6 中,对 Latency 的要求为 10 ns,仅采用 Retry 机制无法满足需求。在综合考量了FBER、FIT、FLIT Retry 概率、带宽效率、Latency 及 FLIT 的 FEC 能力后,PCIe Gen6 最终采用了低权重 FEC + Retry 的纠错方案。

  采用单 Symbol 的 FEC 纠错机制,可以将 FLIT 解码时间压缩到 2 ns 以内。



— 5️⃣ L0p 低功耗 —

✨ 5. L0p 低功耗

  如何实现更低功耗是个避不开的问题,PCIe 6.0 在既有低功耗状态 L0 / L0s / L1 / L2 基础上再加一个状态 L0p。PCIe 6.0 允许部分 Lane 进入 Electric Idle 状态、部分 Lane Active 仍然保持不中断的业务传输。当 Idle 状态的 Lane 想要重新 Active 时,只对这些 Lane 进行 Traning 握手,之前 Active 的 Lane 仍保持数据传输不间断。



— 6️⃣ 新的机制 —

✨ 6. 新的机制

  PCIe 6.0 新加了几种机制:DOE、CMA、DMWr、IDE,删掉了 LN。



— 参考 —

📚 参考

  1. PCI-SIG, “PCI Express base specification revision 6.0, version 0.9,” Beaverton, OR, USA, Oct 5, 2021.
  2. D. Das Sharma, “PCI Express 6.0 Specification: A Low-Latency, High-Bandwidth, High-Reliability, and Cost-Effective Interconnect With 64.0 GT/s PAM-4 Signaling,” in IEEE Micro, vol. 41, no. 1, pp. 23-29, 1 Jan.-Feb. 2021, doi: 10.1109/MM.2020.3039925.
  3. D. D. Sharma, “A low latency approach to delivering alternate protocols with coherency and memory semantics using PCI Express® 6.0 PHY at 64.0 GT/s,” 2021 IEEE Symposium on High-Performance Interconnects (HOTI), 2021, pp. 35-42, doi: 10.1109/HOTI52880.2021.00019.


PCIe 6.0 系列文章:


— END —

### PCIe Gen6 规格与特性 PCIe 6.0PCI-SIG 组织于2022年发布的最新一代标准,其主要目标是在保持向后兼容的同时显著提升性能和效率。以下是关于 PCIe Gen6 的一些关键特性和支持的硬件: #### 1. 双向带宽翻倍 PCIe 6.0 将单通道(Lane)的数据传输速率提高至 **64 GT/s**,相比前代 PCIe 5.0 提升了一倍[^1]。通过这种升级,PCIe 6.0 实现了惊人的 **256 GB/s** 的双向带宽。 #### 2. 向后兼容性 尽管 PCIe 6.0 使用了全新的编码方案——**PAM-4 调制技术**来实现更高的吞吐量,但它仍然完全向下兼容之前的 PCIe 版本设备。这意味着旧版硬件可以在新一代主板上运行,反之亦然。 #### 3. 错误检测与纠正机制 为了应对更高频率下可能出现的信号完整性问题,PCIe 6.0 引入了先进的错误检测和纠正算法,从而确保即使在高负载情况下也能维持稳定可靠的通信质量。 #### 4. 流控单元(FLIT) 作为一种创新性的流量管理模式,“流控单元”被引入到第六代协议中。它能够更高效地管理数据包发送过程中的缓冲区占用情况,减少延迟并优化资源利用率。 #### 5. 支持硬件类型 虽然具体产品还在陆续推出阶段,但从已知信息来看,未来将有多种类型的高性能计算平台、图形处理单元以及固态硬盘会采用此新标准: - **GPU**: 新一代显卡可能利用额外带宽进一步增强渲染能力和AI训练速度; - **NVMe SSDs**: 如 Memblaze 发布的企业级解决方案可能会率先适配该接口以发挥极致读写效能[^5]; - **FPGA 加速卡**: 类似 GaGe 所提供的定制化服务或许也会考虑加入对 PCIe 6.0 的全面支持[^4]. ```python # 示例代码展示如何查询当前系统所使用的PCIe版本号 import os def get_pcie_version(): try: result = os.popen('lspci -vv | grep LnkCap').read() return result.strip().split(':')[1].strip() except Exception as e: return str(e) print(get_pcie_version()) ```
评论 43
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

MangoPapa

请作者喝瓶可乐吧

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值