Aurora 64B/66B 设计,仿真验证数据传输速率

2023-10-14 05:59

本文主要是介绍Aurora 64B/66B 设计,仿真验证数据传输速率,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

项目需求:要求使用Aurora协议,采集光口传输四通道传输的数据。

环境:Vivado 2017.4

器件:Kintex-7      xc7k325tffg676-2

一、创建新的空工程

对应器件选型来创建Aurora_test的工程。

略。

二、添加IP core

 三、配置IP

xilinx官方文档pg074有对应每一个选项下的介绍,采用简单粗暴的stearming式传输。

四、IP核例化

`timescale 1ns / 1psmodule Aurora_test
(                    sys_clk_p       ,sys_clk_n       ,sys_rst_nGTH_MCLK0_P     ,GTH_MCLK0_N     ,txp            ,txn            ,rxp            ,rxn )input   wire                 sys_rst_p      ;   input   wire                 sys_clk_n      ;input   wire                 sys_clk_n      ;input   wire                 GTH_MCLK0_P    ;input   wire                 GTH_MCLK0_N    ;   output  wire   [3:0]         txp            ;output  wire   [3:0]         txn            ;input   wire   [3:0]         rxp            ;input   wire   [3:0]         rxn            ;  reg         [31:0]          s_axi_tx_tdata      ;
reg                         s_axi_tx_tvalid     ;
wire                        s_axi_tx_tready     ;
wire        [255:0]         m_axi_rx_tdata      ;//to ddr4 to pcie
wire                        m_axi_rx_tvalid     ; 
wire                        hard_err            ;
wire                        soft_err            ;
wire                        channel_up          ;
wire                        lane_up             ;
wire                        reset               ;
wire                        gt_reset            ;//user_rst
wire        [ 3:0]          loopback            ;                      
wire                        drpclk_in           ;
wire        [ 8:0]          drpaddr_in          ;
wire                        drpen_in            ;
wire        [15:0]          drpdi_in            ;
wire                        drprdy_out          ;
wire        [15:0]          drpdo_out           ;
wire                        drpwe_in            ;
wire                        tx_lock             ;
wire                        tx_resetdone_out    ;
wire                        rx_resetdone_out    ;
wire                        link_reset_out      ;
wire                        init_clk_in         ;
wire                        user_clk_out        ;//user_clk  to wirte ddr4  
wire                        pll_not_locked_out  ;  
wire                        sys_reset_out       ;   
wire                        gt_reset_out        ;  
wire                        gt_refclk1_out      ;  
wire                        gt0_pll0refclklost_out; 
wire                        quad1_common_lock_out;  
wire                        gt0_pll0outclk_out  ;    
wire                        gt0_pll1outclk_out  ;    
wire                        gt0_pll0outrefclk_out;  
wire                        gt0_pll1outrefclk_out;  
wire                        locked              ;
reg         [10:0]          gt_reset_cnt        ;
reg                         start_flag          ;
reg         [31:0]          data_cnt            ;
reg         [11:0]          err_cnt             ; 
wire                        mmcm_not_locked_out ;      reg                        channel_up_r         ;
reg                        lane_up_r            ;
reg         [23:0]         pma_init_cnt         ;        assign reset = (pma_init_cnt== 24'hFFFFFF) ? 0:1;
//assign sys_rst_n = ~gt_reset;
assign gt_reset = (pma_init_cnt>= 24'h8FFFFF) ? 0:1;always @(posedge user_clk_out) beginif(~sys_rst_n)beginpma_init_cnt <= 24'b0;endelse if(pma_init_cnt< 24'hFFFFFF)pma_init_cnt <= pma_init_cnt + 1'b1;else if(pma_init_cnt>= 24'hFFFFFF)pma_init_cnt <= pma_init_cnt;    elsepma_init_cnt <= pma_init_cnt;                    
end/*************ip 例化****************/
aurora_64b66b_0 inst_aurora(.s_axi_tx_tdata         (s_axi_tx_tdata),.s_axi_tx_tvalid        (s_axi_tx_tvalid),.s_axi_tx_tready        (s_axi_tx_tready),.m_axi_rx_tdata         (m_axi_rx_tdata),.m_axi_rx_tvalid        (m_axi_rx_tvalid),.rxp                    (rxp),.rxn                    (rxn),.txp                    (txp),.txn                    (txn),.hard_err               (hard_err),.soft_err               (soft_err),.channel_up             (channel_up),.lane_up                (lane_up),       .user_clk_out           (user_clk_out),//dushuju.sync_clk_out           (),.reset_pb               (reset),.gt_rxcdrovrden_in      (1'b0),.power_down             (1'b0),.loopback               (loopback),.pma_init               (gt_reset), //gt_reset.gt0_drpdo              (), //output.gt0_drprdy             (), //output.gt0_drpaddr            (9'b0), //.gt0_drpdi              (16'b0),.gt0_drpen              (1'b0),.gt0_drpwe              (1'b0),.init_clk               (clk100m),   //参考时钟.link_reset_out         (link_reset_out),.gt_pll_lock            (),.gt_refclk1_p           (GTH_MCLK0_P),.gt_refclk1_n           (GTH_MCLK0_N),.gt_refclk1_out         (),.gt_powergood                      (),.gt_qpllclk_quad1_out	          (),.gt_qpllrefclk_quad1_out           (),.gt_qplllock_quad1_out             (),.gt_qpllrefclklost_quad1_out       (),.sys_reset_out		              (),.mmcm_not_locked_out          	  (),.gt_reset_out		              (),.tx_out_clk		                  ());

五、IP core仿真

 右击添加的IP ,打开IP的Example Design。Run simulation之后,等待仿真完毕,添加这两个例化信号:

 重新仿真一次,我的仿真过程有点慢不知道是什么原因,等待一段时间之后,IP的仿真波形如下:

 找到TX_D和RX_D,这两个信号代表着在PL端传输的数据,添加两根参考线,可以得到TX_D一个数据传输所用的时间6.44ns。

六、仿真速率的计算

1s传输多少个字节:1s ÷ 6.44ns = 155,279,503.1055901 个

一个字节根据协议在数据通道传输是66位:

用上面的字节数在乘上66 bit = 10,248,447,204.96894 bps ≈ 10.25Gbps

这篇关于Aurora 64B/66B 设计,仿真验证数据传输速率的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

MySQL 主从复制部署及验证(示例详解)

《MySQL主从复制部署及验证(示例详解)》本文介绍MySQL主从复制部署步骤及学校管理数据库创建脚本,包含表结构设计、示例数据插入和查询语句,用于验证主从同步功能,感兴趣的朋友一起看看吧... 目录mysql 主从复制部署指南部署步骤1.环境准备2. 主服务器配置3. 创建复制用户4. 获取主服务器状态5

MyBatis-Plus通用中等、大量数据分批查询和处理方法

《MyBatis-Plus通用中等、大量数据分批查询和处理方法》文章介绍MyBatis-Plus分页查询处理,通过函数式接口与Lambda表达式实现通用逻辑,方法抽象但功能强大,建议扩展分批处理及流式... 目录函数式接口获取分页数据接口数据处理接口通用逻辑工具类使用方法简单查询自定义查询方法总结函数式接口

Java通过驱动包(jar包)连接MySQL数据库的步骤总结及验证方式

《Java通过驱动包(jar包)连接MySQL数据库的步骤总结及验证方式》本文详细介绍如何使用Java通过JDBC连接MySQL数据库,包括下载驱动、配置Eclipse环境、检测数据库连接等关键步骤,... 目录一、下载驱动包二、放jar包三、检测数据库连接JavaJava 如何使用 JDBC 连接 mys

SQL中如何添加数据(常见方法及示例)

《SQL中如何添加数据(常见方法及示例)》SQL全称为StructuredQueryLanguage,是一种用于管理关系数据库的标准编程语言,下面给大家介绍SQL中如何添加数据,感兴趣的朋友一起看看吧... 目录在mysql中,有多种方法可以添加数据。以下是一些常见的方法及其示例。1. 使用INSERT I

Python使用vllm处理多模态数据的预处理技巧

《Python使用vllm处理多模态数据的预处理技巧》本文深入探讨了在Python环境下使用vLLM处理多模态数据的预处理技巧,我们将从基础概念出发,详细讲解文本、图像、音频等多模态数据的预处理方法,... 目录1. 背景介绍1.1 目的和范围1.2 预期读者1.3 文档结构概述1.4 术语表1.4.1 核

MySQL 删除数据详解(最新整理)

《MySQL删除数据详解(最新整理)》:本文主要介绍MySQL删除数据的相关知识,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录一、前言二、mysql 中的三种删除方式1.DELETE语句✅ 基本语法: 示例:2.TRUNCATE语句✅ 基本语

Spring Security中用户名和密码的验证完整流程

《SpringSecurity中用户名和密码的验证完整流程》本文给大家介绍SpringSecurity中用户名和密码的验证完整流程,本文结合实例代码给大家介绍的非常详细,对大家的学习或工作具有一定... 首先创建了一个UsernamePasswordAuthenticationTChina编程oken对象,这是S

MyBatisPlus如何优化千万级数据的CRUD

《MyBatisPlus如何优化千万级数据的CRUD》最近负责的一个项目,数据库表量级破千万,每次执行CRUD都像走钢丝,稍有不慎就引起数据库报警,本文就结合这个项目的实战经验,聊聊MyBatisPl... 目录背景一、MyBATis Plus 简介二、千万级数据的挑战三、优化 CRUD 的关键策略1. 查

python实现对数据公钥加密与私钥解密

《python实现对数据公钥加密与私钥解密》这篇文章主要为大家详细介绍了如何使用python实现对数据公钥加密与私钥解密,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录公钥私钥的生成使用公钥加密使用私钥解密公钥私钥的生成这一部分,使用python生成公钥与私钥,然后保存在两个文

mysql中的数据目录用法及说明

《mysql中的数据目录用法及说明》:本文主要介绍mysql中的数据目录用法及说明,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录1、背景2、版本3、数据目录4、总结1、背景安装mysql之后,在安装目录下会有一个data目录,我们创建的数据库、创建的表、插入的