在线咨询
eetop公众号 创芯大讲堂 创芯人才网
切换到宽版

EETOP 创芯网论坛 (原名:电子顶级开发网)

手机号码,快捷登录

手机号码,快捷登录

找回密码

  登录   注册  

快捷导航
搜帖子
查看: 2468|回复: 5

[求助] 编写RTL代码时候有限状态机三段式的问题

[复制链接]
发表于 2017-5-12 09:54:49 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能,让你轻松玩转社区。

您需要 登录 才可以下载或查看,没有账号?注册

x
写RTL代码时候,在三段式FSM中,我看前两段都是一样的,即always @(posedge clk or posedge rst) begin
        if (rst) begin
            // reset
            state <= IDLE;
            next_state <= IDLE;
        end
        else begin
            state <= next_state;
        end
    end   


always @(*)
        case(state)
            IDLE: if (wr ) begin
               next_state = TAG;

   ......

第三段里面case(state),还是case(next_state)?
如果是state的话,我感觉仿真时候波形总是慢一个周期,比如当上升沿到来时候,state变成TAG,那么在下一个上升沿,才会执行state=TAG的内容
如果是next_state的话,虽然在state=TAG的时候,能让输出是state=TAG时候的内容,但是逻辑电路感觉又不像mearly模型,因为状态存储器感觉变成了next_state
发表于 2017-5-26 03:21:27 | 显示全部楼层
一般情况下常用case(state),根据state和其他条件决定next state, next state虽然定义为reg,但实际上是wire。
发表于 2017-5-27 09:18:28 | 显示全部楼层
case(state)
发表于 2017-6-21 16:37:23 | 显示全部楼层
最笨的方法是你两个都试一下,然后仿真一下看一下波形
发表于 2018-8-22 15:24:17 | 显示全部楼层
这个case(state)综合不生成latch
发表于 2018-10-8 15:10:51 | 显示全部楼层
看仿真波形啊
您需要登录后才可以回帖 登录 | 注册

本版积分规则

关闭

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


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

GMT+8, 2024-12-22 20:01 , Processed in 0.017964 second(s), 8 queries , Gzip On, Redis On.

eetop公众号 创芯大讲堂 创芯人才网
快速回复 返回顶部 返回列表