Verilog的打印系统函数

上一篇 / 下一篇  2007-06-30 13:19:42 / 天气: 晴朗 / 心情: 高兴 / 个人分类:Backup

Verilog本质上也是一门高级语言,因而也提供了丰富打印信息、输出信息的系统函数。
/n |!nF\A0Verilog提供的打印系统函数分为三类:
+k[@*M Ho WM0显示/写系统函数(Display and Write tasks)EDA中国门户网站x|-l0d$CtG7{m sO
脉冲选择监视系统函数(strobed monitoring tasks)
3s"U{+_!cN5T;g5L'y+U0连续监视系统函数(continuous monitoring tasks)EDA中国门户网站?Z8x0I'{/g)] j$k
显示/写系统函数
)?vu|P~+S(X^8\z0这类函数包括$display、$displayb、$displayo、$displayh、$write、$writeb、$ writeo、$writeh等八个函数。其使用语法如下:
3f S;b8G8z2v1m ^1ag0  系统函数名(变量列表);EDA中国门户网站}oZ;R$d O
变量列表就是需要输出的信息,该变量列表可以是变量名、表达式、双引号括起来的字符串、以及这三种形式的组合。变量列表也可以为空。这时,$display会输出一个回车符(就是开始新的一行),而$write则相当于不进行任何操作。EDA中国门户网站2Qr o)[l|&q6L[i,J
$display系列和$write系列除了一点差别外完全一致,其差异在于$display会在变量列表后面自动增加一个回车符,而$write则没有该功能,完全按照变量列表指示的内容输出。当变量列表为空时,$display输出一个回车符,而$write则相当于不进行任何操作。
/O)fIb9f r'x:{)G z0Verilog的这些打印系统函数的使用同其他高级语言比如C中的打印函数很类似。这些函数支持“格式化输出”,也是在双引号括起来的变量中加入转义符号实现的。对于变量列表中的变量或者常量,当指定了输出格式时,这八个函数没有差别,都将以指定格式输出其值;当没有指定输出格式时,各函数以默认的形式输出该变量或者常量的值。EDA中国门户网站&AA9O)ML5\QE%V
下表给出各个函数默认的输出格式:EDA中国门户网站|F9N!PX)Vn9`Y q ~
系统函数      默认制式      例子(a[7:0]=31)
z~8\+NR FT0$display、$write      十进制      $write(12,” and ”, a[7:0]);EDA中国门户网站jN h-V"H C)?3K\
$displayb、$writeb      二进制      $writeb(12, ” and ”, a[7:0]);EDA中国门户网站nee5? d3B q
$displayo、$writeo      八进制      $writeo(12, ” and ”, a[7:0]);EDA中国门户网站(M)ty1OE^,DI
$displayh、$writeh      十六进制      $writeh(12, ” and ”, a[7:0]);EDA中国门户网站FdzuG@S
“格式化输出”功能需要使用转义符。除了增加部分跟硬件设计相关的转义符外,Verilog的这些系统函数中的转义符同其他高级语言中的定义和使用基本相同。Verilog的转义符分为两大类:以”\\”引导的和以”%”引导的。通常,以”%”引导的转义符用于指定变量列表中的变量、常量、表达式的格式化输出;以”\\”引导的表示其他的一些格式化输出功能,通常是比较“特殊”的功能,比如输出一个“TAB”,或者输出”\\”本身,以及输出”%”本身等。
&mp}!L*xj1w0下表给出了Verilog中基本的转义符定义和意义说明:
f:J5U'W*L(})TC7W#{v0转义符      意义说明
Rj }/~ g)n#m2`0%d 以及 %D      以十进制格式输出
)XA5K&^X[0%b 以及 %B      以二进制格式输出
Z&dJq3U|w0%o 以及 %O      以八进制格式输出
k BMmg e*G h1O0%h 以及 %H      以十六进制格式输出EDA中国门户网站/_~by0r ~!E
%s 以及 %S      以字符串格式输出
1o$x$XR)e$YwD0e0%c 以及 %C      以ASCII码格式输出EDA中国门户网站Tqp#w$D/a.g
%v 以及 %V      输出线网类型变量的强度EDA中国门户网站 f,}3Vit8^(y.\
%m 以及 %M      输出层次名EDA中国门户网站JZRJ"QH7o;I nJ2XM!{
%t 以及 %T      以当前时间格式输出
7M9c#b-jnU/G0%e 以及 %E      以指数表示方式输出实数(real型)
'H7I,t,bo*@(B Sn0%f 以及 %F      以十进制数表示方式输出实数(real型)EDA中国门户网站Nqm1YH
%g 以及 %G      以十进制数或者以指数表示方式输出实数。两种输出格式中,哪种占用更少的宽度,就使用哪一种。
#Tgt l%d6L0\\n      开始新行(“回车”功能)EDA中国门户网站1C*R{c2GtQ3n
\\t      输出一个 TABEDA中国门户网站&n J-J!~ Bp
\\”      输出 ” 本身EDA中国门户网站*|'g4m8B/JrE+{+L
\\\\      输出 \\ 本身EDA中国门户网站wI{NAJ3`&X
%%      输出 % 本身EDA中国门户网站^~1M+u)Gs[ iY
\\xyz      xyz表示一个八进制数。\\xyz表示输出八进制数xyz的值对应的ASCII码符号。比如,”\\123”,应该输出的为符号“S”。
T c,o f w`0例子2-1给出了这些转义符的基本使用:EDA中国门户网站,Dn)Ja"Eomf
// Filename: exe_2_1.v
s+Fkc @]rF0// This module is writen by YiTurn Zhao
%Jq3E2D fT&G'Cd0// Module Purpose : $display 和 $write的基本用法EDA中国门户网站'y#p%NTZI;A)s
module exe_2_1();
%Z y2O c L2v.s x kS5[6A0  //
8`U \xexJ0  reg [7:0] a;  
)Z;]{I?u8r9\LiY0  initial begin  EDA中国门户网站 n g){4iI+b ]
    a = 31;  EDA中国门户网站T s:h7b7ms$K v
    abcd = 50;
+miEL|:Z}0    $display(" Using $display, a = ",a, "   And 12 = ",12);
d:JekjU[ N*y0    $displayb(" Using $displayb, a = ",a, "   And 12 = ",12);
+|[G.LXvh(m0    $displayo(" Using $displayo, a = ",a, "   And 12 = ",12);
NIQy_p0    $displayh(" Using $displayh, a = ",a, "   And 12 = ",12);EDA中国门户网站C9iE.@(B FC6o
    $writeo("\\nUsingFormatted $writeh, a = %d   And 12 = %H",a,12);
B G-t v-ni2C^-Ur0    $writeh(" Using Formatted $writeh, a = %d",a, "   And 12 = %H",12,"\\n");EDA中国门户网站 FmL0S"@-pZ
    $display("Print\\"%%\\",\\t\\"%%%%\\" should be used.");EDA中国门户网站 ^'Pn/yp m@'{1x oR
    $display("Use %%C or %%c: a's value %d %C",a,a);
(fm1o5a$A#{j$S2hY0    $display("Use %%S or %%s: a's value %d %s",a,a);
$U;r1}s-}$\0    $display("Use %%E or %%e: 10000.8 can be writen as %e ",10000.8);EDA中国门户网站'M;Nz9Q)B_^)q
    $display("Use %%F or %%f: 1.023E+8 can be writen as %f ",1.023E+8);EDA中国门户网站BT3lU2P!WHxV] C T
    $display("Use %%G or %%g: 1.023E+8 can be writen as %g ",1.023E+8);EDA中国门户网站i?z6?B4I
    $display("Use\\\\xyz: Character\\101'sASCII value is 3'O101");
wb)UX y7GfAzC0    $display("Use\\\\xyz: Character\\053'sASCII value is 3'O53");EDA中国门户网站z`8dQ9n!I6O`
    #200 $finish;
1yX:\D7N$l;I:`0  end
Y["Lo]_0_0   EDA中国门户网站KSDS(m(w5l!`M erF
endmodule
4X%A0|e }6e&K:vY0注意:1,在verilog中,转义符一定是使用在双引号括起来的字符串中!EDA中国门户网站h4aEC5F"\*VFoeu
2,”\\”和”%”后跟的不是前述指定的符号时,行为跟仿真器的设计有关。比如,“\\N”实现的不是换行功能,但不同仿真器对其解释不同。同样,对于”\\%”、”%\\”等1364-2001标准未规定的格式,不同仿真器也可能进行不同的处理。严格的说,没有规定的转义表达式应该不能使用,比如“\\%”这一形式。一旦使用,应该通不过编译,并报告错误信息。但是通过几个仿真器的仿真发现,通常,”\\%”是允许的,推广之,发现”\\”后跟的如果不是表格中规定的转义符,”\\”将被忽略,而直接输出之后的信息。比如”\\%”就输出”%”符号,”\\N”就输出”N”符号。但是”%\\”是不允许的,推广之,发现”%”后跟的如果不是表格中规定的转义符,将报告错误。
oO4k#iG+?9~6@ w03,除”%%”外,”%”引导的转义符的使用必须和对应的变量、或者表达式匹配使用。对应于某一个转义符的变量为空时,可以用两个”,”将的空格来表示。参见例2-2。EDA中国门户网站 O8O6y|!D\&gy?
4,”%C”、”%S”、”\\xyz”等形式的转义符都跟ASCII码有关。”\\xyz”输出值为八进制数”xyz”的ASCII码,它不需要对应的变量(或者常量)列表。”%C”、”%s”也是输出一个ASCII符号,其值为变量列表中对应的变量、常量或者表达式的值,因此需要在变量列表中提供相应的变量、常量或者表达式。EDA中国门户网站ZVi(aE7FE9Y
   EDA中国门户网站vwR_~.nF}/d
同其他高级语言相比,Verilog提供了几种跟硬件设计相关的特殊输出格式转义符:%v、%m、%t。EDA中国门户网站:hM PQvQN(t|6V
%v用于打印一个线网类型变量的信号强度,它不能打印矢量变量的信号强度,而只能打印标量变量,或者矢量变量的指定位的信号强度。信号强度用3个符号输出表示,前两个符号表示信号强度,而第三个符号表示信号的逻辑值。信号强度和逻辑值的意义分别如下面两个表所示:
'w,KV-vvL;r0F2s4t0信号逻辑值表示:EDA中国门户网站a R:L@H;Y] [}2C
逻辑值      表示意义
%C1G2jFVm{:P?V00      表示逻辑0值EDA中国门户网站"?J'po;E ^A+tCS
1      表示逻辑1值EDA中国门户网站6pV9A6TR
X      表示逻辑不定态EDA中国门户网站{D7do}3sJ&P
Z      表示逻辑高阻态EDA中国门户网站'e!o;Z(L#K'K VI_
L      表示逻辑0值,或者逻辑高阻态
I4Rl9]-xV0H      表示逻辑1值,或者逻辑高阻态EDA中国门户网站9J-Y)Y m2[
信号强度表示:EDA中国门户网站m.^O d~Ql
标记符      强度名      强度值表示
Vld"f/W W/R0Su      电源级驱动(Supply drive)      7EDA中国门户网站'ul3zd Q,e
St      强驱动(Strong drive)             6EDA中国门户网站%OO@s0Bzw
Pu      上拉级驱动(Pull drive)      5
pbq PY(WJ0La      大容性(Large capacitor)      4
$m?$R5N3G;QT0We      弱驱动(Weak drive)             3EDA中国门户网站V#amXq
Me      中级容性(Medium capacitor)      2EDA中国门户网站[&M&R!}RYpnB
Sm      小容性(Small capacitor)      1
,`,Ah-C8jIW0Hi      高容性(High capacitor)      0
TR\lT2B0k ` K0用%v打印一个信号的强度时,前两个符号除了用上表中的信号强度“标志符”表示信号强度外,也可以用两个数字表示信号强度。关于信号强度和逻辑值的建模在后续章节进行详细介绍。
Z$Q"iS,\7vsJo]$nS0使用%m,可以打印当前打印语句所在的模块层次。EDA中国门户网站9Hp-o H'@
%t通常用于打印当前的仿真时间,当然也可以用于打印其他数据。该转义符表示把对应的变量使用当前使用的时间表示格式进行打印。Verilog提供系统函数$time获得当前的仿真时间信息,该系统函数输出值为64比特表示的整数。Verilog还提供系统函数$timeformat用于设定当前的时间格式。关于$time和$timeformat的使用也放在后续章节说明。
U7asN*W&F4r0例2-3为这几个转义符简单使用的一个例子。
2w*c7s Gw2^-{{ X0// Filename: exe_2_3.v
G(x;f}c0Op-j0// This module is writen by YiTurn Zhao
8v VgX#?Q C0// Module Purpose : $display 和 $write的部分特殊功能
5xgp"z2B#]4D7v!X0module exe_2_3();
L&v]F)CzA/F0 EDA中国门户网站*|` VN3Q$x'mZN
  reg [7:0] a;  
5s?n$C z j|0  integer i;
QZv+?%s,f|#\%`0  wire x;
7u"Y AT Q/[a0  pulldown(x);    EDA中国门户网站\xCjX]'z.k
  initial beginEDA中国门户网站.O3X.Vr3_u
    #2;
0{h ? mHv0    $display("%m");  EDA中国门户网站en f,D8T2{V7ty
    $display("Simulation Time now is : %t",$time);EDA中国门户网站P/tNXe;n_
    $display("%%t Usage 2:%t",200);
Hc` Ndi0    $display("x's strength is : %v",x);EDA中国门户网站 w P*BOp C Q
  end
W{.r B)O2P0 
vW U7}5W E0  exe_2_3_sub exe_2_3_sub();EDA中国门户网站{R8eC0^| w/U
   
!v+I7t+E"D2C5J0endmoduleEDA中国门户网站;W+C @9mGl)x7ASo
module exe_2_3_sub;
0b{%[d Y6\@0  wire [1:0] x;EDA中国门户网站T4g W6BR~^
  initial beginEDA中国门户网站`$CI"C"|y Ao
    # 4;
(v"MJ(`Zo!B0    $display("%m");EDA中国门户网站&^H/pb\c
    $display("Simulation Time now is : %t",$time);EDA中国门户网站|Y'B!N_7Qlj5T
    $display("x[1]'s strngth is :%v",x[1]);
3@ya-{z#[]1U&_0  endEDA中国门户网站\vB+@i2Y E
endmodule


TAG: verilog Verilog

 

评分:0

我来说两句

显示全部

:loveliness: :handshake :victory: :funk: :time: :kiss: :call: :hug: :lol :'( :Q :L ;P :$ :P :o :@ :D :( :)

日历

« 2008-09-06  
 123456
78910111213
14151617181920
21222324252627
282930    

数据统计

  • 访问量: 8673
  • 日志数: 96
  • 建立时间: 2006-08-07
  • 更新时间: 2007-06-30

RSS订阅

Open Toolbar