时序构成的测试平台
时钟信号的产生
在任何类型的设计中,最重要的信号是时钟信号。把信号电平按照规定的时间间隔反相,就可以产生时钟信号,这是最简单时钟信号发生器。
任何信号的默认值为“x”。若只是把某个信号按照规定的时间间隔反相,将把“x”值反相。下面的代码不能产生时钟信号的原因就在于此;按照这个代码,时钟信号将永远为不定态“x”。
assign #10ps clock = ~clock;
发生错误的原因是忘记设置时钟信号的初始值。只要添加设置时钟初始值语句,就可以解决这个问题:
initial clock = '0;
assign #10ps clock = ~clock;
**最好把每个信号初始值的设置和发生编写在一个过程块中。**举例说明如下:
initial
beginclock = '0;forever #10ps clock = ~clock;
end
下面的例子描述了时钟频率和占空比都是参数的时钟信号发生器。请注意以下两点:
1)指定的时间精度为时间单位的1/10。
2)时钟频率(frequency)和时钟信号维持高电平的时间(markperiod)用实型数表示。
必须满足这两个条件,仿真过程才能正确地执行。
如果频率被指定为整数,时钟信号维持高电平的时间被指定为45%,那么由于参数值取整产生的误差,生成了周期为9ns的时钟,其中高电平维持4ns,低电平维持5ns。
module clockgen;timeunit 1ns;
timeprecision100