搜索
bottom↓
回复: 6

verilog三段式状态机不好使求助各位前辈指点

[复制链接]

出0入0汤圆

发表于 2011-12-6 09:38:32 | 显示全部楼层 |阅读模式
哪位能帮我看看,这个三段式状态机怎么不好使?COUNTER不是在每个时钟上升沿加,是自己在里面连续的加,和CLK都没关系了,这个是怎么回事,是我哪里写错了么
module testchabu2(clk1,pwmout,start,reset);
input clk1,start,reset;
output pwmout;
reg pwmout;
reg[1:0]        StepOfPWMSend_P,StepOfPWMSend_N;
reg[3:0]        JVX;
reg[3:0]        JRX;
reg[3:0]        Counter;
parameter        [3:0]        ADDTotal=4'B1000;
//************************************************
parameter        [1:0]
PWMSEND_IDLE=2'B00,          PWMSEND_S1=2'B01,
PWMSEND_S2=2'B10,        PWMSEND_S3=2'B11;
//**********************************************************************
always @(posedge clk1 or negedge reset)
   if(!reset)
      StepOfPWMSend_P<=PWMSEND_IDLE;
   else
      StepOfPWMSend_P<=StepOfPWMSend_N;
//*******************************************************
always @(StepOfPWMSend_P)
   begin
      StepOfPWMSend_N=PWMSEND_IDLE;
      case(StepOfPWMSend_P)
      PWMSEND_IDLE:begin
         if(start)
            begin JVX=5;JRX=0;Counter=0;StepOfPWMSend_N=PWMSEND_S1;end
         else
            begin JVX=5;JRX=0;Counter=0;StepOfPWMSend_N=PWMSEND_IDLE;end
         end
      PWMSEND_S1:begin
         if(Counter>=ADDTotal)
            begin
               Counter=0;StepOfPWMSend_N=PWMSEND_IDLE;       
            end
         else
            begin
               Counter=Counter+1;JRX=JVX+JRX;
               if(JRX>=8)// or JRX<=-8)
                  begin
                     JRX=JRX-8;StepOfPWMSend_N=PWMSEND_S2;       
                  end
               else
                   begin
                     StepOfPWMSend_N=PWMSEND_S3;
                   end
            end
          end
      PWMSEND_S2:StepOfPWMSend_N=PWMSEND_S1;
      PWMSEND_S3:StepOfPWMSend_N=PWMSEND_S1;       
      endcase
   end
   //************************************************************
   always @(posedge clk1 or negedge reset)
      if(!reset)
         pwmout<=0;
      else
         begin
            pwmout<=0;
            case(StepOfPWMSend_N)
            PWMSEND_IDLE:pwmout<=0;
            PWMSEND_S1:pwmout<=0;
            PWMSEND_S2:pwmout<=1;
            PWMSEND_S3:pwmout<=0;
            endcase
         end
endmodule

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

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

出0入0汤圆

 楼主| 发表于 2011-12-6 11:32:25 | 显示全部楼层
回复【楼主位】jessie9940509
-----------------------------------------------------------------------

怎么看了这么多,没有一个留言的,就没有一个帮忙么?

出0入0汤圆

发表于 2011-12-6 11:38:09 | 显示全部楼层
什么语言啊?VHDL?

出0入0汤圆

 楼主| 发表于 2011-12-6 11:39:30 | 显示全部楼层
回复【2楼】zyw19987
-----------------------------------------------------------------------

verilog的

出0入0汤圆

 楼主| 发表于 2011-12-6 12:32:10 | 显示全部楼层
回复【3楼】jessie9940509
-----------------------------------------------------------------------

为啥看了都不回呢?我都等一上午了,看样是没人管了,5555555555,都不会么??

出0入0汤圆

发表于 2011-12-6 14:16:30 | 显示全部楼层
modelsim仿真找问题

出0入0汤圆

发表于 2011-12-8 09:16:17 | 显示全部楼层
always @(StepOfPWMSend_P)
   begin
      StepOfPWMSend_N=PWMSEND_IDLE;
      
      case(StepOfPWMSend_P)
      PWMSEND_IDLE:begin


这里的"StepOfPWMSend_N=PWMSEND_IDLE; "是什么意思??
  它好像始终在做初始化!!!
回帖提示: 反政府言论将被立即封锁ID 在按“提交”前,请自问一下:我这样表达会给举报吗,会给自己惹麻烦吗? 另外:尽量不要使用Mark、顶等没有意义的回复。不得大量使用大字体和彩色字。【本论坛不允许直接上传手机拍摄图片,浪费大家下载带宽和论坛服务器空间,请压缩后(图片小于1兆)才上传。压缩方法可以在微信里面发给自己(不要勾选“原图),然后下载,就能得到压缩后的图片。注意:要连续压缩2次才能满足要求!!】。另外,手机版只能上传图片,要上传附件需要切换到电脑版(不需要使用电脑,手机上切换到电脑版就行,页面底部)。
您需要登录后才可以回帖 登录 | 注册

本版积分规则

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

GMT+8, 2024-7-24 11:16

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

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