Aurora64B 66B IP的原理及示例工程分析(高速收发器二十四)

news2025/1/18 10:43:35

  点击进入高速收发器系列文章导航界面


1、Aurora 64B/66B原理

  Aurora 64B/66B的原理与Aurora 8B/10B的原理基本上一致,通道概述如下所示。

在这里插入图片描述

图1 Aurora 64B/66B概述

  上图的Aurora 64B/66B Core就是该IP,一个IP可以驱动多个高速收发器,该内核的主要内容如下图所示,也与Aurora 8B/10B的内部构成一致。

在这里插入图片描述

图2 Aurora 64B/66B内核构成

  Aurora 64B/66B的全双工模式构成如下图所示,发送端和接收端都可以给用户提供AXI4-Stream和Stream两种接口,最右侧是高速收发器。中间就是该IP内部的一些处理逻辑,因此可知该IP就是在GTX的基础上封装得到的,内部很多内容与GTX是一致的。

在这里插入图片描述

图3 Aurora 64B/66B全双工的内部结构

  Aurora 64B/66B的内核时钟架构如下所示,如果看过我前面GTX相关的文章,那么理解下图就水到渠成了,应该都不需要我在分析。

  紫红色方框是高速收发器参考时钟与QPLL的处理,蓝色方框就是高速收发器结构,tx_out_clk经过TX_MMCM后生成txusrclk和txusrclk2,这部分也与GTX的设计一致。

  txusrclk2作为用户逻辑的参考时钟user_clk,因此user_clk的频率与txusrclk2的频率一致,计算方式与GTX的txusrclk2计算方式一致,本文就不再赘述了。

  红色方框包含发送端的加扰模块和接收端的解扰模块,因此用户使用该IP时,就不需要考虑加扰和解扰了。

在这里插入图片描述

图4 Aurora 64B/66B内核时钟架构

  由上图知,Aurora 64B/66B的初始化时钟与其余时钟是独立的,便于复位和初始化内核,因此需要单独提供。

  上述的讲解与前文通过GTX实现自定义64B66B的功能基本一致,但是该IP还具备流控和CRC校验等功能,在Aurora 8B/10B文中已经讲解过,本文就不再赘述。

  在讲解一下该IP复位和初始化相关内容,如下图所示,该IP会给用户提供一些状态和控制信号,便于用户调试。

在这里插入图片描述

图5 Aurora 64B/66B双工状态和控制接口

  该IP复位和初始化流程如下所示,Lane_up指示通道中的哪些通道已完成通道初始化部分。仅当内核(所有通道和内部逻辑)完成整个初始化过程后,channel_up才会被拉高。

  Aurora 64B/66B内核可以在Channel_up拉高之前接收数据,但Channel_up拉高之前不能发送数据,因此可以把Channel_up取反用作全双工模式下发送端的复位信号。

在这里插入图片描述

图6 初始化概述

  双工模式下,Aurora 64B/66B上电时序如下图所示,pma_init(gt_reset)和Reset_pb(reset)信号均为高电平,INIT_CLK和GT_REFCLK必须始终保持稳定。

  当两个时钟都稳定时,先拉低pma_init(gt_reset),之后拉低Reset_pb(reset)。

在这里插入图片描述

图7 Aurora 64B/66B上电时序

  双工模式下的正常复位时序如下图所示,先把Reset_pb(reset)拉高128个时钟周期,然后再拉高pma_init(gt_reset)一段时间(图中为1S)。之后先拉低pma_init(gt_reset),最后拉低Reset_pb(reset)信号。

在这里插入图片描述

图8 Aurora 64B/66B双工模式的正常复位时序

  通过上述讲解可知,Aurora 64B/66B包含Reset_pb和pma_init两个复位信号,他们的区别是什么呢?

  pma_init(gt_reset)的范围大一些,会先复位高速收发器,然后复位内核逻辑。而Reset_pb(reset)只会复位内核逻辑,不会复位底层的高速收发器。

  下图是双工模式下Reset_pb(reset)的复位时序,Reset_pb(reset)拉高的最短时间为128个user_clk周期。经过一段时间后,channel_up被拉低,表示传输通道建立失效。

在这里插入图片描述

图9 双工内核的复位时序

  下图是双工模式下的pma_init(gt_reset)复位时序,pma_init(gt_reset)至少拉高128个init_clk周期。经过一段时间后,user_clk会暂停产生时钟(因为user_clk的时钟来源是GT收发器,pma_init(gt_reset)复位从底层的物理层复位)。随后拉低channel_up信号,表示传输通道建立失效。

在这里插入图片描述

图10 双工内核的pma_init复位时序

  高速收发器一般都会使用双工模式,单工模式应该使用的比较少。因此本文不对单工的时序进行讲解,详情参考手册,与双工模式的相关时序大同小异。

2、生成Aurora 64B/66B IP

  Aurora 64B/66B IP的配置界面如下图所示,与Aurora 8B/10B的配置基本一致。线速率设置为10Gbps,高速收发器的参考时钟设置为156.25MHz,初始化时钟和DRP时钟频率均设置为100MHz,后续共用同一个时钟信号。

