25GBASE-CR(S) (C110)
概述
本条款规定了25GBASE-CR PMD、25GBASE-CR-S PMD和基带介质。这些规范与100GBASE-CR4(第92条)的规范密切相关,但采用单通道而不是4通道。有3个相关附件。附件110A提供了在已实现的系统中可能无法测试的测试点的参数信息,附件110B规定了测试夹具,附件110C描述了25GBASE-CR和25GBASE-CR-S主机和电缆组件的形状系数cable assembly form factors。
在形成完整的物理层时,PMD关联下表中所示的相应PMA,通过MDI连接到介质,并连接到可通过第45条中定义的管理接口或同等方式访问的管理功能。
下图显示了PMD和MDI(阴影显示)与ISO/IEC开放系统互连(OSI)参考模型的其他子层的关系。25GBASE-CR 使用RS(528, 514) FEC,25GBASE-CR-S 使用BASE-R(2112, 2080) FEC。
25GBASE-CR PHY通过CA-25G-N、CA-25G-S和CA-25G-L型电缆组件运行(见110.10)。25GBASE-CR-S PHY在CA-25G-N和CA-25G-S型电缆组件上运行。表110-2总结了每种PHY类型支持的电缆组件类型。
当形成完整的25GBASE-CR或25GBASE-CR-S物理层时,根据以下准则,链路BER要求取决于FEC模式:
a) 如果PHY在RS-FEC模式下运行,并且RS-FEC解码器没有绕过纠错,则链路需要以10-5或更高的BER运行。
b) 如果PHY在BASE-R FEC模式下运行,则链路需要以10-8或更高的BER运行。
c) 如果PHY在无FEC模式或绕过纠错的RS-FEC模式下运行,则链路需要以10-12或更高的BER运行。
在这种情况下,链路由兼容的PMD发射机、兼容的PMD接收机和兼容的电缆组件组成。
对于一个完整的物理层,对于线速64字节的帧,帧丢失率小于6.2×10–10,则认为满足此规范。
具有可选节能以太网(EEE)功能的25GBASE-CR和25GBASE-CR-S PHY可以可选地进入低功耗空闲(LPI)模式,以在低链路利用率期间节约能源。
25GBASE-CR硬件上必须实现BASE-R FEC和RS-FEC,25GBASE-CR-S硬件必须实现BASE-R FEC。
RS && 25GMII(C106)
本条款定义了以太网媒体访问控制器MAC和各种PHY之间的调协子层(RS)和25千兆媒体独立接口(25GMII)的逻辑和电气特性。下图显示了RS和25GMII与ISO/IEC(IEEE)OSI参考模型的关系。
25GMII是MAC子层和物理层设备之间的可选逻辑接口。RS使MAC侧的位串行协议转换成并行协议的PCS侧服务接口。
25GMII接口特点
a) 它能够支持25 Gb/s的操作。
b) 数据和分隔符Delimiters与时钟参考同步。
c) 它提供独立的32位宽的发送和接收数据路径。
d) 它仅提供全双工操作。
25GMII概念
a) 25GMII在功能上类似于为其他速度定义的其他媒体无关接口,因为它们都定义了1个允许独立开发MAC和PHY逻辑的接口。
b) RS在MAC串行数据流和25GMII的并行数据路径之间进行转换。
c) RS将25GMII处提供的信号集映射到MAC处提供的PLS服务原语。
d) 数据发送的每个方向都是独立的,由数据、控制和时钟信号提供服务。
e) RS在发送路径上生成连续的数据或控制字符,并在接收路径上期望连续的数据和控制字符。
f) RS通过监测接收路径上指示不可靠链路的状态报告,并在发送路径上生成状态报告,向连接链路远端的DTE报告检测到的链路故障,从而参与链路故障检测和报告。
g) 25GMII可以支持节能以太网(EEE)的PHY类型的低功耗空闲(LPI)信令。
25GMII结构
RS层将MAC层的串行数据和25GMII接口的并行数据实现互相转换的功能;
25GMII只支持全双工操作,故PLS_SIGNAL.indication原语永远不会产生。
25GMII若支持EEE或Link Interruption(特殊的序列有序集用于标识链路短暂中断),PLS_CARRIER.indication原语才会产生。
25GMII:32个数据信号(TXD<31:0> and RXD<31:0>), 4个控制信号(TXC<3:0> and RXC<3:0>), and 1个时钟信号(TX_CLK and RX_CLK)。当工作于25Gbps,时钟频率为390.625MHz(100ppm),上升沿和下降沿采样,390.625M Clk/(s×边沿) × 2边沿 × 32bit/Clk=25Gbps;
32个TXD和4个TXC信号应被组织成4个数据通道Lane,32个RXD和4个RXC信号也应如此。每个方向上的4个通道Lane共享一个公共时钟--TX_CLK用于发送,RX_CLK用于接收。这4个通道以循环序列的方式用于发送字节流。
在发送时,每8个PLS_DATA.request事务表示MAC发送的一个字节。第一个字节与通道0对齐,第二个与通道1对齐,第三个与通道2对齐,第四个与通道3对齐,然后与第五个对齐,以此类推。分隔定界符Delimiters和帧间空闲字符IPG分别用TXC和RXC宣称指示的控制码编码在TXD和RXD信号上。
25GMII发送接收Lane分配
25GMII与PLS服务原语映射
调协子层(RS)应将25GMII提供的信号映射到PLS服务原语。全双工操作仅在25 Gb/s;因此支持CSMA/CD操作的PLS服务原语没有通过RS映射到25GMII。如果支持EEE能力,则映射会发生变化(见78.3)。LPI_REQUEST不得设置为ASSERT,除非所连接的链路已运行至少1秒钟(即,根据底层PCS/PMA,link_status=OK)。
为25 Gb/s操作定义了以下原语的映射:
PLS_DATA.request
PLS_DATA.indication
PLS_CARRIER.indication
PLS_SIGNAL.indication
PLS_DATA_VALID.indication
PLS_DATA.request ( OUTPUT_UNIT = 0/1/DATA_COMPLETE )
DATA_COMPLETE值表示媒体访问控制子层MAC没有更多数据要输出。OUTPUT_UNIT值通过每个TX_CLK边沿上(上升沿和下降沿)的信号TXD<31:0>和TXC<3:0>传送到PHY。每个PLS_DATA .request事务应按顺序映射到TXD信号(TXD<0>,TXD<1>,…TXD<31>,TXD<0>,…)。在来自MAC子层的32个PLS_DATA .request事务(4个字节,每个字节有8个PLS_DATA.request事务)之后,RS请求PHY发送32个数据比特。前导码的第一个字节应转换为Start控制字符,并与Lane 0对齐。对于MAC子层的每32比特时间,RS应生成TXD<31:0>和TXC<3:0>。DATA_COMPLETE值应映射到在最后一个数据字节之后按顺序编码在接下来的8个TXD位信号上的Terminate控制字符;并在下一个TX_CLK边沿发送到PHY。这可能与最后一个数据字节或随后的TX_CLK边沿位于同一TX_CLK边上。当Terminate控制字符位于Lane 0、1或2中时,顺序后面的通道Lane将使用Idle控制字符进行编码。
PLS_DATA.indication ( INPUT_UNIT = 0/1)
INPUT_UNIT值来自RX_CLK每个边沿上(上升沿和下降沿)从PHY接收到的信号RXC<3:0>和RXD<31:0>。为MAC子层实体生成的每个原语对应于MAC在连接两个DTE的链路的远程端发出的PLS_DATA.request。对于帧接收期间的每个RXD<31:0>,RS应生成32个PLS_DATA.indication事务,直到帧结束(终止控制字符),其中0、8、16或24个PLS_DATA.indication事务将由包含Terminate的RXD<31:0>生成。在帧接收期间,每个RXD信号应按顺序映射到PLS_DATA.indication事务中(RXD<0>,RXD<1>,…RXD<31>,RXD<0>,…)。在生成相关的PLS_DATA.indication事务之前,RS应将有效的Start控制字符转换为前导码第一个字节。RS不得为终止控制字符生成任何PLS_DATA.indication原语。为了确保稳健运行,发送到MAC的数据值可以是根据XGMII错误指示的要求,由RS执行更改动作。序列有序集不会指示给MAC。
PLS_CARRIER.indication ( CARRIER_STATUS = CARRIER_ON / CARRIER_OFF )
25 Gb/s操作仅支持全双工操作。RS从只为支持EEE或链路中断的PHY生成此原语。对于支持EEE功能的PHY,设置CARRIER_STATUS以响应LPI_REQUEST。对于支持链路中断的PHY,可以设置CARRIER_STATUS以响应Link_fault。如果LPI_CARRIER_STATUS = true ; link_fault = 链路中断link interruption,则CARRIER_STATUS设置为CARRIER_ON。否则,CARRIER_STATUS设置为CARRIER_OFF。基于链路中断Link Interruption信号的延迟机制可以由管理启用或禁用。
PLS_SIGNAL.indication ( SIGNAL_STATUS = SIGNAL _ERROR / NO _SIGNAL _ERROR )
25 Gb/s操作仅支持全双工操作。RS永远不会生成这个原语。
PLS_DATA.VALID ( DATA_VALID_STATUS = DATA_VALID / DATA_NOT_VALID )
DATA_VALID_STATUS参数可以取两个值之一:DATA_VALID或DATA_NOT_VALID。DATA_VALID值表示PLS_DATA.indication原语的INPUT_UNIT参数包含传入帧的有效数据。DATA_NOT_VALID值表示PLS_DATA.indication原语的INPUT_UNIT参数不包含传入帧的有效数据。每当DATA_VALID_STATUS参数从DATA_VALID变为DATA_NOT_VALID或反之亦然,RS应生成PLS_DATA_VALID.indication服务原语。如果先前的RXC<3:0>和RXD<31:0>包含4个空闲字符IDLE (RXD=0x07070707)或1个序列有序集(4Byte),则然后在Lane 0上接收到开始控制字符Start control character (RXD=0xFB)后而响应生成PLS_DATA.indication事务时,DATA_VALID_STATUS应取DATA_VALID值。当序列中当前通道的RXC=1用于除错误控制字符(RXD=0xFE)以外的任何字符时,DATA_VALID_STATUS应取DATA_NOT_VALID值。在没有错误的情况下,DATA_NOT_VALID是由Terminate控制字符(RXD=0xFD)引起的。当DATA_VALID_STATUS因Terminate以外的控制字符而从DATA_VALID更改为DATA_NOT_VALID时,RS应确保MAC(在RS向MAC发送DATA_NOT_VALUED服务原语之前)检测到FrameCheckError。
25GMII数据流
Inter-frame
25GMII发送或接收路径上的帧间<帧间>时段是一个没有帧数据活动发生的间隔。对应于MAC包间间隙的<帧间>以Terminate控制字符开始,以Idle控制字符继续,以开始控制字符之前的Idle控制字符结束。IPG的长度可以变化(在发送MAC和接收MAC之间实现一个或多个功能)(例如,RS Lane对齐、PHY时钟速率补偿)。接收RS的25GMII处的最小IPG为5个字节。链路状态信息的信令在逻辑上发生在IPG时段。
Preamble与SFD
Start控制字符表示25GMII上MAC数据的开始。在发送时,RS将从MAC传送的前导码的第一个数据字节转换为Start控制字符。在接收时,RS将开始控制字符转换为前导码数据字节。RS在发送时和PHY在接收时将启动控制字符与25GMII的通道0对齐。
第一个Preamble替换成“Start型” 25GMII Control Code(0xFB)[只能出现在Lane0]
开始控制字符Start control character (0xFB)对齐。在发送时,RS可能需要修改IPG的长度,以便在Lane 0上对齐Start控制字符(前导码的第一个字节)。这应通过以下两种方式之一实现:
1) MAC实现可以将此RS功能合并到其设计中,并始终插入额外的空闲字符IDLEs,以在4字节边界上对齐Start控制字符。请注意,这将降低以最小IPG分隔的某些数据包大小的有效数据速率。(此法不可行)
2) 或者,RS可以通过有时插入和有时删除空闲字符来IDLEs对齐Start控制字符(保证所有帧的Start控制符永远出现在Lane0),从而保持有效数据速率。使用此方法时,RS会维护一个赤字空闲计数(DIC),表示删除或插入的空闲字符的累积计数。DIC为每个删除的空闲字符递增,为每个插入的空闲字符递减,是否插入或删除空闲字符的决定受到DIC最小值为0、最大值为3的限制。请注意,这可能会导致在发送25GMII上观察到的帧间间隔比规定的最小IPG(12Byte)短3个字节;然而,缩短IPG的频率受到DIC规则的限制。DIC仅在初始化时重置,并且无论MAC子层发送的IPG大小如何,都会应用DIC。如果效果与RS实现的DIC相同,则可以采用等效技术来控制Start控制字符的RS对齐。
帧结尾标记EFD
EFD采用“Terminate型” 25GMII Control Code(0xFD)[可以出现在任意Lane]
普通数据帧发送
S=0xFB (TXC=1), DP=0x55 (TXC=0) , DP=0x55 (TXC=0) , DP=0x55 (TXC=0) , DP=0x55 (TXC=0) , DP=0x55 (TXC=0) , DP=0x55 (TXC=0) , SFD=0xD5 (TXC=0) , MAC帧数据…………+FCS,T=0xFD (TXC=1),I=0x07 (TXC=1),……
TXD, TXC编码
普通数据帧接收
S=0xFB (RXC=1), DP=0x55 (RXC=0) , DP=0x55 (RXC=0) , DP=0x55 (RXC=0), DP=0x55 (RXC=0) , DP=0x55 (RXC=0) , DP=0x55 (RXC=0), SFD=0xD5 (RXC=0), MAC帧数据…………+FCS,T=0xFD (RXC=1) ,I=0x07 (RXC=1),……
RXD, RXC编码
错误与故障处理
25GMII响应错误指示
如果在帧接收期间(即当PLS_DATA.VALID 的DATA_VALID_STATUS = DATA_VALID时),在接收到的通道Lane上用信号发送了终止控制字符以外的控制字符,则RS应确保MAC将检测到该帧中的帧校验错误。通过在RS中加入一个功能可以满足这一要求。该功能产生被传递到MAC子层的接收帧数据序列。该数据序列可以通过替换传递到MAC的数据来产生。当Terminate之外的控制字符出现在包的结尾时,RS为帧内接收到的每个错误控制字符生成8个PLS_DATA.indication原语,并可能生成8个PLS_DATA.indication原语确保帧检测错误标记的产生。可以采用其他技术来响应接收到的错误控制字符,前提是MAC子层的行为就像在接收到的帧中发生了帧校验错误一样。
生成发送错误控制字符的条件
如果在发送帧的过程中,有必要请求PHY故意破坏帧的内容,使得接收端将以最高的概率检测到损坏,则可以通过对通道的TXD和TXC信号进行适当的编码(0xFE error控制符),在发送通道上宣称错误控制字符。
对接收到的无效帧序列的响应
需要与此RS相邻的25 Gb/s PCS来保持发送RS的列对齐,或将Start控制字符与通道0对齐。对于在任何其他通道上接收到的Start控制字符,RS不得向MAC指示DATA_VALID。无差错的25 Gb/s操作不会改变通道3中的SFD对齐。不需要25 Gb/s MAC/RS实现来处理在包含Start控制字符的列之后的列的通道3以外的位置具有SFD的数据包。
链路故障信令
链路故障信令在远程RS和本地RS之间运行。在远程RS与本地RS之间检测到的故障被本地RS作为本地故障接收。只有RS发出远程故障信号。PHY内的子层能够检测到导致链路通信不可靠的故障。
在识别到故障状况后,PHY子层指示数据路径上的本地故障状态。当此本地故障状态到达RS时,RS停止发送MAC数据或LPI,并在发送数据路径上连续生成远程故障状态(可能截断正在发送的MAC帧)。当RS接收到远程故障或链路中断状态时,RS停止发送MAC数据或LPI,并连续生成空闲控制字符。当RS不再收到故障状态消息时,它将恢复正常运行,发送MAC数据或LPI。
链路故障指令通过64B/66B序列有序集的方式实现(非常重要)。
PHY用通道0中的序列控制字符Q和通道1和2中的0x00数据字符以及通道3中的0x01数据字符表示本地故障。在通道0中具有序列控制字符,在通道1和2中具有数据字符0x00,在通道3中具有数据字符0x02表示远程故障。虽然大多数故障检测是在PHY的接收数据路径上进行的,但在某些特定的子层中,可以在PHY的发送侧检测到故障。PHY的本地故障状态也表明了这一点。
对于可能暂时中断的链路的操作,提供了对第3种故障情况(链路中断)的可选检测。
RS报告链路的故障状态。本地故障表示在远程RS和本地RS之间的接收数据路径上检测到的故障。远程故障表示本地RS和远程RS之间的发送路径上的故障。