与aurora 64B66B 发送端 AXI4-Stream接口 相连的FIFO设置

2023-10-14 05:59

本文主要是介绍与aurora 64B66B 发送端 AXI4-Stream接口 相连的FIFO设置,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

目录

  • 1 背景
    • 1.1 关于Aurora 64b66b IP核
    • 1.2 关于FIFO的读操作模式
    • 1.3 遇到的问题
  • 2 与Aurora 64b66b IP核AXI4-S发送接口相连的FIFO的设计

1 背景

1.1 关于Aurora 64b66b IP核

在【PG074】1 简略学习Aurora 64B/66B IP核中2.3.3 Streaming接口章节学习了Aurora 64b66b IP核的基础指示。

  1. Aurora Example Design的结构

整个Example Design的机构:

在这里插入图片描述

  1. 示例设计具体的module的结构:

在这里插入图片描述

在此基础上,我们只要简单的把FRAME_GENFRAME_CHECK两个模块的接口拎出来就可以用于自己的收发数据设计了。

  1. FIFO与Aurora 64b66b IP核的连接
    在AXI4-Stream Aurora 64B/66B Example Design的基础上进行开发,我们发送数据的FIFO需要与这个接口连接,设计的结构图为:

在这里插入图片描述

AXI4-S接口有关的信号在各模块中的说明,这里只说明发送相关的,其他见PG074:

LocalLink中的名字AXI4-S中的名字区别
TX_Ds_axi_tx_tdata只有名字区别
TX_SRC_RDY_Ns_axi_tx_tvalid名字区别,反相
TX_DST_RDY_Ns_axi_tx_tready名字区别,反相
  1. 发送数据时 AXI4-Stream 接口的时序:

在这里插入图片描述

1.2 关于FIFO的读操作模式

在【PG057】FIFO Generator IP核学习中3.3.2 读操作章节中学习了first-word fall-through (FWFT) 读模式。FIFO的这种读模式可以预读一个数据,当读使能到来时,再往下读取一个数据,也就是说实现了在与读使能同一个时钟周期中输出读取的数据。

时序图:

在这里插入图片描述

1.3 遇到的问题

相信学习了前面两个背景知识,可以很好的判断,如果用于这种接口的传输,FIFO的FWFT读模式是很适合的。
之前使用的是标准读模式,这会导致很难去对齐TX_DST_RDY_N信号。造成数据帧前面多发多少发数据。因为s_axi_tx_tready并不是一个有恒定规律的信号,IP核随时会打断。类似下面这种波形:

在这里插入图片描述

2 与Aurora 64b66b IP核AXI4-S发送接口相连的FIFO的设计

afifo afifo_u (.rst   (~I_reset_n   ),  // input wire rst.wr_clk(I_sync_clk   ),  // input wire wr_clk.rd_clk(I_user_clk   ),  // input wire rd_clk.din   (R_afifo_din  ),  // input wire [31 : 0] din.wr_en (W_afifo_wr_en),  // input wire wr_en.rd_en (W_afifo_rd_en),  // input wire rd_en.dout  (W_afifo_dout ),  // output wire [63 : 0] dout.full  (             ),  // output wire full.empty (             ),  // output wire empty.valid (W_afifo_valid)   // output wire valid
);
assign W_afifo_rd_en = W_afifo_valid && (~TX_DST_RDY_N); assign TX_D = W_afifo_dout;
assign TX_SRC_RDY_N = ~W_afifo_valid;  

已知当FIFO非空,也就是有数据需要发送时,W_afifo_dout会预读一个数据并且W_afifo_valid被置为高,此时TX_SRC_RDY_N被断言,数据等待被发送。当Aurora 64b66b IP核准备好发送(TX_DST_RDY_N为低)时,使能W_afifo_rd_en读取当前数据,并且在相同的时钟周期将数据传递给IP核。之后W_afifo_dout会在有数据需要发送时预读下一个数据。

这篇关于与aurora 64B66B 发送端 AXI4-Stream接口 相连的FIFO设置的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

