0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
会员中心
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

串行总线中的先进设计理念及SerDes/PMA介绍

OpenFPGA 来源:OpenFPGA 作者:碎碎思 2021-10-21 15:00 次阅读

串行总线技术(二)-串行总线中的先进设计理念及SerDes/PMA介绍字节分割/链路聚合下面以PCIe为例对字节分割加以讨论,如图所示。

PCIe使用链路和线路来发送串行数据。链路是一个逻辑实体,能够具有单个线路或多个线路。当逻辑链路包括一个线路时,TLP和DLLP通过单一的线路发送,每次发送一字节。

当链路包括多个线路时,TLP和DLLP分布在多个线路中,此时不是在不同的线路中发送不同的TLP而是所有的线路共同发送TLP在一个x4 PCIe链路(拥有4条线路)中,第一字节通过线路0、第二字节通过线路1、第三字节通过线路2、第四字节通过线路3、第五字节又回到线路0进行传输。这种传输机制被称为字节分割,字节分割在连续的线路上持续进行,直到最后一字节被发送。

正如我们所注意到的,可以通过使用更宽的链路来增加带宽。一个X4链路发送数据的带宽是xl链路的4倍。虽然线路是并行使用的,宽链路需要更多的引脚,其与并行总线结构也是有本质不同的。

宽链路中每个独立的线路仍然是以串行方式工作的。每个线路都有自己的差分传输信号线和独立的数据恢复电路,都具有串行传输所具有的优点。它们是独立的串行传输通道,通过使用字节分割机制合并起来作为一个逻辑实休使用。字节分割是MAC的功能。但是并不是所有的串行协议都使用字节分割,SATAUSB没有使用字节分割技术。

如果希望增加SATA硬盘的传输带宽,需要使用多个相互独立的SATA驱动器,使用不同的事务层包 (FIS ) 进行通信,如图所示。USB也是采用类似的机制,每个USB设备采用单线路连接。

通道绑定与去偏移前而我们讨论了字节分割技术,它将一个TLP分布到多个线路中进行传输。当接收电路从不同的线路收到这些分布传输的数据后,对其正确合路处理会遇到一些实际闲难,在电路板上,不同的传输路径会带来不同的传输延迟。

当接收电路收到来自不同线路的数据时,它们经过的延迟存在差异并且处于不同的时钟域。接收电路需要将不同线路上收到的数据进行级联,合并得到原始的TLP,此时所接收的数据之间已经失去了发送时相互之间的字节同步关系,需要使用通道绑定技术在接收端重新恢复不同线路之间的字节对准关系,如图所示。

d269e276-322c-11ec-82a8-dac502259ad0.png

在所有的线路上传输的数据流中有一种特殊的COMMA字符。在链路训练阶段,在所打线路上都会发送包含COMMA字符的用于训练的有序字符集合。与TLP和DLLP不同,训练字符集合不是以字节分割方式发送的。通道绑定逻辑在1个线路(例如,线路0)中査找COMMA,接着它在其他线路中定位COMMA字符并记录它们的相对位置。

一旦它锁定了COMMA字符出现的位置,它就停止搜索COMMA字符并记录下这些相对位置信息。通道绑定逻辑使用这些相对位置信息来对准存在偏移的接收数据字节流。通道绑定逻辑会始终保持基线路(线路0)字节位置不变。

对于其他线路,它会根据所检测到的COMMA的相对位置写入或读出数据,在此期间这些相对位置信息会保持不变。即使输入数据相对于通道绑定逻辑发生了延迟偏移,从通道绑定逻辑输出的数据仍然是对准的,TLP和DLLP能够被正确处理。

通道绑定也被称为去延迟偏移操作。通道绑定逻辑通常属于MAC层功能,只应用于包含多个线路、采用字节分割技术的链路中。

极性翻转串行数据比特通过TX+和TX-信号线发送。信号线在印制电路板(PCB)上布线时,TX+应该连接收端的RX+,TX-应该连接收端的RX-。但随着PCB板的层数不断增加,布线密度不断增大,走线距离可能较长,有时还可能要通过连接器,所以经常因为疏忽而发生TX+连接收端的RX-、TX-连接收端的RX+的情况。发生这种情况后,有时可以通过重新布线加以解决,但有时重新布线的代价会比较高。

