最近在写一个异步FIFO的时候,从网上找了许多资料,文章都写的相当不错,只是附在后面的代码都多多少少有些小错误。

于是自己写了一个调试成功的代码,放上来供大家参考。

非原创 原理参考下面:

原文 https://www.cnblogs.com/SYoong/p/6110328.html

上代码:

 module Asyn_FIFO_tb;

     parameter WIDTH = ;

     reg clk_wr;
reg clk_rd;
reg rst_n_rd;
reg rst_n_wr; reg [WIDTH-:] data_wr;
reg wr_en;
wire wr_full; wire [WIDTH-:] data_rd;
reg rd_en;
wire rd_empty; Asyn_FIFO fifo_inst(
.clk_wr(clk_wr),
.rst_n_rd(rst_n_rd),
.rst_n_wr(rst_n_wr),
.wr_en(wr_en),
.data_wr(data_wr),
.clk_rd(clk_rd),
.rd_en(rd_en),
.data_rd(data_rd),
.rd_empty(rd_empty),
.wr_full(wr_full)
); initial begin
rst_n_rd = ;
rst_n_wr = ;
clk_wr = ;
clk_rd = ;
wr_en = ;
rd_en = ; #
rst_n_rd = ;
rst_n_wr = ; #
wr_en = ;
rd_en = ; #
wr_en = ;
rd_en = ;
end always # clk_wr = ~clk_wr;
always # clk_rd = ~clk_rd; /* always @(posedge clk_rd)
rd_en <= ($random) % 2; always @(posedge clk_wr)
wr_en <= ($random) % 2; */ always @(posedge clk_wr)
data_wr <= ($random) % ; endmodule

Asyn_FIFO_tb.v

 module Asyn_FIFO
#(
parameter WIDTH = ,
parameter DEPTH =
)
(
input clk_wr,
input clk_rd,
input rst_n_rd,
input rst_n_wr,
input wr_en,
input rd_en,
input [WIDTH-:] data_wr,
output [WIDTH-:] data_rd,
output reg rd_empty,
output reg wr_full
); //defination
reg [WIDTH- : ] mem [ : (<<DEPTH)-]; //2^DEPTH numbers
reg [DEPTH : ] wp, rp;
reg [DEPTH : ] wr1_rp, wr2_rp, rd1_wp, rd2_wp;
reg [DEPTH : ] wbin, rbin; wire [DEPTH- : ] waddr, raddr;
wire [DEPTH : ] wbin_next, rbin_next; //bincode
wire [DEPTH : ] wgray_next, rgray_next; //graycode wire rd_empty_val, wr_full_val; //output
assign data_rd = (rd_en && !rd_empty) ? mem[raddr] : ; //clear "xx" state //input
always@(posedge clk_wr)
if(wr_en && !wr_full)
mem[waddr] <= data_wr; /*----------generate waddr and raddr-------------------------*/
//gen raddr and read gray code
always@(posedge clk_rd or negedge rst_n_rd)
if(!rst_n_rd)
{rbin, rp} <= ;
else
{rbin, rp} <= {rbin_next, rgray_next}; assign raddr = rbin[DEPTH- : ];
assign rbin_next = rbin + (rd_en & ~rd_empty);
assign rgray_next = rbin_next ^ (rbin_next >> ); //gen waddr and write gray code
always@(posedge clk_wr or negedge rst_n_wr)
if(!rst_n_wr)
{wbin, wp} <= ;
else
{wbin, wp} <= {wbin_next, wgray_next}; assign waddr = wbin[DEPTH- : ];
assign wbin_next = wbin + (wr_en & ~wr_full);
assign wgray_next = wbin_next ^ (wbin_next >> ); /*---------------synchro rp and wp--------------------------*/
//synchro rp
always@(posedge clk_wr or negedge rst_n_wr)
if(!rst_n_wr)
{wr2_rp, wr1_rp} <= ;
else
{wr2_rp, wr1_rp} <= {wr1_rp, rp}; //delay two clock //synchro wp
always@(posedge clk_rd or negedge rst_n_rd)
if(!rst_n_rd)
{rd2_wp, rd1_wp} <= ;
else
{rd2_wp, rd1_wp} <= {rd1_wp, wp}; /*---------------empty and full flags--------------------------*/
//gen rd_empty
assign rd_empty_val = (rd2_wp == rgray_next);
always@(posedge clk_rd or negedge rst_n_rd)
if(!rst_n_rd)
rd_empty <= 'b1;
else
rd_empty <= rd_empty_val; //gen wr_full, two high bit do not equal
assign wr_full_val = ({~wr2_rp[DEPTH : DEPTH-], wr2_rp[DEPTH- : ]} == wgray_next);
always@(posedge clk_wr or negedge rst_n_wr)
if(!rst_n_wr)
wr_full <= 'b0;
else
wr_full <= wr_full_val; endmodule

Asyn_FIFO.v

注意wire、reg类型的赋值。