在这里插入图片描述

图11 设置“Core Options”界面

  在2处将IP设置为双工模式,用户端口设置为Framing,关闭流控模块,其余设置保持默认即可。

  如果只需要使用单个高速收发器,“GT Selections”界面全部保持默认即可,如下图所示,后续可以通过分配管脚来达到使用对应收发器的目的。

在这里插入图片描述

图12 配置“GT Selections”界面

  最后是配置“Shared Logic”界面,将共享逻辑放置在示例工程中,便于后续扩展高速收发器,与前文的高速收发器设置一致。

在这里插入图片描述

图13 配置“Shared Logic”界面

  然后生成IP即可。

3、分析Aurora 64B/66B示例工程

  通过上述IP生成示例工程,然后打开示例工程的RTL视图,如下所示。

在这里插入图片描述

图14 示例工程的RTL视图

  示例工程的相关IP设置如下图所示,与前面讲解的高速收发器相关结构基本一致,包含QPLL、复位、用户时钟生成等几个模块。

在这里插入图片描述

图15 IP的示例工程

  前面详细讲解过GTX和Aurora 8B/10B的信号流向,Aurora 64B/66B的设计类似,本文就不再赘述了。

  运行示例工程的仿真结果如下所示,运行时间会比较长,因为高速收发器的初始化需要的时间比较长,等到Channel_up拉高,表示高速收发器初始化完成。

在这里插入图片描述

图16 高速收发器初始化仿真时序

  下图蓝色方框表示用户发送的一帧数据,发送的第一个数据为四个16’h4eb3,最后两个有效字节数据为16’h5b7a。

在这里插入图片描述

图17 高速收发器发送一帧数据

  下图是另一个高速收发器接收上述数据的时序,接收的起始数据为四个16’h4eb3,最后两个字节数据为16’h5b7a,与上述发送的数据一致,证明高速收发器收发数据正常。

在这里插入图片描述

图18 高速收发器接收一帧数据

  Aurora 64B/66B IP的简介和官方示例工程的讲解到此结束,下文整理该IP,并且上板和仿真测试。

  该IP的手册依旧可以在公众号后台回复“xilinx手册”(不包含引号),在Aurora 64B/66B的文件夹下获取。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1990039.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

虚拟机(VMware16)安装rocky9.2详细过程,附镜像下载链接

rocky官方站点 链接: 官方站点 rocky9.2镜像下载路径 链接: Rocky-x86_64-dvd.iso 打开虚拟机,选择新建虚拟机 新建虚拟机 选择典型 由于VMware16没有rocky的版本,所以我们这里选择其他liunx 5.x 内核 64位 因为rocky9默认内核版本就是5开头的&#xf…

高频焊机逆变电路谐波计算及分析

一、SPWM谐波分析 简化高频焊机逆变模块为图4-6的单相PWM逆变电路。它由一个大小为u0的直流电压源和两个桥臂组成,每个桥臂包括两个MOSFET全控器件,阻抗Z模块为逆变输出负载[26]。逆变控制器的控制算法为双极性SPWM算法,即通过正弦调制波和三…

Unity Addressables bundle依赖查看和资源重复查看工具

在开发的过程有时候想要知道addressables 打包出来bundles的依赖关系,以及资源的重复情况。直接通过自带的addressables工具查看有点困难。这里分享一个github上的开源工具。名称为UnityAddressablesBuildLayoutExplorer。该工具可以帮助查看所有文件的依赖情况&…

在Visual Studio/Qt Creator 中使用CMake安装和使用vcpkg包

文章目录 0. vcpkg简介和安装0.1 vcpkg简介0.2 vcpkg安装0.2.1 如何在Visual Studio 2022以及以上版本中安装vcpkg0.2.2 在其他VS版本或Qt Creator等平台上中安装vcpkg 1. 在Visual Studio 中使用CMake安装和使用vcpkg包1.1 创建Visual Studio项目1.2 设置项目文件a. 配置CMake…

线性方程组迭代算法的Python实现

更多精彩,关注博客园主页,不断学习!不断进步! 我的主页 csdn很少看私信,有事请b站私信 博客园主页-发文字笔记-常用 有限元鹰的主页 内容: ABAQUS数值模拟相关Python科学计算开源框架,编程…

pip 安装 scikit-learn

第一步:更新pip 可以首先执行 python -m ensurepip 然后执行 python -m pip install --upgrade pip 即可更新完毕。 python -m ensurepip python -m pip install --upgrade pip第二步 安装sklearn的时候一定要注意顺序。 安装顺序:numpy / scipy / ma…

汇编语言入门基础(访问寄存器和内存)

目录 访问寄存器和内存 2.1 寄存器是CPU内部的信息存储单元 2.1.1 通用寄存器--以AX为例 2.1.2 将AX分成AH与AL 2.2 “字”再寄存器中的存储 2.3 mov和add指令 2.3.1 练习1 2.3.2 练习2 2.4 确定物理地址的方法 2.4.1 物理地址 2.4.2 8086CPU给出物理地址的方法 2.4.…

