高速串行总线设计基础(十)常用MGT协议简介以及自定义协议示例
MGTs设计的挑战
了解各个挑战是开始解决任何工程问题的关键。设计多吉比特收发器(MGT)时,挑战包括理解收发器协议,信号完整性,阻抗和电源要求,屏蔽要求,印刷电路板(PCB)设计要求以及连接器和电缆选择要求。原型的仿真和测试对于成功的MGT设计也至关重要。本文先来讨论MGT协议的那些事!
协议概念介绍
SERDESs本身是相对灵活的设备。要设计它们,你必须定义一个对齐序列、一个时钟校正序列、链路编码方式和物理连接,数据就会在两个收发器之间流动。但这些数据的意义需要更多的定义,这就是协议的目的。什么数据传输到哪里,数据的含义是什么,数据中插入了什么,什么可以丢弃,都是由协议来定义的。
MGT的协议可以有很大的不同,从简单的数据定义到复杂的接口,再到上层协议。在MGTs中可以指定的项目包括:
数据格式(Data formats):视频和音频协议的值定义;我们如何使用1和0来表示特定的值或含义。
子信道(Sub-channels):通常在同一链路上需要几个不同的通道。子通道的一些常见用途是控制、状态和辅助数据路径。
数据条带化(Data striping):协议的一个常见功能是定义数据与开销的分离方式和位置。这通常被称为条带化或去嵌入。
嵌入(Embedding):协议通常定义数据与开销分离的方式和位置。协议经常定义数据如何以及在哪里被嵌入到协议流或数据包中。这对于遵循协议栈模型的协议尤其如此。
错误检测和处理(Errors detection and handling):协议定义了如何检测到错误以及发生错误时的情况。
流控制(Flow control):协议还可以定义流控制。这可以是多种多样的,从定义动态缩放子通道带宽分配的方式,到改变空闲插入率以匹配时钟校正需求。
寻址/切换/转发(Addressing/switching/forwarding):虽然串行协议的直接点对点性质消除了对寻址方案的许多需求,但一些更复杂的协议包括寻址方案。有了寻址就有了转发和交换的可能。
物理接口(Physical interface):驱动级别、预加重等,由协议指定,以确保设备之间的兼容性。
通常协议的选择很简单。在构建PCI Express卡时,只需运行PCI Express协议即可。但在构建专有系统时,系统架构师必须决定是使用预定义协议还是设计自定义协议。
标准协议
接下来提供一些工业标准协议的简要介绍(这些标准的完整定义可能内容很多,这里仅简要介绍)。
XAUI:万兆以太网的4通道接口(2.5 Gb/s有效载荷,3.125 Gb/s线速)。
PCI Express:将旧的并行PCI结构更新为高速串行结构。该协议的上层协议保持兼容,可轻松适应传统的PCI系统。
Serial RapidIO:旧的并行规范的另一个串行版本,RapidIO相当灵活,有时被用作与PCI和Infiniband等多个协议接口的方法。
FiberChannel:FiberChannel一直是一个串行标准,但它的速度在多年来一直在增加。随着铜缆互连的发展,它也已经可以在铜缆以及光纤上使用。
Infiniband:一种在铜线或光纤上运行的盒对盒协议。Infiniband类型的电缆已在几米范围内的多吉比特链接中高度流行。该规范允许各种设备和复杂性,并包括中继器、交换机或集线器的规格,以扩大连接设备的数量。Infiniband还可以使用Infiniband交换机和控制台进行复杂的系统配置,如下图。
高级交换(Advanced Switching):一种建立在与PCI Express相同的物理和数据级协议上的交换式结构协议。在交换结构领域,这是一套新兴的重要标准。
PICMG:PICMG是一个由600多家公司组成的联盟,他们合作开发高性能标准化背板架构的开放规范。其中许多标准使用了PCI和Infiniband等其他工业标准。
ATCA:又称高级电信计算架构或AdvancedTCA,这个PICMG标准是下一代电信机柜的规范。它的目的是缓解多厂商之间的操作性,同时提供一个非常灵活、非常可扩展的系统。该标准在一个共同的主题下有各种实现。包括星型背板的架构、冗余星型背板和全连接网状架构。
ATCA Carrier for Two PCIe Modules
Aurora:Aurora是一种相对简单的协议,仅处理链路层和物理问题。它被设计为允许其他协议(例如TCP / IP或以太网)轻松在其之上运行。它使用一个或多个高速串行通道,如下图:
除了物理接口定义外,它还定义了一个数据包结构,以及嵌入其他协议数据包、数据条带和流控制的推荐程序。它定义了一个验证链路的初始化程序,并描述了一个不允许使用错误过多的链路的程序。它没有任何寻址方案,所以不支持交换。它也没有定义数据有效载荷内的错误检测和重试或纠正。该协议由Xilinx公司开发,并发布给公众使用,不受限制。如下图:
自定义协议
有时候您想定义自己的协议。当标准协议不能满足您的需求和/或对于您的应用而言过于广泛时,这通常是有意义的。当然,有时也需要新的复杂协议,但这通常由专家委员会来决定。
在定义自己的协议时,需要考虑的一些事情最好通过一个简单的例子来说明。
在示例应用中,我们需要将一个恒定的1.8 GHz流从一个板子传输到另一个板子。进出系统的数据将是一个12位的总线,以150 MHz的速度变化。
有了这个简单的要求,你真正需要从协议中得到的是数据帧的定义、对齐和空闲字符。在这个例子中,我们将使用8b/10b作为链路编码方案,并借鉴其他8b/10b标准来选择我们的标记和逗号。我们链接的基本结构如下图所示。
注:sf表示帧开始; ef表示帧尾
一旦我们为sf(帧的开始),ef(帧的结束)和空闲定义了一个字符或一组有序的字符,就需要确定线速度和数据帧大小。应该选择数据帧的大小,以便我们可以保证有足够的sf符号可以对齐,而空闲的符号可以提供时钟校正。在这种情况下,由于我们需要1.8 GHz的数据有效负载,因此一个简单的选择就是以2.5 Gb / s的速度运行线路。
这为我们提供了2 Gb / s的“有线有效负载”,可用于我们的1.8 GHz数据需求,而额外的容量可满足我们的开销需求。
因为我们要进行板对板(board-to-board),所以肯定会有不同的振荡器来驱动收发器的发送时钟,因此我们必须考虑时钟校正。在考虑制作数据框的大小时,我们需要权衡两个相互矛盾的需求。数据帧越大,开销越少,可用数据的带宽就越大。数据帧越小,对齐和时钟校正字符越多。显然,我们必须在这两个需求之间取得平衡。我们可以计算两个极限并在中间选择一些东西。
数据处理能力很容易计算。在可用的2Gb/s中,我们需要1.8Gb/s。因此,只要开销位适合可用空间,我们就可以了。现在,我们必须选择一个方便的大小,看看它是否有效。
如果数据帧包含2048个字节,并且开销为10个字节(sf为2个字节,ef为2个字节,空闲为6个字节),那么我们的总开销率为10/2058或大约0.5%。我们的可用开销为0.2 / 2或10%。我们可以将数据帧缩小20倍,但仍在我们的开销预算之内。
如果有必要的话,我们希望更小的时钟校正,所以我们需要研究这个问题。我们特殊的MGT需要一个20ppm精度的参考时钟。如果我们将MGT编程为2个符号宽的空闲序列,最大的校正将是每49,999个符号。空闲字符之间的距离必须小于这个数字。在大多数情况下,我们希望它小于空闲字符之间最大距离的1/3。我们大约是1/24,所以我们的非常简单的协议几乎已经确定了。我们唯一需要处理的是一个流控问题。
还记得我们只用了0.5%的时间做开销,却有10%的可用空间吗?我们需要定义什么来填充这个空间,以及谁来管理这个填充。所以我们需要用空闲时间来填充这段额外的时间,如下图:
请注意,根据参考振荡器的不同,帧间空闲的确切数量需要略有不同。如何发生这种情况应该在协议中定义,空闲字节的剥离也应该在协议中定义。我们可以在协议中简单地定义,发射机的责任是增加足够的空闲时间来填充线时间,而接收机的责任是将所有空闲时间,包括帧的开始和结束,从输入的数据流中剥离出来。
所以,这样九定义一个简单的协议的全部内容。但是实现呢?大部分的工作将由一个支持8b/10b的MGT来完成。我们需要在接口上添加一些自定义逻辑,但不需要处理器或软件,甚至不需要复杂的状态机。
下图显示了定制硬件和实现该协议的MGT的框图。
在某些情况下,一个非常简单的专有协议可能正是您所需要的。
拓展阅读
An Introduction to NI High-Speed Serial Instruments
- 分享
- 举报
-
浏览量:9493次2020-12-20 00:26:35
-
浏览量:8230次2020-12-20 14:19:53
-
浏览量:16865次2020-12-03 00:29:52
-
浏览量:12311次2020-12-05 03:10:25
-
浏览量:11725次2020-11-30 23:56:05
-
浏览量:19146次2020-12-07 00:56:53
-
浏览量:3065次2020-05-06 15:52:54
-
浏览量:14123次2020-12-16 01:39:47
-
浏览量:10622次2020-12-12 23:47:07
-
浏览量:12801次2020-12-10 00:29:44
-
浏览量:15108次2020-12-15 01:26:18
-
浏览量:2237次2020-08-03 12:02:37
-
浏览量:13460次2020-12-07 00:58:01
-
浏览量:3847次2020-09-20 21:19:24
-
浏览量:15216次2020-11-12 21:55:56
-
浏览量:5904次2020-09-23 23:07:37
-
浏览量:1879次2020-08-03 12:01:28
-
浏览量:34238次2021-03-03 17:25:19
-
浏览量:4937次2021-06-28 15:59:34
-
60篇
- 简单的dv/dt控制技术降低IGBT开通损耗
- 实力种草.GIF
- FPGA的设计艺术(30)FPGA硬件逻辑调试刍论
- Qorvo® 将 TP-Link® Wi-Fi 6 路由器性能提升至全新水平
- AMD发布新一代Radeon RX 6000系列游戏显卡 — 为AAA游戏带来领先4K性能
- 高速串行总线设计基础(七)揭秘SERDES高速面纱之时钟校正与通道绑定技术
- 单片机STM32L476ZET6 STM32L476ZE及STM32L476RCT6 资料
- FPGA零基础学习:数字通信中的电压标准
- 常见匹配网络的微带线实现(二):λ/4匹配网络的微带线设计
- FPGA逻辑设计回顾(5)多比特信号的CDC处理方式之MUX同步器
-
广告/SPAM
-
恶意灌水
-
违规内容
-
文不对题
-
重复发帖
李锐博恩
感谢您的打赏,如若您也想被打赏,可前往 发表专栏 哦~
举报类型
- 内容涉黄/赌/毒
- 内容侵权/抄袭
- 政治相关
- 涉嫌广告
- 侮辱谩骂
- 其他
详细说明