异步FIFO的verilog实现与简单验证(调试成功)的更多相关文章

  1. 异步FIFO及verilog原码

    这几天看了Clifford E. Cummings的两篇大作<Simulation and Synthesis Techniques for Asynchronous FIFO Design&g ...

  2. 异步FIFO总结+Verilog实现

    异步FIFO简介 异步FIFO(First In First Out)可以很好解决多比特数据跨时钟域的数据传输与同步问题.异步FIFO的作用就像一个蓄水池,用于调节上下游水量. FIFO FIFO是一 ...

  3. 异步fifo的Verilog实现

     一.分析 由于是异步FIFO的设计,读写时钟不一样,在产生读空信号和写满信号时,会涉及到跨时钟域的问题,如何解决? 跨时钟域的问题:由于读指针是属于读时钟域的,写指针是属于写时钟域的,而异步FIFO ...

  4. 同步fifo与异步fifo

    参考以下帖子: https://blog.csdn.net/hengzo/article/details/49683707 https://blog.csdn.net/Times_poem/artic ...

  5. 基于FPGA的异步FIFO验证

    现在开始对上一篇博文介绍的异步FIFO进行功能验证,上一篇博文地址:http://blog.chinaaet.com/crazybird/p/5100000872 .对异步FIFO验证的平台如图1所示 ...

  6. Verilog学习笔记简单功能实现(八)...............同步FIFO

    Part 1,功能定义: 用16*8 RAM实现一个同步先进先出(FIFO)队列设计.由写使能端控制该数据流的写入FIFO,并由读使能控制FIFO中数据的读出.写入和读出的操作(高电平有效)由时钟的上 ...

  7. 怎么用Verilog语言描述同步FIFO和异步FIFO

    感谢 知乎龚大佬 打杂大佬 网上几个nice的博客(忘了是哪个了....) 前言 虽然FIFO都有IP可以使用,但理解原理还是自己写一个来得透彻. 什么是FIFO? Fist in first out ...

  8. Verilog设计异步FIFO

    转自http://ninghechuan.com 异步FIFO有两个异步时钟,一个端口写入数据,一个端口读出数据.通常被用于数据的跨时钟域的传输. 同步FIFO的设计.一个时钟控制一个计数器,计数器增 ...

  9. 异步fifo的设计

    本文首先对异步 FIFO 设计的重点难点进行分析 最后给出详细代码 一.FIFO简单讲解 FIFO的本质是RAM, 先进先出 重要参数:fifo深度(简单来说就是需要存多少个数据)           ...

随机推荐

  1. 再见VB6!再见程序生涯!

    今天写一篇博文告别使用了15年的VB6,从此终结程序生涯.记得读大学的时候第一学习编程,用VB6嵌入MediaPlayer控件写了一个简易视频播放器,看着视频的画面激动人心,从此就爱上了编程,从此也和 ...

  2. python 云打码 http接口

    import http.client, mimetypes, urllib, json, time, requests ######################################## ...

  3. sklearn错误

    1.No module named 'sklearn.cross_validation' sklearn.cross_validation会报错,关键在于新版本的sklearn没有cross_vali ...

  4. ES6系列之箭头函数

    本系列是在平时阅读.学习.实际项目中有关于es6中的新特性.用发的简单总结,目的是记录以备日后温习:本系列预计包含let/const.箭头函数.解构.常用新增方法.Symbol.Set&Map ...

  5. 解除Portal for ArcGIS与ArcGIS Server的联合

    将ArcGIS Server站点添加到Portal中,可以实现ArcGIS Server站点的单点登录特性,并可以与Portal共享Server站点发布的内容,同时通过将联合服务器注册为托管服务器后还 ...

  6. 第十二章 Java内存模型与线程

    Java内存模型(Java Memory Model,JMM): 主内存与工作内存:Java内存模型主要是定义程序中各个变量的访问规则.Java内存模型规定了所有的变量都存储在主内存(Main Mem ...

  7. kubelet工作原理

    在调度这一步完成后,Kubernetes 就需要负责将这个调度成功的 Pod,在宿主机上创建出来,并把它所定义的各个容器启动起来.这些,都是 kubelet 这个核心组件的主要功能. kubelet ...

  8. 【HDFS API编程】jUnit封装-改写创建文件夹

    首先:什么是jUnit  回顾: https://www.cnblogs.com/Liuyt-61/p/10374732.html 上一节我们知道: /** * 使用Java API操作HDFS文件系 ...

  9. 解决安装fiddler后IE打开网页提示“代理服务器无响应”

    环境:win8.1+IE11 安装fiddler4后,启动fiddler,IE11打开百度网站,打开失败:代理服务器无响应,如图: 在网上找了各种方法,修改fiddler的设置,均无法解决这个问题,无 ...

  10. QPixmap 在非QtCreator环境下无法显示jpg图片

    这几天需要实现在Qt界面中显示jpg图片,于是直接将路径传给QPixmap对象,发现显示不出来. 然而在Qt SDK自带的Demo中却可以正确显示jpg图片,经搜索引擎查找发现,是自己的exe文件缺少 ...