FIFO Generate IP核使用——Data Counts页详解

在Vivado IDE中,当看到一个用于设置数据计数选项的选项卡时,需要注意的是,尽管某些选项值可能因为当前的配置而显示为灰色(即不可选或已禁用),但IDE中显示的有效范围值实际上是你可以选择的真实值。即使某些值在视觉上被灰化,它们仍然是可用的,只要你的FIFO配置支持这些值。然而,通常灰化的值是因为它们在当前FIFO的特定配置下不适用或不推荐。

1 选择Native 接口采用Common时钟Standard模式时(Built-in除外)

此时,只需要配置Data Count的宽度。
在这里插入图片描述
数据计数的目的是输出用于显示FIFO中当前存储的数据字数量。其宽度可以是指定数据计数总线的宽度,最大宽度为log2(depth),其中depth是FIFO的深度(即最大可以存储的数据字数量)。如果指定的宽度小于最大允许宽度,那么总线的较低位将被截去。

假设FIFO的深度为8(即可以存储8个数据字),可以指定一个2位的数据计数总线,这2位将只能提供四种状态:00(FIFO为空)、01(FIFO包含1到2个数据字)、10(FIFO包含3到4个数据字)、11(FIFO包含5到8个数据字)。

注意:
如果在clk的上升沿发生读或写操作,数据计数端口(data_count)将在相同的clk上升沿更新。这意味着在每个时钟周期结束时检查data_count的值,以确定FIFO的当前状态。

2 选择Native 接口采用Independent时钟Standard模式时(Built-in除外)

此时,需要配置Write Data Width 和Read Data Count。
在这里插入图片描述
2.1 读数据计数(Read Data Count)

rd_data_count报告FIFO中可用于读取的数据字数量。它永远不会报告比实际可用的数据字更多的数量(尽管它可能会暂时报告更少的数量),以确保用户设计不会因读取过多数据而导致FIFO下溢。

宽度:可以指定读数据计数总线的宽度是最大宽度为log2(read depth),其中read depth是FIFO的读取深度(即最大可以读取的数据字数量)。如果指定的宽度小于最大允许宽度,那么总线的较低位将被截去。

注意:
如果在rd_clk/clk的上升沿发生读操作,这个读操作将在下一个rd_clk/clk的上升沿反映在rd_data_count信号上。
在wr_clk/clk时钟域上的写操作可能需要经过多个时钟周期才能在rd_data_count中反映出来,这取决于FIFO的实现和跨时钟域同步的机制。
因此,在设计跨时钟域FIFO时,需要特别注意读写数据计数的更新和同步问题,以确保数据的正确性和系统的稳定性。

2.2 Write Data Count(写数据计数)

wr_data_count报告已写入FIFO的数据字数量。它永远不会报告比实际已写入的数据字更少的数量(尽管它可能会暂时报告更多的数量),以确保你永远不会因写入过多数据而导致FIFO溢出。
宽度:可以指定写数据计数总线的宽度,最大宽度为log2(write depth),其中write depth是FIFO的写入深度(即最大可以写入的数据字数量)。如果指定的宽度小于最大允许宽度,那么总线的较低位将被截去。

注意:
如果在wr_clk/clk的上升沿发生写操作,这个写操作将在下一个wr_clk/clk的上升沿反映在wr_data_count信号上。
在rd_clk/clk时钟域上的读操作可能需要经过多个时钟周期才能在wr_data_count中反映出来,这取决于FIFO的实现和跨时钟域同步的机制。
因此,在设计跨时钟域FIFO时,需要特别注意读写数据计数的更新和同步问题,以确保数据的正确性和系统的稳定性。

3 选择Native 接口采用First-Word Fall-Through模式时

当采用该模式时,除了上述的数据计数、读数据计数和写数据计数意外,当采用common时钟时More Accurate Data Counts为默认必选项,如下图。
在这里插入图片描述
当选择Native 接口采用First-Word Fall-Through模式时,如果使用了Independent时钟,More Accurate Data Counts为可选项。
在这里插入图片描述
More Accurate Data Count(更精确的数据计数),目的是适应深度的增加并确保提供准确的数据计数。

当在Vivado IDE中选择“More Accurate Data Count ”选项时,wr_data_count(写入数据计数)、rd_data_count(读取数据计数)和data_count(数据计数)的宽度将分别增加,以容纳在First-Word Fall-Through情况下深度的增加。具体来说,它们的宽度分别为log2(write depth)+1、log2(read depth)+1和log2(depth)+1。

