打印

关于verilog forever语句的疑惑

[复制链接]
7172|4
手机看帖
扫描二维码
随时随地手机跟帖
跳转到指定楼层
楼主
congcongfire|  楼主 | 2009-11-2 11:13 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
最近在testbeach中写了一段波形产生的程序,但是编译后出现错误.发现对forever语句的用法不是很明白,不清楚为什么#START_DELAY后面的end一定要放在#LOW_DELAY的后面,因为只有这样编译才正确。我把end放在#START_DELAY的后面就 出错。
我想问下难道forever 语句一定要用在initial或者是always语句中吗?好像书上也没有这方面的要求啊。
谢谢各位大家的解答。。。。。。。
module testbeach_exap(clk_d);
  output reg clk_d;
   
   parameter START_DELAY=5,LOW_TIME=3,HIGH_TIME=2;
      initial
        begin
          clk_d=0;
        #START_DELAY;
        end  
         forever
      begin
       clk_d=1;
    #HIGH_TIME;
       clk_d=0;
     #LOW_TIME;
    end   
  endmodule

相关帖子

沙发
cracker007| | 2009-11-7 04:40 | 只看该作者
forever与always不同,必须写在inital里。

使用特权

评论回复
板凳
congcongfire|  楼主 | 2009-11-9 12:39 | 只看该作者
学习了
明白。。。。。。

使用特权

评论回复
地板
flanix| | 2009-11-24 14:03 | 只看该作者
你要分清楚哪些是测试用的,哪些是能综合的设计的。

使用特权

评论回复
5
ic00| | 2009-12-3 22:26 | 只看该作者
你要明白begin......end 是构成块语句是成对出现的。你可以简单的理解了C语言里的{}类似。如果你在C语言里乱打{},你想一想你要的结果是不是一样的了,还不是要出错。在这里一个道理的。如果不明白,加我的QQ132 159 1335

使用特权

评论回复
发新帖 我要提问
您需要登录后才可以回帖 登录 | 注册

本版积分规则

1

主题

3

帖子

0

粉丝