在PCIe中,使用了一种机制来解决极性连接错误问题。在链路训练阶段,接收端查找常规的训练练字符集合或者反相的训练字符集合。如果发生了极性翻转,那么接收的串行比特会发生逐比特翻转(1变为0,0变为1)。

如果链路训练逻辑检测到了逐比特翻转的训练字符,那说明出现连线错误。发送电路无法获知是否发生了连接极性错误,接收电路检测到这一错误并通过逐比特取反在不进行硬件重新设计和PCB重新加工的情况下解决了这一问题,如图所示。

d2f59050-322c-11ec-82a8-dac502259ad0.png

线路翻转在多线路链路(例如,x8 PCIe有8条线路)中,数据包按照字节分割方式进行传输。所有的线路通过电路板连接到接收设备。正确的连接方式是TX线路0连接到RX线路0,TX线路1连接到RX线路1,以此类推。

在实际设计和布线时,可能会因为疏忽造成收发之间没有正确对应的情况。这些线路在多层PCB上布线时,会在不同层次之间穿过,会进行90°弯曲,这些都可能导致连接失误。在某些情况下,常规连接会导致布线闲难,此时也会有意识地希望能够进行错序连接。PCIe采用了一种名为线路切换的技术来解决这种无意或有意的板级错序连接。

如图所示,其基本思路是在链路训练过程中发现错序连接并进行数据重排。

d37916c8-322c-11ec-82a8-dac502259ad0.png

属于一个链路的多个线路被编号为0、1、2、3、4、5、6、7等。当信号线两端试图发现线路编号时(在训练字符集中的特定区域内写入了所属线路的编号),它们各自都有期望的编号值。线路0希望收到的训练字符集合中的编号为0,线路7希望收到的编号为7。

如果接收电路收到的编号与期望值不同,它会记录下来其实际连接的对端发送电路的编号。信号线两端的电路都可以根据实际连接的通道编号调整本端的实际编号,但需要注意的是,只能有一端可以进行调整,不能两端同时进行,否则会继续出错。

双方选择的用于解决错序问题的一端在发送数据之前先要切换发送数据的通路(例如,线路0的数据切换到线路7上,线路7的数据切换到线路0上)。同时它还要切换接收通路RX通路0上的数据与通路7连接,通路7与通路0连接,剩余的通路依次切换)。正如我们所能看到的,这里没有逻辑修改,通过内部的连接重定位解决了板级连接存在的问题。

锁相环 PLLPLL在数字系统中有很多应用,常见的典型重要应用如下:

数据时钟恢复(Clock Data Recovery,CDR)

去除时钟偏移

作为倍频器使用

CDR

在很多高速串行数据传输应用中,数据在传输过程中没有伴随着时钟的传输。然而,在数据流中存在着足够的数据跳变(0到1和1到0的跳变),接收端电路可以据此提取与数据同步的时钟。在接收端,可以使用参考时钟为时钟提取提供帮助。在没有参考时钟的情况下也可以提取接收时钟的。下面我们将针对这两种情况对PLL电路加以讨论。

不带参考时钟的CDR(见下图)

d40f56e2-322c-11ec-82a8-dac502259ad0.png

如果接收端接收的比特流速率为f,那么接收端的边沿检测器检测到的数据跳变频率为2f,VCO产生的自由震荡时钟频率为2f。

带参考时钟的CDR (见下图)

d4e362ca-322c-11ec-82a8-dac502259ad0.png

这种方式就不需要过多介绍,常见的传输方式。

使用PLL去除时钟偏移

在SoC中,时钟树被用于将时钟信号分配给物理上分布在芯片各个区域的触发器。在时钟树的通路上,分布着带有延迟的驱动器。由于时钟分布路径上存在延迟,叶节点上的时钟与根节点上的时钟相比,存在相移(相位滞后)。此时,可以使用PLL消除叶节点上时钟的相移使之和根节点上的时钟相位对准,如图所示。

d54a31b2-322c-11ec-82a8-dac502259ad0.png

PLL还可用于产生与输人时钟存在指定相移的输出时钟,例如,产生和输入时钟存在90°相移的输出时钟。

使用PLL实现倍频器

PLL可用于根据时钟源产生更高频率的时钟信号。将输岀时钟信号除以N作为PLL的反馈信号与时钟源相比较,可以得到N倍于时钟源的输出时钟信号,同时二者具有相同的相位。

