1 Training Sequence
Training Sequence是由Order Set(OS) 组成,它们主要是用于bit aligment,symbol aligment,交换物理层的参数。当data_rate = 2.5GT or 5GT 它们不会被扰码(scramble),当date_rate = 8GT or higher 根据特殊的规则决定是否对Order Set 进行扰码。
LTSSM中使用最多的训练序列为TS1 TS2,它们一般都是连续进行发送,只可以被SKP**以及 **EIOS(2.5GT除外,因为其不支持低功耗模式)打断。协议中对于“连续”的描述是:
- 对于使用8b/10b 的TS1 or TS2,symbol 6与前一个symbol 6是一致;
- 对于使用128/130b编码的TS1 or TS2, symbol 6~9与前几个symbol 6 -9是相同的,对于symbol 中Reserved field 需要按照如下的规则处理。发送时Reserved 字段全部填充为0,对于接收机必须对reserved bit进行奇偶性计算(parity computation)(如果reserved bit 进行了奇偶性计算), 如果明确指出相邻的symbol中所有的Reserved bit必须保持相同,则may 需要直接比较前后symbol中的reserved bit。
- 此外对于**128b/130b**的编解码每条lane能偶独立跟踪各自的DC Balance (dc balance指的是1 和 0 之间的差距),最大的differenct 为511,达到最大值之后会保持在511。
在两种情况下Dc Balance differentce会被 set to 0:
- 发送机进入电气空闲状态[electrical idle]
- 发送机在发送EIEOS退出电气空闲后发送了Data BLock。
每发送8个TS1 or TS2 OS,发送机必须评估running DC Balance并设置TS 中的DC Balance Symbol ,设置的算法如下:如果需要降低对方发送 “1“ ,需要set 20h for symbol14 and 08h for symbol 15;如果需要降低发送”0“, 需要set DFh for symbol 14 and F7h symbol 15。
- runing dc balance > 31 DC Balance (symbol 14 and symbol 15) are not scrambld.
- runing dc balance > 15 symbol 14 TS1 Identifier Symbol is scarmbled , DC Balance ( symbol 15) are not scrambld.
- else symbol 14and 15 TS1 Identifier Symbol is scarmbled .
note 任何DC Balance symbol(symbol 14、15) 禁止进行扰码。
2 Electrical Idle
在发送机进入电气空闲(Electrical Idle) 之前,它必须发送Electrical Idle Order Set Sequence(EISOQ)。EIOSQ 是1个EIOS symbol in data_rate 2.5T 8GT 16GT, 2个EIOS symbol in data_rate 5GT。在8b/10b编码下EIOS = K28.5(COM)+ 3个K28.3(IDL) Symbol,发送时需要发送所有的4个symbol,在接受时只要收到 COM+2个IDL便认为识别到了一个EIOS Symbol。在128b/130b编码条件下EIOS 是一个order set block,正常发送时需要发送完整的symbol(但是如果在它发送接收进入电气空闲状态,个人理解它指的是最有一个EIOS,此时可以只发送EIOS 中的symbol 0-14),接收时如果一个OS block 的symbol 0-3 符合EIOS的定义则认为收到了一个EIOS 序列。
在发送Electrical IDLE OS 最后一个symbol ,发送机必须处于电气空闲状态。
当使用8b/10b编码时并且data_rate = 5GT ,EIEOS还可以被用作如下场景中:
- 在进入Configuration.Linkwidht.start的第一个TS1 OS之前;
- 在进入Recovery.Lock的第一个TS1 OS之前;
- 每隔32个TS1 or TS2 OS 需要发送一个EIOS(Configuration.Linkwidht.start Recovery.Lock Recovery.RcvrCfg );
当使用128b/130b编码时EIEOS也可以被用作Block Alignment,也可以用作在如下场景中:
- 在进入Configuration.Linkwidht.start的第一个TS1 OS之前;
- 在进入Recovery.Lock的第一个TS1 OS之前;
- 在Data Stream 发送结束时候,如果不发送EIOS 也不进入Recovery.RcvrLock 则需要在EDS Frame Token 之后发送一个EIEOS;
- 每隔32个TS1 or TS2 OS 需要发送一个EIOS ;
- 如果Reset EIEOS Interval Count Bit =1 则避免将TS打断,则在Recovery.Equalizatoin 状态需要每隔65536个 TS1 OS 发送后需要发送一个EIOS ;
- 它是FTS OS, Compliance Pattern,or Modified Compliance pattern中需要使用。
3 Fast Training Sequence
FTS用于从L0s(低功耗) 退出至L0时用于bit and symbol锁定的序列,它被Receiver用于检查测是否退出电气空闲状态,并对齐Receiver ‘s bit and symbol 电路应应对后续到来的数据。
当速度是2.5GT or 5 GT时:FTS = K28.5 + 3个K28.1,N_FTS(number of FTSs)是组件可以请求对端设备需要发送FTSs 的最大数量(max is 255)。 如果data_rate = 5GT, 在发送第一个FTS之前,会先发送4个EIE symbol (主要是帮助Receiver 检测到 退出电气空闲),规范允许至多发送8个EIE symbol (帮助恢复发送机pin上的电压可以在允许的时间内达到一个可接收的水平 )。如果Extended Sync Bit = 1 则需要发送4096个FTS,提供给link 监控工具足够的时间实现完成bit frame 同步。 SKP必须FTSs之间发送,但是在第一个N_FTS FTSs 不可以发送中间不可以发送FTS,主要是为了维持两端设备间的clk 频偏,在最后一个FTS后需要发送一个SKP OS。
Note:协议规范也允许最后发送2个SKP OS,一个用于指示FTS已经发送完成,另一个用于补偿频偏。
当速度是8GT or higher时:N_FTS(number of FTSs)是组件可以请求对端设备需要发送FTSs 的最大数量(max is 255)。第一个FTS 是130 bit的unscrambled 的Order Set Block,在退出至L0s,发送机需要发送first 1个EIEOS帮助Receiver 识别到退出电气空闲,随后发送N_FTS个FTSs (如果Extended Sync Bit = 1,N_FTS=4096),FTS目的主要是为了完成bit or symbol锁定。规范要求每隔32个FTS则需要发送一个EIEOS,当lastFTS 发送结束后需要发送 1个EIEOS帮助receiver 完成block alignment。当最后一个EIEOS发送结束后,需要发送一个SDS OS,它是用于帮助接收机完成去偏移和指示link partner 跳转到Data stream,SDS OS之后必须发送Data Block。
Note:协议允许在最后一个FTS后发送2个EIEOS,前提是N_FTS是32的整数倍。
需要注意的是N_FTS字段的值可以通过Recovery 阶段更新new value,但同时也可以通过上层软件通过Common Clock Configuration bit进行修改。