SpringBoot实现不同接口指定上传文件大小的具体步骤

《SpringBoot实现不同接口指定上传文件大小的具体步骤》:本文主要介绍在SpringBoot中通过自定义注解、AOP拦截和配置文件实现不同接口上传文件大小限制的方法,强调需设置全局阈值远大于... 目录一  springboot实现不同接口指定文件大小1.1 思路说明1.2 工程启动说明二 具体实施2

Java Stream 并行流简介、使用与注意事项小结

《JavaStream并行流简介、使用与注意事项小结》Java8并行流基于StreamAPI,利用多核CPU提升计算密集型任务效率,但需注意线程安全、顺序不确定及线程池管理,可通过自定义线程池与C... 目录1. 并行流简介​特点:​2. 并行流的简单使用​示例:并行流的基本使用​3. 配合自定义线程池​示

从原理到实战解析Java Stream 的并行流性能优化

《从原理到实战解析JavaStream的并行流性能优化》本文给大家介绍JavaStream的并行流性能优化:从原理到实战的全攻略,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的... 目录一、并行流的核心原理与适用场景二、性能优化的核心策略1. 合理设置并行度:打破默认阈值2. 避免装箱

基于Python实现自动化邮件发送系统的完整指南

《基于Python实现自动化邮件发送系统的完整指南》在现代软件开发和自动化流程中,邮件通知是一个常见且实用的功能,无论是用于发送报告、告警信息还是用户提醒,通过Python实现自动化的邮件发送功能都能... 目录一、前言:二、项目概述三、配置文件 `.env` 解析四、代码结构解析1. 导入模块2. 加载环

Java中的stream流分组示例详解

《Java中的stream流分组示例详解》Java8StreamAPI以函数式风格处理集合数据,支持分组、统计等操作,可按单/多字段分组,使用String、Map.Entry或Java16record... 目录什么是stream流1、根据某个字段分组2、按多个字段分组(组合分组)1、方法一:使用 Stri

使用Python的requests库来发送HTTP请求的操作指南

《使用Python的requests库来发送HTTP请求的操作指南》使用Python的requests库发送HTTP请求是非常简单和直观的,requests库提供了丰富的API,可以发送各种类型的HT... 目录前言1. 安装 requests 库2. 发送 GET 请求3. 发送 POST 请求4. 发送

MySQL设置密码复杂度策略的完整步骤(附代码示例)

《MySQL设置密码复杂度策略的完整步骤(附代码示例)》MySQL密码策略还可能包括密码复杂度的检查,如是否要求密码包含大写字母、小写字母、数字和特殊字符等,:本文主要介绍MySQL设置密码复杂度... 目录前言1. 使用 validate_password 插件1.1 启用 validate_passwo

基于Python编写自动化邮件发送程序(进阶版)

《基于Python编写自动化邮件发送程序(进阶版)》在数字化时代,自动化邮件发送功能已成为企业和个人提升工作效率的重要工具,本文将使用Python编写一个简单的自动化邮件发送程序,希望对大家有所帮助... 目录理解SMTP协议基础配置开发环境构建邮件发送函数核心逻辑实现完整发送流程添加附件支持功能实现htm

Java Stream流以及常用方法操作实例

《JavaStream流以及常用方法操作实例》Stream是对Java中集合的一种增强方式,使用它可以将集合的处理过程变得更加简洁、高效和易读,:本文主要介绍JavaStream流以及常用方法... 目录一、Stream流是什么?二、stream的操作2.1、stream流创建2.2、stream的使用2.

基于Redisson实现分布式系统下的接口限流

《基于Redisson实现分布式系统下的接口限流》在高并发场景下,接口限流是保障系统稳定性的重要手段,本文将介绍利用Redisson结合Redis实现分布式环境下的接口限流,具有一定的参考价值,感兴趣... 目录分布式限流的核心挑战基于 Redisson 的分布式限流设计思路实现步骤引入依赖定义限流注解实现