swin和vit

参考:https://blog.csdn.net/weixin_44878336/article/details/125444556 Swin Transformer与Vision Transformer的对比 二者的不同之处: Swin-Transformer所构建的特征图是具有层次性的,很像我们之前将的卷积神经网络那样,随着…

基于检索增强生成 (RAG) 的大语言模型优化研究

复旦大学的研究人员对检索增强生成技术 (RAG) 的现有方法进行了系统性的研究,提出了一种三步式方法来优化 RAG 框架,并通过实验证明了该方法在提高大型语言模型性能方面的有效性,特别是在多模态检索和问答方面的应用。 论文介绍 基于检索的…

HexView 刷写文件脚本处理工具-基本功能介绍(二)-导入文件

菜单 保存(Save) 在对数据进行任何修改后(例如修改十六进制行或块的基地址),保存选项将被启用。这表示文件已被修改。在这种情况下,“保存”选项允许你将数据存储到当前文件名中。Hexview会以当前文件格式写入数据。当前文件格式显示在状态行中。 另存为(Save as) 允…

LVS详细介绍及常见模式(NAT,DR,防火墙标记)实验详解

目录 一、什么是LVS 二、LVS的核心思想 三、 LVS的优势 四、LVS的调度算法 4.1. LVS的调度算法类型 4.2. LVS静态调度算法 4.3. LVS动态调度算法 4.4.在4.15版本内核以后新增调度算法 五、LVS软件相关信息 六、ipvsadm命令 七、 LVS的NAT模式实验详解 7.1实验环境 7.…

“DS18B20,感知每一度细微变化,记录每一刻温暖。”#DS18B20温度传感器

“DS18B20,感知每一度细微变化,记录每一刻温暖。”#DS18B20温度传感器 前言预备知识1.DS18B20核心参数2.DS18B20初始化函数代码编写2.1分析DS18B20初始化时序图2.2依据时序图编写相应代码 3.向DS18B20写入一个字节函数代码编写3.1分析DS18B20写时序图3.2…

Zoho工作邮箱支持哪些功能?

工作域名邮箱都有哪些常见功能呢?一、消息流 ;二、邮件委托给同事代为处理;三、附件查看器 ;四、在邮箱里直接和同事音频/视频通话等八大功能。 一、消息流 - 邮箱里的社交渠道 Zoho Mail等专业工作邮箱平台引入了消息流功能&…

免账户免权限免费获取 A股 全市场股票ETF指数 分钟级数据

日期 2024/8/2 意外发现的,抛砖引玉,测试了下,其他券商的也可以。 可以直接获取 1m 5m 1day 级别的数据,全A股市场的都可以。期货未测试。 需要 其他的级别的分数数据可以自行合成。 原理 券商版qmt获取行情数据时,不…

JavaSE之常用API(后篇)

接上篇 五、Random 5.1 使用 5.2 练习 六、包装类 6.1 是什么 包装类:封装了基本类的一些操作,更加方便使用 为了对象的完整性,更重要的是配合泛型一起使用 byte Byte short Short int Integer long Long float Float double Double boolean Boolean char Character 八种包装…

Cadence学习笔记 Day0 Cadence17.4环境安装

当然是选择“吴法安装” 直接跟着吴川斌博客的方法来就可以了,这里大致记录一下我的安装步骤: 安装许可证管理器破解许可证管理器安装软件以及补丁破解软件 获取 直接放出链接:吴川斌的博客 下载得到: 一、安装许可证管理器&am…

Redis未授权利用方式总结

前言 目前的大多数网站搭建的Redis 均采用 docker 一键部署的方式,而 docker 镜像中的 redis 默认不是以 root 权限运行的,也就是说即使拿下这台 redis,我们也只能在对方服务器的本地内网中漫游,当然还是会有部分 redis 部署在服…

Tensorflow—第四讲网络八股扩展

本讲概述 一、自制数据集 我们用六万张数字图片自制训练集,一万张数字图片制作测试集 代码(注释已经很清楚了,就不解释了): def generateds(path, txt):f open(txt, r) # 以只读形式打开txt文件contents f.readl…

【喜报】龙信助力上饶市公安局斩获全国刑侦部门数据侦查技战法大赛两项大奖

文章关键词:电子数据取证、手机取证、云取证、现场勘查、电子物证 8月2日,全国刑侦部门数据侦查技战法大赛在福建晋江市落下帷幕。来自全国各地的33支参赛队伍汇聚一堂,展现了全国公安刑侦部门数据侦查的新思路、新做法。 在这一高水平的竞技…

ant tree 数据的最优解

项目背景 : react ant ant 官网中目前只提供了 默认父子关联 或 checkStrictly(父子不关联)注意 : 不能盲目选择父子关联 , 虽然选中父 , 子也联动确实是需要的效果 , 但有一个bug 如下图 (当选中部分子 , 所有子被选中)解决方案 : 只能取消父子关联 , 自己去判断当前点击处…