GT收发器64B66B设计(1)IP核配置和example design

2024-04-04 01:52

本文主要是介绍GT收发器64B66B设计(1)IP核配置和example design,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

文章目录

  • 前言
  • 一、IP核配置
    • 1.1、编码方式
    • 1.2、字节对齐和逗号码
  • 二、example design

前言

在前面我们基于GT收发器进行了PHY层设计,其中采用的编码方式为8B10B,为进一步提高传输效率,从本文开始,将采用基于GT高速收发器采用64B66B编码方式进行设计。

一、IP核配置

1.1、编码方式

在这里插入图片描述
前面的配置与8B10B一致,可以看前面的文章介绍。
第三页有所不同:
数据位宽我们选择64bit,当然32bit也可以。TX端在进行编码选择的时候,64B66B有俩种方式,分别为:
Ext Seq Ctr:数据流经过64B/66B的齿轮箱和混淆器。这里提到了外部序列计数器(External Sequence Counter),这可能是指序列计数器是在设计中实现的,而不是在收发器内部。
Int Seq Ctr:这里提到了GTX收发器,数据流同样经过64B/66B的齿轮箱和混淆器,但序列计数器是在收发器内部实现的。

这里需要先了解Gearbox,也就是齿轮箱是干嘛的,对于64B66B编码而言,数据输入是54bit,输出是2bit,所以这之间存在着2bit的带宽差,Gearbox 就是用来解决这种差异的,实现方式是:将66bit数据拿出来2bit先存入Gearbox,然后输出64bit,当发送32次后,用户这边暂停发送一帧,让Gearbox当中的64bit数据发送,这样就将输入输出带宽差异消除。而这里的计数器就是用来计数发了多少次数据了的。这个计数器可以是在GT内部实现,也可以在用户逻辑里实现,GTH以后就没有内部计数器了,为了减小电路复杂度,这里为了通用我们也选择外部计数器。

文档描述部分:
在这里插入图片描述

1.2、字节对齐和逗号码

在64B66B编码当中,我们需要自己去进行字节对齐,所以这里的都没办法选择。
在这里插入图片描述

二、example design

在这里插入图片描述
在示例工程里我们可以看到比8B10B工程多了三模块,分别是:块同步模块,该模块就是实现字节对齐的功能;和64B66B编码相关的加扰模块以及解扰模块。

这些模块可以直接被我们拿来使用,
我们重点关注块锁定模块:
参考xilinx文章ug476
在这里插入图片描述
状态机通过跟踪有效和无效的同步头来工作。在复位时,块锁定被取消,状态为LOCK_INIT。下一个状态是RESET_CNT,其中所有计数器都被归零。同步头在TEST_SH状态中进行分析。如果头部有效,则在VALID_SH状态中递增sh_cnt,否则在INVALID_SH状态中递增sh_count和sh_invalid_count。对于图中显示的块同步状态机,sh_cnt_max和sh_invalid_cnt_max都是常量,分别设置为64和16。从VALID_SH状态开始,如果sh_cnt小于sh_cnt_max且test_sh为高电平,则下一个状态是TEST_SH。如果sh_cnt等于sh_cnt_max且sh_invalid_cnt等于0,则下一个状态是GOOD_64,并且从那里开始断言block_lock。然后进程再次重复,并将计数器清零。为了实现块锁定,状态机必须连续接收sh_cnt_max个有效同步头,而不会收到无效同步头。但是,当块锁定达到sh_invalid_cnt_max-1时,可以在sh_cnt_max个有效同步头内接收到无效同步头。因此,一旦锁定,要破坏锁定就更加困难。
下图显示了由于在实现数据对齐之前多次收到无效同步头而导致的块同步状态机多次断言RXGEARBOXSLIP的波形。发出RXGEARBOXSLIP后,状态机在检查有效同步头之前等待32个RXUSRCLK2周期。
在这里插入图片描述

这篇关于GT收发器64B66B设计(1)IP核配置和example design的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/874518

相关文章

龙蜥操作系统Anolis OS-23.x安装配置图解教程(保姆级)

