免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 1092 | 回复: 0
打印 上一主题 下一主题

verilog 状态机设计的例子 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2011-12-21 08:41 |只看该作者 |倒序浏览

//状态机设计的例子

module FSM(clk,clr,out,start,step2,step3);
input clk,clr,start,step2,step3;
output[2:0] out;
reg[2:0] out;
reg[1:0] state,next_state;
 
parameter   state0=2'b00,state1=2'b01,
state2=2'b11,state3=2'b10;

always @(posedge clk or posedge clr)    
begin
   if (clr) state <= state0;
   else state <= next_state;

end
 
always @(state or start or step2 or step3)    
begin    
case (state)
   state0: begin
     if (start)  next_state <=state1;
     else       next_state <=state0;
     end
   state1: begin
           next_state <= state2;
     end
   state2: begin
     if (step2)  next_state <=state3;
     else       next_state <=state0;
     end
   state3: begin
     if (step3)  next_state <=state0;
     else       next_state <=state3;
     end
   default:    next_state <=state0;  
 endcase
end
 
always @(state)         
begin
case(state)
     state0: out=3'b001;
     state1: out=3'b010;
     state2: out=3'b100;
     state3: out=3'b111;
     default:out=3'b001;    
endcase
end
 

您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP