sdlyyuxi的个人空间 https://blog.eetop.cn/907322 [收藏] [复制] [分享] [RSS]

空间首页 动态 记录 日志 相册 主题 分享 留言板 个人资料

日志

同步FIFO的空满检测

已有 3034 次阅读| 2017-7-14 15:59 |个人分类:FIFO|系统分类:硬件设计

试了一下,好像基本功能是OK的。深度为8        
parameter   DATA_WIDTH     = 8 ;         
parameter   DATA_DEPTH     = 8;         
parameter   DATA_PTR_WIDTH = 3 ;         
reg[DATA_PTR_WIDTH-1 :0] counter_rd   ;         
reg[DATA_PTR_WIDTH-1 :0] counter_wt   ;       
 wire[DATA_PTR_WIDTH-1:0]    counter_rd_tmp;       
 wire                    counter_rd_zero;        
wire                    ptr_eq;        
wire                    ptr_eq_tmp;
空的判断 读指针 == 写指针              
assign  ptr_eq = !(counter_rd ^ counter_wt);             
 assign    empty = ptr_eq ? 1'b1 : 1'b0; 
满的判断 [深度为8]
1. 写指针在前:读指针在 0,而写指针在7    
2. 读指针在前:即写指针已写满FIFO一次后,再次追上了读指针           
assign  counter_rd_zero = & ((~counter_rd) & counter_wt);           
assign  counter_rd_tmp = counter_rd >> 1;           
assign  ptr_eq_tmp = !(counter_rd_tmp ^ counter_wt);           
assign  full   = counter_rd_zero ? 1'b1 : ptr_eq ? 1'b0 : ptr_eq_tmp;

点赞

发表评论 评论 (2 个评论)

回复 kuaijin_09 2017-7-20 15:20
简单明了,好文章

facelist

您需要登录后才可以评论 登录 | 注册

  • 关注TA
  • 加好友
  • 联系TA
  • 0

    周排名
  • 0

    月排名
  • 0

    总排名
  • 1

    关注
  • 4

    粉丝
  • 0

    好友
  • 0

    获赞
  • 3

    评论
  • 538

    访问数
关闭

站长推荐 上一条 /2 下一条

小黑屋| 关于我们| 联系我们| 在线咨询| 隐私声明| EETOP 创芯网
( 京ICP备:10050787号 京公网安备:11010502037710 )

GMT+8, 2024-4-20 01:47 , Processed in 0.028419 second(s), 16 queries , Gzip On, Redis On.

eetop公众号 创芯大讲堂 创芯人才网
返回顶部