中科亿海微FIFO使用

引言

        FPGA(现场可编程门阵列)是一种可编程逻辑器件,具有灵活性和可重构性,广泛用于数字电路设计和嵌入式系统开发。在FPGA中,FIFO(First-In, First-Out)是一种常见的存储器结构,用于在不同的时钟域之间进行数据传输和缓冲。FPGA中的FIFO通常由双端口内存实现,其中一个端口用于读取数据,另一个端口用于写入数据。FIFO内部有一个读指针和一个写指针,用于指示下一个要读取或写入的位置。当数据被写入FIFO时,写指针向前移动;当数据被读取时,读指针向前移动。这样,保证了先进先出的数据顺序。FIFO在FPGA中的应用非常广泛,特别是在数据流处理、通信接口、高速数据采集等领域。它可以解决不同时钟域之间的数据传输问题,同时还可以提供缓冲功能,使得数据传输能够以合适的速度进行,从而避免数据丢失或过载。FPGA厂商通常提供了各种类型和大小的FIFO IP核(知识产权核),可以方便地集成到设计中。此外,FPGA开发工具也提供了相应的设计工具和资源,以简化FIFO的使用和配置。

原理

  1. 内部存储器:FIFO由一个内部存储器组成,通常是一个双端口的存储器。一个端口用于写入数据,另一个端口用于读取数据。

  2. 写指针和读指针:FIFO内部有两个指针,一个是写指针,用于指示下一个要写入数据的位置;另一个是读指针,用于指示下一个要读取数据的位置。

  3. 写入数据:当有新的数据要写入FIFO时,写指针会向前移动到下一个可用的位置,并将数据写入该位置。

  4. 读取数据:当需要读取FIFO中的数据时,读指针会向前移动到下一个要读取的位置,并将该位置的数据输出。

  5. 先进先出:由于写指针和读指针的移动顺序是固定的,FIFO保证了写入FIFO的数据按照它们的顺序被读取,即先进先出。

  6. 缓冲和流量控制:FIFO提供了临时存储功能,可以用于缓冲数据,以适应不同时钟域之间的数据传输速率差异。它还可以用于流量控制,当写入方和读取方的速率不匹配时,FIFO可以缓冲数据以平衡传传输。

软核开发

module fifo_core(input wire clk,input wire rst,input wire wr_en,input wire rd_en,input wire [DATA_WIDTH-1:0] data_in,output wire [DATA_WIDTH-1:0] data_out,output wire fifo_empty,output wire fifo_full
);parameter DEPTH = 16; // FIFO深度parameter DATA_WIDTH = 8; // FIFO数据宽度reg [DATA_WIDTH-1:0] fifo[DEPTH-1:0];reg [DEPTH-1:0] wr_ptr, rd_ptr;reg [DATA_WIDTH-1:0] data_out_reg;reg fifo_empty_reg, fifo_full_reg;always @(posedge clk) beginif (rst) beginwr_ptr <= 0;rd_ptr <= 0;fifo_empty_reg <= 1;fifo_full_reg <= 0;data_out_reg <= 0;end else beginif (wr_en && !fifo_full_reg) beginfifo[wr_ptr] <= data_in;wr_ptr <= wr_ptr + 1;if (wr_ptr == DEPTH - 1)wr_ptr <= 0;if (wr_ptr == rd_ptr)fifo_full_reg <= 1;fifo_empty_reg <= 0;endif (rd_en && !fifo_empty_reg) begindata_out_reg <= fifo[rd_ptr];rd_ptr <= rd_ptr + 1;if (rd_ptr == DEPTH - 1)rd_ptr <= 0;if (rd_ptr == wr_ptr)fifo_empty_reg <= 1;fifo_full_reg <= 0;endendendassign data_out = data_out_reg;assign fifo_empty = fifo_empty_reg;assign fifo_full = fifo_full_reg;endmodule