例如,对于一个深度为16的独立FIFO,具有对称的读写端口宽度,并选择了First-Word Fall-Through选项,实际的FIFO深度将从15增加到17(因为First-Word Fall-Through会占用一个额外的空间)。当使用准确的数据计数时,wr_data_count和rd_data_count的宽度将是5位,最大值为31(因为log2(17) = 4,但加1后变为5)。

当使用此选项时,不能使用wr_data_count、rd_data_count或data_count的任何一位来表示FIFO的状态,比如大约半满、四分之一满等。因为数据计数器的宽度增加了,直接使用传统的位表示方法(如最高位表示满或空)将不再准确。

对于上面的例子,如果想判断FIFO是否至少半满,你必须同时检查数据计数的最高位(MSB)和次高位(MSB-1)。这是因为数据计数器的范围从0(空)到31(对于5位计数器),而不是从0到16(对应于原始的FIFO深度)。因此,需要一个更复杂的条件来判断FIFO的状态。

这个选项允许更准确地跟踪FIFO中的元素数量,特别是在First-Word Fall-Through模式下,但它也引入了对FIFO状态判断的复杂性。因此,在使用此选项时,需要特别注意如何解释数据计数器的值。

2 选择Native 接口采用Built-in时钟

在选择Native接口时,如果使用了Built-in时钟,没有Data Counts选项页。

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

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

相关文章

《十二》Qt各种对话框之FileDialog文件对话框及QMessageBox 消息对话框

QFileDialog 对话框 选择打开一个文件 若要打开一个文件,可调用静态函数 QFileDialog::getOpenFileName(),“打开一个文件”按钮的响应代码如下: void Dialog::on_btnOpen_clicked() { //选择单个文件QString curPathQDir::currentPath()…

基于React实现B站评论区

今天继续来学习一下React,使用React实现B站评论区,如下图: 在使用React开发类似B站评论区的功能时,我们需要考虑以下几个关键点来构建一个基本的评论系统: 1. 设计组件结构 首先,设计组件结构是关键。至少…

Unity Animation--动画剪辑

Unity Animation--动画剪辑 动画剪辑 动画剪辑是Unity动画系统的核心元素之一。Unity支持从外部来源导入动画,并提供创建动画剪辑的能力使用“动画”窗口在编辑器中从头开始。 外部来源的动画 从外部来源导入的动画剪辑可能包括: 人形动画 运动捕捉…

css---浮动知识点精炼汇总

前言 欢迎来到我的博客 个人主页:北岭敲键盘的荒漠猫-CSDN博客 浮动简单理解与介绍 这是我们普通的页面标签效果。 每个标签从上到下依次排列。 浮动顾名思义就是让这个标签飞翔起来。 他飞起来后,后面的标签来到他的位置上。 而浮动的标签就会显示在标签的上面。…

设计模式之MVC模式

在编程江湖闯荡多年,我手中打磨过的设计模式多如繁星,但论及经典与实用, MVC(Model-View-Controller)模式 绝对是个中翘楚!它不仅是Web应用的骨架,更是软件架构的智慧结晶。今天,咱们…

LeetCode-网络延迟时间(Dijkstra算法)

每日一题 今天刷到一道有关的图的题,需要求单源最短路径,因此使用Dijkstra算法。 题目要求 有 n 个网络节点,标记为 1 到 n。 给你一个列表 times,表示信号经过 有向 边的传递时间。 times[i] (ui, vi, wi),其中 …

Mybatis-Plus学习:快速入门、核心功能、扩展功能、插件功能

文章目录 MybatisPlus快速入门快速开始常见注解常见配置 核心功能条件构造器(Wrapper)自定义SQLService接口基本用法基础业务接口复杂业务接口Lamda查询Lamda更新批量新增 扩展功能代码生成代码生成器快速开发插件 静态工具逻辑删除枚举处理器JSON处理器…

万界星空科技商业开源MES+项目合作+商业开源低代码平台

今天我想和大家分享的是一套商业开源的 MES制造执行管理系统带源码。对于制造业而言,MES 是一个至关重要的系统,它可以帮助企业提高生产效率、优化资源利用、提高产品质量,从而增强市场竞争力。 什么是 MES? MES 是指通过计算机技…

# notepad++ 编辑器英文版,如何打开自动换行

notepad 编辑器英文版,如何打开自动换行 在Notepad中,如果你想要开启自动换行功能,可以按照以下步骤操作: 1、打开 Notepad 编辑器。 1.1. 依次点击菜单栏中的【视图】,英文版对应【View】。1.2. 在【视图】下拉菜单…

商务谈判技巧与口才书籍有哪些类型

商务谈判技巧与口才书籍有哪些类型(3篇) 商务谈判技巧与口才书籍的类型丰富多样,以下从三个角度进行介绍: **篇:基础理论与策略类书籍 这类书籍通常深入剖析谈判的本质,系统介绍谈判的原理、技巧和策略。…

量子城域网建设设备系列(二):量子密钥管系统(KMS)

在上文介绍光量子交换机的文章中我们提到,量子保密通信网络的通道切换是由量子密钥管理系统(Key Management System,KMS)给光量子交换机下发信道切换指令,实现整个网络中任意两对量子密钥分发终端的量子信道互联互通&a…

【跟马少平老师学AI】-【神经网络是怎么实现的】(九)长短期记忆网络

一句话归纳: 1)RNN也会存在梯度消失的问题。 2)同一句话,对于不同的任务,句中不同的词起的作用也不一样。 3)LSTM(长短期记忆)子网络: 门,让输入经过运算&…

与Apollo共创生态:探索自动驾驶的未来蓝图

目录 引言Apollo开放平台Apollo开放平台企业生态计划Apollo X 企业自动驾驶解决方案:加速企业场景应用落地Apollo开放平台携手伙伴共创生态生态共创会员权益 个人心得与展望技术的多元化应用数据驱动的智能化安全与可靠性的重视 结语 引言 就在2024年4月19日&#x…

SpringBoot的ProblemDetails

1.RFC 7807 之前的项目如果出现异常,默认跳转到error页面。或者是抛出500 异常。 但是对于前后端分离的项目,Java程序员不负责页面跳转,只需要 把错误信息交给前端程序员处理即可。而RFC 7807规范就是将异常 信息转为JSON格式的数据。这个…

导数之光:探寻机器学习中的微变奥秘

在当今这个数据驱动的时代,机器学习以其强大的学习和预测能力,成为了推动科技进步的重要力量。而在机器学习的背后,数学原理,尤其是导数的应用,为其提供了坚实的理论支撑。本文将详细探讨导数在机器学习中的体现&#…

如何使用 GPT API 从 PDF 出版物导出研究图表?

原文地址:how-to-use-gpt-api-to-export-a-research-graph-from-pdf-publications 揭示内部结构——提取研究实体和关系 2024 年 2 月 6 日 介绍 研究图是研究对象的结构化表示,它捕获有关实体的信息以及研究人员、组织、出版物、资助和研究数据之间的关…

IDEA 创建Servlet-HelloWorldServlet

servlet 1.创建空项目2.配置web项目3.配置Tomcat4.加载Tomcat包5.创建HelloWorldServlet类6.配置web.xml7.运行get与post请求 1.创建空项目 2.配置web项目 3.配置Tomcat 4.加载Tomcat包 5.创建HelloWorldServlet类 public class controller extends HttpServlet {Override//get…

【Mellanox命令之】如何查看系统MFT版本是否与OFED和FW匹配?(mst version、rpm -qa|grep mft)

0. 背景 如果出现升级了OFED,以及FW、lib等,但是在Debug中遇到异常。可能与mft版本不匹配有关。 那么如何获取mft与OFED、FW之间的匹配关系呢? 1. 查看MFT版本 mft因为不是一个命令,而是4类工具的集合(参考兄弟篇&a…

DRF版本组件源码分析

DRF版本组件源码分析 在restful规范中要去,后端的API中需要体现版本。 3.6.1 GET参数传递版本 from rest_framework.versioning import QueryParameterVersioning单视图应用 多视图应用 # settings.pyREST_FRAMEWORK {"VERSION_PARAM": "versi…

图像处理1,灰度,data,for循环批处理图片,图片属性查看,图片单通道查看,椒盐噪声的生成,滤波处理,图像分割

图像处理1 灰度处理data库的使用for循环批处理图像对图像属性的查看图片类型图片尺寸图片宽度图像高度通道数总像素个数最大像素值最小像素值,像素平均值图像点像素值 for循环分别显示图像rgb通道椒盐噪声的生成中值滤波处理高斯模糊处理图像切割 灰度处理 from sk…