前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
社区首页 >专栏 >铜缆以太网9-25GBASE-CR(S)(一)

铜缆以太网9-25GBASE-CR(S)(一)

作者头像
追宇星空
发布2025-03-11 21:16:47
发布2025-03-11 21:16:47
720
举报
文章被收录于专栏:追宇星空追宇星空

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之间的发送路径上的故障。

本文参与 腾讯云自媒体同步曝光计划,分享自微信公众号。
原始发表:2025-03-10,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 追宇星空 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档