以上示例是一个简单的FIFO软核程序,具有16深度(DEPTH)和8位数据宽度(DATA_WIDTH)。它包含了时钟(clk)和复位(rst)输入信号,以及写使能(wr_en)和读使能(rd_en)输入信号。数据输入(data_in)和数据输出(data_out)信号用于写入和读取数据。此外,还有fifo_empty和fifo_full信号用于指示FIFO是否为空或已满。在always块中,根据时钟上升沿进行FIFO的写入和读取操作。当rst为1时,FIFO被复位,指针和状态寄存器被重置为初始值。当wr_en为1且FIFO不满时,将数据写入FIFO并更新写指针。当rd_en为1且FIFO不为空时,从FIFO读取数据并更新读指针。同时更新FIFO的空和满状态。最后,使用assign语句将data_out_reg、fifo_empty_reg和fifo_full_reg分配给对应的输出信号。

eLinx工具开发

        

module FIFO_TOP(input 	wire 	clk);reg    [7:0]    data=0;reg    wrreq=0;wire   empty;wire   full;wire    [3:0]    usedw;wire    [7:0]    q;always @ (posedge clk) begin data	<=	data	+	1'b1;wrreq	<=	1'b1;end fifo_1 u_fifo_1(.clock					(clk),.data					(data),.rdreq					(1'b1),.wrreq					(wrreq),.empty					(empty),.full					(full),.usedw					(usedw),.q						(q));endmodule

实验结果

结论

        FIFO大小:根据应用需求选择适当的FIFO大小。如果FIFO太小,可能会导致数据丢失或溢出。如果FIFO太大,可能会浪费资源。因此,根据应用的数据流量和延迟要求选择合适的FIFO深度。时钟和复位:确保FIFO的时钟和复位信号正确连接。时钟信号必须是稳定的,并满足FIFO的最小时钟频率要求。复位信号应在系统启动时对FIFO进行复位,以确保其处于已知状态。数据宽度匹配:确保FIFO的输入和输出数据宽度匹配。如果数据宽度不匹配,可能会导致数据损坏或不正确的数据传输。读写控制:正确控制FIFO的读写操作。确保只在FIFO非满时写入数据,并在FIFO非空时读取数据。使用合适的读写使能信号来控制FIFO的读写操作。状态检测:使用FIFO的状态信号(如fifo_empty和fifo_full)来检测FIFO的状态。这些信号可以用于判断FIFO是否为空或已满,以避免数据丢失或溢出。时序约束:在设计中,确保对FIFO的读写操作满足正确的时序约束。这可以通过设置适当的时序约束或使用时序分析工具来验证。时钟域处理:确保FIFO的读写操作在正确的时钟域进行。如果涉及多个时钟域,需要使用合适的时钟域划分技术(如时钟域交叉点或异步FIFO)来处理时钟域间的数据传输。异步复位:如果FIFO的复位信号来自于异步复位源(如外部复位信号),需要考虑异步复位的时序和影响,并确保正确处理异步复位。同步/异步接口:根据系统需求,选择合适的FIFO接口类型。可以使用同步接口(如双时钟同步FIFO)或异步接口(如双端口异步FIFO)。时序和资源约束:在FPGA设计中,根据具体的FPGA型号和工具要求,设置适当的时序和资源约束,以确保FIFO的正确功能和性能。

参考文献

  1. Smith, J. G., & Franzon, P. D. (1997). The designer's guide to VHDL. Morgan Kaufmann.

    本书介绍了FIFO的基本概念和设计方法,并提供了用VHDL实现FIFO的示例。
  2. Chu, P. (2000). FPGA prototyping by Verilog examples: Xilinx Spartan-3 version. Wiley-Interscience.

    本书提供了使用Verilog实现FIFO的示例代码和详细说明。
  3. Bhasker, J. (2005). A VHDL primer. Pearson Education India.

    本书介绍了FIFO的基本原理,并提供了VHDL代码实现示例。
  4. Gajski, D. D., Dömer, R., Abdi, S. A., & Gerstlauer, A. (2009). Embedded system design: Modeling, synthesis and verification. Springer Science & Business Media.

    本书介绍了FIFO在嵌入式系统设计中的应用,包括建模、综合和验证等方面的内容。
  5. Palnitkar, S. (2003). Verilog HDL: A guide to digital design and synthesis. Prentice Hall.

    本书详细介绍了Verilog HDL语言,包括FIFO的设计和实现。

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

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

相关文章

1001 Battle Over Cities - Hard Version (PAT顶级)

总体思路是用并查集来做。vec记录了目前断掉的路&#xff0c;use记录了使用中的路。将断掉的路按照修复费用从小到大排序。 对每一个城市i失守进行讨论&#xff0c;先根据use将其中两端城市进行union&#xff0c;然后计算一下联通块个数。再按序找两个城市不在同一个联通块中的…

Java常用代码块、工具类、常用框架、mysql常用语句模版汇总

Idea常用插件 Build Generator:生成builder模式的代码MybatisX:mapper.xml文件和dao之间关联、映射LombokMaven Helper:分析maven冲突等Json parserJava后台常用框架 springbootspringmvcmybatis -plusmysqlmavenjunitjacksonguavaapache commons utilsnettyswaggerjoda-tim…

【Nginx】Nginx的重定向——location

location 匹配URI location 匹配的规则和优先级&#xff1b;***重点 nginx常用的变量&#xff1b;要求掌握 rewrite 重定向&#xff1b;掌握/理解 location匹配&#xff1a;*** 正则表达式&#xff1a;匹配的是文件内容 常见的正则表达式&#xff1a…

读《Flask Web开发实战》(狼书)笔记 | 第1、2章

前言 2023-8-11 以前对网站开发萌生了想法&#xff0c;又有些急于求成&#xff0c;在B站照着视频敲了一个基于flask的博客系统。但对于程序的代码难免有些囫囵吞枣&#xff0c;存在许多模糊或不太理解的地方&#xff0c;只会照葫芦画瓢。 而当自己想开发一个什么网站的时&…

【云原生】Kubernetes 概述

Kubernetes 概述 1.Kubernetes 简介 Kubernetes 是一个可移植的、可扩展的、用于管理容器化工作负载和服务的开源平台&#xff0c;它简化&#xff08;促进&#xff09;了声明式配置和自动化。它有一个庞大的、快速增长的生态系统。Kubernetes 的服务、支持和工具随处可见。 K…

消息队列kafka及zookeeper机制

一、zookeeper1.1 zookeeper简介1.2 zookeeper工作机制1.3 Zookeeper特点1.4 Zookeeper 数据结构1.5 Zookeeper 应用场景1.5.1 统一命名服务1.5.2 统一配置管理1.5.3 统一集群管理1.5.4 服务器动态上下线1.5.5 软负载均衡 1.6 Zookeeper 选举机制1.6.1 第一次启动选举机制1.6.2…

Jenkins 使用

Jenkins 使用 文章目录 Jenkins 使用一、jenkins 任务执行二、 Jenkins 连接gitee三、Jenkins 部署静态网站 一、jenkins 任务执行 jenkins 创建 job job的名字最好是有意义的 restart_web_backend restart_web_mysql[rootjenkins ~]# ls /var/lib/jenkins/ config.xml …

为什么Tomcat的NIO在读取body时要模拟阻塞?

文章首发地址 Tomcat的NIO完全可以以非阻塞方式处理IO&#xff0c;为什么在读取body部分时要模拟阻塞呢&#xff1f;在Tomcat的NIO读取HTTP请求时&#xff0c;为了保证请求的正确性和可靠性&#xff0c;需要模拟阻塞模式&#xff0c;这是因为servlet规范里定义了ServletInputSt…

W5500-EVB-PICO作为TCP Client 进行数据回环测试(五)

前言 上一章我们用W5500-EVB-PICO开发板通过DNS解析www.baidu.com&#xff08;百度域名&#xff09;成功得到其IP地址&#xff0c;那么本章我们将用我们的开发板作为客户端去连接服务器&#xff0c;并做数据回环测试&#xff1a;收到服务器发送的数据&#xff0c;并回传给服务器…

设计模式-单例

概述 在类加载后&#xff0c;整个系统只有一个实例类 饿汉式 public class Mg1 {private static final Mg1 INSTANCE new Mg1();private Mg1(){}public static Mg1 getInstance(){return INSTANCE;}public static void main(String[] args) {System.out.println(Mg1.getIns…

SAP MM学习笔记16-在库品目评价

在库品目评价是指评估物料。具体比如物料价格&#xff0c;数量&#xff0c;保管场所等发生变化的时候&#xff0c;判断是否发生了变化&#xff0c;要不要生成 FI票&#xff0c;用哪个FI科目来进行管理等内容就叫在库品目评价。 在库品目评价有很多层级&#xff0c;这里先讲3兄弟…

物联网嵌入式学习路线发展方向(表格一目了然)

文章目录&#xff1a; 一&#xff1a;学习路线 二&#xff1a;各种分类 1.软件硬件分类 2.发展方向 技术类型 对应岗位分类 3.常见板子芯片内核 4.嵌入式公司 对于小白&#xff1a;不知道嵌入式整个体系&#xff1f;学什么&#xff1f;顺序是什么&#xff1f;可以找什么…

在Linux虚拟机内配置nginx以及docker

目录 1、nginx源码包编译以及安装依赖 1、配置安装所需的编译环境 2、安装函数库&#xff08;pcre、zlib、openssl&#xff09; 2、安装nginx 1、获取源码包 2、解压编译 3、启动nginx服务 1、关闭防火墙 2、运行nginx 3、使用本地浏览器进行验证 3、安装docker 1、…

每次执行@Test方法前都执行一次DB初始化(SpringBoot Test + JUnit5环境)

引言 在执行单元测试时&#xff0c;可以使用诸如H2内存数据库替代线上的Mysql数据库等&#xff0c;如此在执行单元测试时就能尽可能模拟真实环境的SQL执行&#xff0c;同时也无需依赖线上数据库&#xff0c;增加了测试用例执行环境的可移植性。而使用H2数据库时&#xff0c;通…

Oracle DB 安全性 : TDE HSM TCPS Wallet Imperva

• 配置口令文件以使用区分大小写的口令 • 对表空间进行加密 • 配置对网络服务的细粒度访问 TCPS 安全口令支持 Oracle Database 11g中的口令&#xff1a; • 区分大小写 • 包含更多的字符 • 使用更安全的散列算法 • 在散列算法中使用salt 用户名仍是Oracle 标识…

【JavaEE】Spring Boot - 日志文件

【JavaEE】Spring Boot 开发要点总结&#xff08;3&#xff09; 文章目录 【JavaEE】Spring Boot 开发要点总结&#xff08;3&#xff09;1. 日志有什么作用2. 日志格式2.1 日志框架原理 3. 日志的打印3.1 System.out.println3.2 使用日志框架3.3 日志级别3.3.1 设置默认日志显…

深度学习(36)—— 图神经网络GNN(1)

深度学习&#xff08;36&#xff09;—— 图神经网络GNN&#xff08;1&#xff09; 这个系列的所有代码我都会放在git上&#xff0c;欢迎造访 文章目录 深度学习&#xff08;36&#xff09;—— 图神经网络GNN&#xff08;1&#xff09;1. 基础知识2.使用场景3. 图卷积神经网…

提高测试用例质量的6大注意事项

在软件测试中&#xff0c;经常会遇到测试用例设计不完整&#xff0c;用例没有完全覆盖需求等问题&#xff0c;这样往往容易造成测试工作效率低下&#xff0c;不能及时发现项目问题&#xff0c;无形中增加了项目风险。 因此提高测试用例质量&#xff0c;就显得尤为重要。一般来说…

部署K8S集群

目录 一、环境搭建 1、准备环境 2、安装master节点 3、安装k8s-master上的node 4、安装配置k8s-node1节点 5、安装k8s-node2节点 6、为所有node节点配置flannel网络 7、配置docker开启加载防火墙规则允许转发数据 二、k8s常用资源管理 1、创建一个pod 2、pod管理 一、…

电脑开不了机如何解锁BitLocker硬盘锁

事情从这里说起&#xff0c;不想看直接跳过 早上闲着无聊&#xff0c;闲着没事干&#xff0c;将win11的用户名称改成了含有中文字符的用户名&#xff0c;然后恐怖的事情发生了&#xff0c;蓝屏了… 然后就是蓝屏收集错误信息&#xff0c;重启&#xff0c;蓝屏收集错误信息&…