资源描述:
《Verilog设计内外延时》由会员上传分享,免费在线阅读,更多相关内容在教育资源-天天文库。
1、Verilog语言设计增加延时的正确方法仿真在设计仿真激励文件是,为了满足和外部芯片接口的时序要求,经常会用到延时赋值语句,由于不同的延时赋值语句在仿真过程中行为不同,会产生不同的激励输出,如果不认真区分不同表达式引起的差异,就可能产生错误的激励,无法保证仿真结果的正确,本文就是区分各种延时赋值语句的差异,并给出比较结果。1:阻塞式外延时赋值语句举例说明如下moduleadder_t1(co,sum,a,b,ci);outputco;output[3:0]sum;input[3:0]a,b;inputci;regco;reg[3:0]sum;always@(aorborci)#12{co,su
2、m}=a+b+ci;endmodule分析:上面例子是希望在输入信号变化后12ns再更新输出结果,假设在15ns时a发生变化,在27ns时,结果将被更新,但是如果在15ns到27ns这一段时间,a,b,ci又发生了变化,在27ns时,结果将按照最新的a,b,ci进行计算并被更新,图示如下:如果将程序做如下修改,moduleadder_t7b(co,sum,a,b,ci);outputco;output[3:0]sum;input[3:0]a,b;inputci;regco;reg[3:0]sum;reg[4:0]tmp;always@(aorborci)begintmp=a+b+ci;#12{
3、co,sum}=tmp;endendmodule仿真的结果如下所示:从15ns到27ns之间的变化被忽视。2:阻塞式内延时赋值语句看下面的例子:moduleadder_t6(co,sum,a,b,ci);outputco;output[3:0]sum;input[3:0]a,b;inputci;regco;reg[3:0]sum;always@(aorborci){co,sum}=#12a+b+ci;endmodule它的仿真结果同adder_t7b,在延时12个ns的时间里,不作任何处理。3:非阻塞式外延时赋值语句看例子:moduleadder_t2(co,sum,a,b,ci);outpu
4、tco;output[3:0]sum;input[3:0]a,b;inputci;regco;reg[3:0]sum;always@(aorborci)#12{co,sum}<=a+b+ci;endmodule它的仿真结果同adder_t1,假设在15ns时a发生变化,在27ns时,结果将被更新,但是如果在15ns到27ns这一段时间,a,b,ci又发生了变化,在27ns时,结果将按照最新的a,b,ci进行计算并被更新。4:非阻塞式内延时赋值语句看例子moduleadder_t3(co,sum,a,b,ci);outputco;output[3:0]sum;input[3:0]a,b;inpu
5、tci;regco;reg[3:0]sum;always@(aorborci){co,sum}<=#12a+b+ci;endmodule该例子的输出结果能随时跟踪输入信号的变化。结论:使用非阻塞式内延时赋值语句可以,输出结果能够跟随输入的变化,建议使用,其他三种不建议使用。5:非阻塞式内延时多重赋值语句看例子moduleadder_t9c(co,sum,a,b,ci);outputco;output[3:0]sum;input[3:0]a,b;inputci;regco;reg[3:0]sum;reg[4:0]tmp;always@(aorborciortmp)begintmp<=#12a+b
6、+ci;{co,sum}<=tmp;endendmodule该例子的输出结果和adder_t3相同,但是一定要注意将tmp也要列入敏感变量列表中去。或者使用如下程序,也能得到和adder_t3相同的结果。moduleadder_t9d(co,sum,a,b,ci);outputco;output[3:0]sum;input[3:0]a,b;inputci;regco;reg[3:0]sum;reg[4:0]tmp;always@(aorborciortmp)begintmp<=a+b+ci;{co,sum}<=#12tmp;endendmodule结论:使用非阻塞式右延时多重赋值语句,一定要将
7、内部定义的变量也写到敏感变量表中6:连续赋值语句看例子moduleadder_t4(co,sum,a,b,ci);outputco;output[3:0]sum;input[3:0]a,b;inputci;assign#12{co,sum}=a+b+ci;endmodulemoduleadder_t5(co,sum,a,b,ci);outputco;output[3:0]sum;input[3:0