搜索
bottom↓
回复: 2

一个状态机程序老报错

[复制链接]

出0入0汤圆

发表于 2011-8-29 23:50:24 | 显示全部楼层 |阅读模式
小弟不才,用三段输出锁存式状态机 写一个序列检测程序,检测101序列。我的状态可能有冗余,暂时不要关心这些~我想问的是,为什么报错,程序如下

module sq_scan (
                                input dat,clk,rst_n,
                                output  reg led);
        parameter S0 = 4'b 0001,
                  S1 = 4'b 0010,
                  S2 = 4'b 0100,
                  S3 = 4'b 1000;
        reg [3:0] state,next;
       
always @(posedge clk or negedge rst_n)
                if (!rst_n) state <= S0 ;
                else                state <= next;

always @(state or dat)begin  /Error (10028): Can't resolve multiple constant drivers for net "led" at sq_scan.v(14)
                next = 4'bx;
                led  = 1'b0;
                case(state)
                 S0: if(dat)          next = S1;
                         else      next = S0;
                       S1: if(dat)          next = S1;
                         else        next = S2;
                 S2: if(dat)          next = S3;
                         else      next = S0;
                 S3: if(dat)          next = S1;
                                  else     next = S2;
        endcase
end
always @(posedge clk or negedge rst_n)
                if (!rst_n) begin
                   led <= 1'b0;
                end
                else begin
                case (next)
                        S0,S1,S2: led <= 1'b0 ;
                        S3      : led <= 1'b1;
                endcase
                end
endmodule

程序老是报错,错误已经标注在报错行的后面了。可是我觉得那句always就应该把涉及状态转变的变量都作为敏感变量啊?请大侠指点一二

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

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

出0入0汤圆

发表于 2011-8-30 06:42:06 | 显示全部楼层
两个always里都放了
led <= 1'b0;
这个是不允许的

估计LZ可能应该吧
always @(state or dat)中的句子给删了

PS:编译器已经说的非常明白了,led不能多处同时赋值

出0入0汤圆

 楼主| 发表于 2011-8-30 09:01:12 | 显示全部楼层
回复【1楼】syuanwang  昙花公公
-----------------------------------------------------------------------

正解!!!多谢多谢。3 always 块状态机,状态转移的那个逻辑里不能出现输出~~~和2 always块搞混了~
回帖提示: 反政府言论将被立即封锁ID 在按“提交”前,请自问一下:我这样表达会给举报吗,会给自己惹麻烦吗? 另外:尽量不要使用Mark、顶等没有意义的回复。不得大量使用大字体和彩色字。【本论坛不允许直接上传手机拍摄图片,浪费大家下载带宽和论坛服务器空间,请压缩后(图片小于1兆)才上传。压缩方法可以在微信里面发给自己(不要勾选“原图),然后下载,就能得到压缩后的图片。注意:要连续压缩2次才能满足要求!!】。另外,手机版只能上传图片,要上传附件需要切换到电脑版(不需要使用电脑,手机上切换到电脑版就行,页面底部)。
您需要登录后才可以回帖 登录 | 注册

本版积分规则

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

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

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

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