d5cc6d8a-322c-11ec-82a8-dac502259ad0.png

串行总线的PMA层功能PMA层主要实现模拟电路功能。PMA层电路也被称为SerDes(Serializer & Deserializer),是一个非常特殊的电路。我们的目标是从电路的系统设计层面对其加以介绍,以便对串行总线技术形成完整的理解。

发送均衡

采用串行传输机制时,数据以比特流的方式在差分对(TX+ TX-)上传输。在线路上传输的数据波形可以看成是大量不同频率、不同幅度的正弦波叠加作用的结果。

当数据速率很高时,存在一个占主导地位的高频正弦波分量。在高速传输时,差分传输线路的通路特性与低通滤波器(RC滤波器)接近,但相对于低频成分,高频成分的衰减更大一些。这意味着在接收端,接收信号中的不同的频率成分所占的比例与发送时不同。接收到的信号与发送端信号相比会发生畸变,造成ISI(码间串扰),这会使得CDR恢复的数据中存在误码。

什么是码间串扰?

如果我们发送一个阶跃函数波形(在一个时钟周期内为1的脉冲信号),在接收端波形会发生变化。接收脉冲会展宽并进入相邻时钟周期中。从第N个时钟周期展宽到第N+1个时钟周期的信号与第N+1个时钟周期的信号波形叠加,使得第N+1个周期内的波形发生畸变,这种畸变可能会造成对该时钟周期逻辑值的判决发生错误,这被称为符号间的串扰,即码间串扰(IS1)。

前有很多种技术可以解决传输线频率响应的问题。可以通过采用发送端均衡技术,或采用接收端均衡技术加以解决。

发送端预加重技术

发送驱动时,对高频成分的增益大于低频成分,频率越高增益越大。信号到达接收端时,所有的频率成分得到的总体增益相同。

发送端后加重技术

另一种技术是后加重技术。采用后加重技术时,边沿翻转(0到1或1到0)之后的比特被正常放大,但此后的其他比特(没有边沿翻转的比特)增益相对降低。由于信号的高频成分主要出现在信号翻转部分,这样做等效于为高频成分提供了更大的增益。当数据到达接收端时,所有比特位的最终等效增益是相同的。PCIe和SATA都使用了后加重传输技术。

接收均衡

在接收端,可以为高频成分提供相对于低频成分更大的增益。针对高频成分给予补偿的结果是整个传输系统为所有频率成分提供了相同的增益。经过补偿后,接收波形与发送波形更加相似。接收器均衡技术有利于减少1SI。

端接电阻

TX+和TX-信号是一对传输线,在发送端和接收端需要进行传输线阻抗匹配,以避免产生信号反射,使发送信号产生畸变。当信号发生反射时,它与原始的发送信号发生叠加,使发送信号增强或减弱。如果反射的信号强度较大,可能会使发送信号产生较大的畸变从而导致接收错误。终端匹配的目的就是减少或消除接收端对发送信号的反射。

编辑:jq

声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • 电阻
    +关注

    关注

    86

    文章

    5521

    浏览量

    172132
  • pcb
    pcb
    +关注

    关注

    4319

    文章

    23108

    浏览量

    398197
  • 串行数据
    +关注

    关注

    0

    文章

    52

    浏览量

    16547
  • cdr
    cdr
    +关注

    关注

    1

    文章

    50

    浏览量

    18113

原文标题:串行总线技术(二)-串行总线中的先进设计理念及SerDes/PMA介绍

文章出处:【微信号:Open_FPGA,微信公众号:OpenFPGA】欢迎添加关注!文章转载请注明出处。

