搜索
bottom↓
回复: 8

verilog case语句似乎构成了锁存器?

[复制链接]

出0入0汤圆

发表于 2011-7-9 11:50:41 | 显示全部楼层 |阅读模式
代码如下:
parameter SYS_IDLE = 'd0;
parameter WR_VEC = 'd1;
parameter WR_VEC_S1 = 'd2;
parameter WR_VEC_S2 = 'd3;

reg[3:0] sys_cs,sys_ns;
reg last,current;  //启动状态机标志
reg wr,cs;
reg[6:0] timeoutcount;
input wr_ack;

case(sys_cs)
        SYS_IDLE:
            begin
                if(last!=current)
                begin
                    sys_cs <= sys_ns;
                    last <= current;
                end
                else
                    sys_cs <= SYS_IDLE;
                wr <= 1;
                cs <= 0;
            end
        WR_VEC://
            begin
                data <= {databuf2,databuf1,databuf0};
                sys_cs <= WR_VEC_S1;
                cs <= 1;
                wr <= 0;
            end
        WR_VEC_S1://
            begin
                sys_cs <= WR_VEC_S2;
                timeoutcount <= 0;
            end
        WR_VEC_S2:
            begin
                cs <= 0;
                //问题出在这个if判断;本意是要接受到wr_ack 高电平才推出的
                if(wr_ack)
                begin
                    sys_cs <= SYS_IDLE;
                    wr <= 1;
                end
                else
                begin
                    if(timeoutcount > 100)
                    begin
                        sys_cs <= SYS_IDLE;
                        wr <= 1;
                        timeoutcount <= 0;
                    end
                    else
                    begin
                        wr <= 0;
                        sys_cs <= WR_VEC_S2;
                        timeoutcount <= timeoutcount +1'b1;
                    end
                end
            end

经波形仿真发现第四个状态里面只要有判断wr_ack状态,状态机就乱了,sys_cs出现未知知,不知道是不是程序有什么问题啊!
望高手解答!

阿莫论坛20周年了!感谢大家的支持与爱护!!

知道什么是神吗?其实神本来也是人,只不过神做了人做不到的事情 所以才成了神。 (头文字D, 杜汶泽)

出0入0汤圆

发表于 2011-7-9 11:51:44 | 显示全部楼层
你这种写法,自然就是latch

出0入0汤圆

发表于 2011-7-9 13:27:23 | 显示全部楼层
default?

出0入0汤圆

发表于 2011-7-9 15:49:02 | 显示全部楼层
在电平敏感的“进程”中,
或者把所有可能的case 列全了 或者使用default 就避免出现LATCH

出0入0汤圆

 楼主| 发表于 2011-7-10 16:24:55 | 显示全部楼层
不好意思,后面有default,没拷贝全,后面掉了两句
parameter SYS_IDLE = 'd0;  
parameter WR_VEC = 'd1;
parameter WR_VEC_S1 = 'd2;
parameter WR_VEC_S2 = 'd3;

reg[3:0] sys_cs,sys_ns;
reg last,current;  //启动状态机标志
reg wr,cs;
reg[6:0] timeoutcount;
input wr_ack;

case(sys_cs)
        SYS_IDLE:
            begin
                if(last!=current)
                begin
                    sys_cs <= sys_ns;
                    last <= current;
                end
                else
                    sys_cs <= SYS_IDLE;
                wr <= 1;
                cs <= 0;
            end
        WR_VEC://
            begin
                data <= {databuf2,databuf1,databuf0};
                sys_cs <= WR_VEC_S1;
                cs <= 1;
                wr <= 0;
            end
        WR_VEC_S1://
            begin
                sys_cs <= WR_VEC_S2;
                timeoutcount <= 0;
            end
        WR_VEC_S2:
            begin
                cs <= 0;
                //问题出在这个if判断;本意是要接受到wr_ack 高电平才推出的
                if(wr_ack)
                begin
                    sys_cs <= SYS_IDLE;
                    wr <= 1;
                end
                else
                begin
                    if(timeoutcount > 100)
                    begin
                        sys_cs <= SYS_IDLE;
                        wr <= 1;
                        timeoutcount <= 0;
                    end
                    else
                    begin
                        wr <= 0;
                        sys_cs <= WR_VEC_S2;
                        timeoutcount <= timeoutcount +1'b1;
                    end
                end
            end

       default:sys_cs <= SYS_IDLE;
endcase

出0入0汤圆

发表于 2011-7-10 17:33:39 | 显示全部楼层
if判断,接受到wr_ack 高电平才推出的,这种方法咋觉得这不靠谱那,边沿触发不可以嘛

出0入0汤圆

发表于 2011-7-10 22:38:32 | 显示全部楼层
多点看看综合出来的rtl或者map图。这样会比问人可能还更有效果。

出0入0汤圆

发表于 2011-7-14 13:10:41 | 显示全部楼层
这种写法还是锁存器,需要在default中对变量赋值X,综合器就不考虑了

出0入0汤圆

发表于 2011-7-16 09:32:57 | 显示全部楼层
用时序逻辑来搞应该会好看点吧
回帖提示: 反政府言论将被立即封锁ID 在按“提交”前,请自问一下:我这样表达会给举报吗,会给自己惹麻烦吗? 另外:尽量不要使用Mark、顶等没有意义的回复。不得大量使用大字体和彩色字。【本论坛不允许直接上传手机拍摄图片,浪费大家下载带宽和论坛服务器空间,请压缩后(图片小于1兆)才上传。压缩方法可以在微信里面发给自己(不要勾选“原图),然后下载,就能得到压缩后的图片。注意:要连续压缩2次才能满足要求!!】。另外,手机版只能上传图片,要上传附件需要切换到电脑版(不需要使用电脑,手机上切换到电脑版就行,页面底部)。
您需要登录后才可以回帖 登录 | 注册

本版积分规则

手机版|Archiver|amobbs.com 阿莫电子技术论坛 ( 粤ICP备2022115958号, 版权所有:东莞阿莫电子贸易商行 创办于2004年 (公安交互式论坛备案:44190002001997 ) )

GMT+8, 2024-7-24 13:19

© Since 2004 www.amobbs.com, 原www.ourdev.cn, 原www.ouravr.com

快速回复 返回顶部 返回列表