码迷,mamicode.com
首页 > 其他好文 > 详细

异步fifo的读写

时间:2014-06-28 17:36:37      阅读:207      评论:0      收藏:0      [点我收藏+]

标签:style   blog   http   数据   2014   问题   

这里不讨论异步fifo是如何实现的,而是在实现fifo的前提下,对fifo的读写。

现在遇到的问题是:总线的数据不能写入fifo中,但是地址能加一。

 

代码如下:

if( !fifo_tx_full && cpu_write_fifo_en ) begin
                    fifo_r[ write_addr[ADDR_SIZE - 1‘b1 : 0] ] <= cpu_2_fifo;
                    write_addr <= write_addr + 1‘b1;
end

bubuko.com,布布扣

 

接收到的数据位00.

 

 

bubuko.com,布布扣

可能是时序约束问题,在之前我确实没有约束。

 

 

 

 bubuko.com,布布扣

改了译码的编写后就好了,在此,没有译码必须是1个1的译码,不然就会出错。但是,地址不够,我要如何改,现在还不确定。但是译码必须是1 个 1.

 

 

//控制三态

always @(cpu_read_req or intrp_en_en or fifo_con_en) begin
         if(cpu_read_req)
                en_tri = 1‘b1;
         else
                en_tri = 1‘b0;
end

 

 由于read和write是同一地址,所以这样总线就冲突了。这样读总线上的读数据就都是0.

 

always @(cpu_read_req or intrp_en_en or fifo_con_en) begin
  if(cpu_read_req && cpu_read_clk ) 
    en_tri = 1‘b1;
  else
    en_tri = 1‘b0;
end

修改后的代码,读请求和cpu_read_clk同时有效,才使能输出。这样总线就不会冲突了。

 

 bubuko.com,布布扣

 结果正确。

注:通过这个,知道总线上只能有一个是发数据,其他的设备只能是接收数据。不然就会冲突,且此时接收可能为0。

 

 

异步fifo的读写,布布扣,bubuko.com

异步fifo的读写

标签:style   blog   http   数据   2014   问题   

原文地址:http://www.cnblogs.com/cornhill/p/3793656.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!