收藏 人收藏

    评论

    相关推荐

    MultiGABSE-AU物理层PMA子层及PMD子层的相关机制

    在之前的文章,我们介绍了IEEE 802.3cz[1]协议,MultiGABSE-AU物理层XMII、PCS子层以及两个可选功能的相关内容,本篇将介绍MultiGABSE-AU物理
    的头像 发表于 12-23 10:20 158次阅读
    MultiGABSE-AU物理层<b class='flag-5'>PMA</b>子层及PMD子层的相关机制

    CAN总线通信原理介绍 CAN总线模块选择指南

    于工业自动化、医疗设备、船舶系统等领域。 CAN总线通信原理介绍 1. CAN总线概述 CAN总线是一种多主控制的串行通信协议,它允许多个设
    的头像 发表于 11-21 10:21 604次阅读

    谐波的概念及应用

    本文简单介绍了谐波的概念及应用。
    的头像 发表于 10-18 14:14 488次阅读
    谐波的概<b class='flag-5'>念及</b>应用

    工业系统LVDS SerDes的设计与应用

    电子发烧友网站提供《工业系统LVDS SerDes的设计与应用.pdf》资料免费下载
    发表于 09-26 09:12 0次下载
    工业系统<b class='flag-5'>中</b>LVDS <b class='flag-5'>SerDes</b>的设计与应用

    国产车载SerDes百花齐放,12G以上已是“基本操作”

    。   SerDes是Serializer/Deserializer 的缩写,即串行器和解串器。SerDes芯片在发送端将多路低速并行的信号转换成一路的高速串行信号,在接收端将高速
    的头像 发表于 09-10 00:19 9654次阅读
    国产车载<b class='flag-5'>SerDes</b>百花齐放,12G以上已是“基本操作”

    电脑通用串行总线控制器感叹号怎么办

    控制器感叹号时,通常表示USB控制器存在问题,可能是驱动程序问题、硬件故障或其他原因导致的。本文将介绍如何解决电脑通用串行总线控制器感叹号的问题。 检查USB设备 首先,我们需要检查连接到电脑的USB设备是否存在问题。尝试断开所有USB设备,然后重新启动电脑,查看通用
    的头像 发表于 08-29 15:53 3841次阅读

    通用串行总线控制器和通用串行总线设备的区别

    ,主要有两种类型的设备:通用串行总线控制器(Universal Serial Bus Controller)和通用串行总线设备(Universal Serial Bus D
    的头像 发表于 08-29 15:40 1979次阅读

    USB是通用串行总线

    USB是通用串行总线 USB是通用串行总线,USB协议版本包括 USB1.0、USB1.1、USB2.0、USB3.0、USB3.1、USB3.2,最新的是USB4.0协议,可直连CPU的PCIe
    的头像 发表于 08-21 10:52 309次阅读

    ASP4644在FPGA SERDES供电的应用

    ASP4644典型设计,纹波在4.17-10.67mV完全能满足供电要求。 ASP4644在FPGA SERDES供电的应用优势 低纹波输出: 优化的高频率、高带宽设计,使用单个低ESR陶瓷输出电容即可
    发表于 08-16 14:55

    聚焦MIPI 系列之二:汽车 SerDes 发射机测试

    ⊙ 测试、调试和表征 高速串行器与解串器 (SerDes) 支持传输数据流,使得车载视频、音频和通信成为可能。SerDes 串行链路的大带宽、高可靠性和高性能是汽车应用的关键要求,有助
    的头像 发表于 07-22 15:42 529次阅读
    聚焦MIPI 系列之二:汽车 <b class='flag-5'>SerDes</b> 发射机测试

    高速串行总线有哪些

    在信息技术的飞速发展总线技术作为连接各种电子设备的重要纽带,其性能和可靠性对于整个系统的运行效率具有决定性的影响。高速串行总线技术,以其高速度、低延迟、低干扰等优势,成为现代电子系
    的头像 发表于 05-16 17:02 1480次阅读

    汽车以太网发明人押宝SerDes!一文详解车载SerDes技术

    SerDes,即Serializer(串行器)和Deserializer(解串器)的简称,是一种高速串行数据传输技术。
    的头像 发表于 03-12 14:05 2237次阅读
    汽车以太网发明人押宝<b class='flag-5'>SerDes</b>!一文详解车载<b class='flag-5'>SerDes</b>技术

    汽车芯片市场集中度最高的领域:SerDes介绍

    SerDes串行与解串行,汽车领域每一颗摄像头至少需要一片串行器,至少需要0.25片解串行
    的头像 发表于 01-22 14:42 4148次阅读
    汽车芯片市场集中度最高的领域:<b class='flag-5'>SerDes</b><b class='flag-5'>介绍</b>

    SERDES的作用 SerDes基础知识详解

    SERDES是英文SERializer(串行器)/DESerializer(解串器)的简称。
    的头像 发表于 01-04 09:04 4344次阅读
    <b class='flag-5'>SERDES</b>的作用 <b class='flag-5'>SerDes</b>基础知识详解