异步FIFO设计.docVIP

  1. 1、本文档共11页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  5. 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  6. 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  7. 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  8. 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
异步FIFO设计

【转】/s/blog_6592e7700100x68n.html 异步FIFO是一种先进先出电路,用在需要实时数据接口的部分,用来存储、缓冲在两个异步时钟之间的数据传输。异步FIFO与同步FIFO最大的不同在于异步FIFO读写时钟不同,通常异步FIFO用来做数据的时钟域转换,FIFO设计中难度最大的地方在FIFO的空满标识的产生,对同步FIFO来说,由于读写指针的增加时钟频率相同,因此读写指针可以直接进行比较产生出空满标志,而异步FIFO某由于读写两端时钟频率不同,读写指针需要进行时钟域转换后才能进行比较,也就是读时钟域的读地址要先转到写时钟域,然后与写时钟域的写地址进行比较,而实际这种比较时存在一定风险的。 ??? 异步FIFO设计一般的结构有:双口存储器、读地址产生逻辑、写地址产生逻辑、空/满标志产生逻辑四部分构成。图1是一种常用的异步FIFO设计方案,其中,读地址(rptr)和空标志(rempty)由读时钟 (rclk)产生,而写地址(wptr)和满标志(wfull)由写时钟(wclk)产生。把写地址与读地址相互比较以产生空/满标志。由于读写地址的变化由不同的时钟产生,所以对FIFO空或满的判断是跨时钟域的。如何避免异步传输带来的亚稳态以及正确地产生空/满标志是设计异步FIFO的难点。 ????? 图1 ??? 在设计时,需要弄清楚以下几个方面: ??? 1.首先确定输入输出接口,异步FIFO在一个时钟域中进行写数据操作,而在另一个时钟域中进行读数据操作,所以在写数据模块,需要有写数据wdata,写时钟wclk,写复位wrst_n,写请求wreq,写满标志wfull;在读数据模块,需要有读数据rdata,读时钟rclk,读复位rrst_n,读请求rreq,读空标志rempty。其中rdata,rempty,wfull为输出信号,其余为输入信号。 ??? 其FIFO用来存储16*8数据(数据宽为8,数据深度为16)的顶层模块如下: ???? //异步FIFO缓存16*8数据,即数据宽度为8,深度为 16// module yibufifo(rdata,rempty,rrep,rclk,rrst_n,wdata,wfull,wrep,wclk,wrst_n); input wclk,wrep,wrst_n; input rclk,rrep,rrst_n; input[7:0]wdata; output[7:0]rdata; output rempty,wfull; wire wclk,wrep,wrst_n; wire rclk,rrep,rrst_n; wire [7:0]wdata; wire [7:0]rdata; wire [3:0]wptr,rptr; wire [3:0]waddr,raddr; wire aempty_n,afull_n; ram i1(.wdata(wdata),//读写存储模块 ?????? .rdata(rdata), ?????? .waddr(wptr),//地址与指针同步 ?????? .raddr(rptr),// ?????? .wrep(wrep), ?????? .wclk(wclk)); async_cmp i2(.aempty_n(aempty_n),//异步比较读写指针产生异步空满标志 ???????????? .afull_n(afull_n), ???????????? .wptr(wptr), ???????????? .rptr(rptr), ???????????? .wrst_n(wrst_n)); rptr_empty2 i3(.rempty(rempty),//根据rclk产生读指针rptr和空标志rempty? ????????????? .rptr(rptr), ?????????????? .aempty_n(aempty_n), ?????????????? .rrep(rrep), ?????????????? .rclk(rclk), ?????????????? .rrst_n(rrst_n)); wptr_full2 i4(.wfull(wfull),//根据wclk产生写指针wptr和满标志wfull ????????????? .wptr(wptr), ????????????? .afull_n(afull_n), ????????????? .wrep(wrep), ????????????? .wclk(wclk), ????????????? .wrst_n(wrst_n)); endmodule 顶层模块图: ??? 其中 ??? 2.1 读写地址产生逻辑(本设计中读写地址与读写指针同步)   读写地址线一般有多位,如果在

文档评论(0)

asd522513656 + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档