《龙蜥操作系统AnolisOS-23.x安装配置图解教程(保姆级)》:本文主要介绍了安装和配置AnolisOS23.2系统,包括分区、软件选择、设置root密码、网络配置、主机名设置和禁用SELinux的步骤,详细内容请阅读本文,希望能对你有所帮助... ‌AnolisOS‌是由阿里云推出的开源操作系统,旨

mysql-8.0.30压缩包版安装和配置MySQL环境过程

《mysql-8.0.30压缩包版安装和配置MySQL环境过程》该文章介绍了如何在Windows系统中下载、安装和配置MySQL数据库,包括下载地址、解压文件、创建和配置my.ini文件、设置环境变量... 目录压缩包安装配置下载配置环境变量下载和初始化总结压缩包安装配置下载下载地址:https://d

Python中的可视化设计与UI界面实现

《Python中的可视化设计与UI界面实现》本文介绍了如何使用Python创建用户界面(UI),包括使用Tkinter、PyQt、Kivy等库进行基本窗口、动态图表和动画效果的实现,通过示例代码,展示... 目录从像素到界面:python带你玩转UI设计示例:使用Tkinter创建一个简单的窗口绘图魔法:用

shell脚本快速检查192.168.1网段ip是否在用的方法

《shell脚本快速检查192.168.1网段ip是否在用的方法》该Shell脚本通过并发ping命令检查192.168.1网段中哪些IP地址正在使用,脚本定义了网络段、超时时间和并行扫描数量,并使用... 目录脚本:检查 192.168.1 网段 IP 是否在用脚本说明使用方法示例输出优化建议总结检查 1

gradle安装和环境配置全过程

《gradle安装和环境配置全过程》本文介绍了如何安装和配置Gradle环境,包括下载Gradle、配置环境变量、测试Gradle以及在IntelliJIDEA中配置Gradle... 目录gradle安装和环境配置1 下载GRADLE2 环境变量配置3 测试gradle4 设置gradle初始化文件5 i

SpringCloud配置动态更新原理解析

《SpringCloud配置动态更新原理解析》在微服务架构的浩瀚星海中,服务配置的动态更新如同魔法一般,能够让应用在不重启的情况下,实时响应配置的变更,SpringCloud作为微服务架构中的佼佼者,... 目录一、SpringBoot、Cloud配置的读取二、SpringCloud配置动态刷新三、更新@R

MySQL中my.ini文件的基础配置和优化配置方式

《MySQL中my.ini文件的基础配置和优化配置方式》文章讨论了数据库异步同步的优化思路,包括三个主要方面:幂等性、时序和延迟,作者还分享了MySQL配置文件的优化经验,并鼓励读者提供支持... 目录mysql my.ini文件的配置和优化配置优化思路MySQL配置文件优化总结MySQL my.ini文件

C#读取本地网络配置信息全攻略分享

《C#读取本地网络配置信息全攻略分享》在当今数字化时代,网络已深度融入我们生活与工作的方方面面,对于软件开发而言,掌握本地计算机的网络配置信息显得尤为关键,而在C#编程的世界里,我们又该如何巧妙地读取... 目录一、引言二、C# 读取本地网络配置信息的基础准备2.1 引入关键命名空间2.2 理解核心类与方法

Redis连接失败:客户端IP不在白名单中的问题分析与解决方案

《Redis连接失败:客户端IP不在白名单中的问题分析与解决方案》在现代分布式系统中,Redis作为一种高性能的内存数据库,被广泛应用于缓存、消息队列、会话存储等场景,然而,在实际使用过程中,我们可能... 目录一、问题背景二、错误分析1. 错误信息解读2. 根本原因三、解决方案1. 将客户端IP添加到Re

最新版IDEA配置 Tomcat的详细过程

《最新版IDEA配置Tomcat的详细过程》本文介绍如何在IDEA中配置Tomcat服务器,并创建Web项目,首先检查Tomcat是否安装完成,然后在IDEA中创建Web项目并添加Web结构,接着,... 目录配置tomcat第一步,先给项目添加Web结构查看端口号配置tomcat    先检查自己的to