Verilog的打印系统函数
上一篇 / 下一篇 2007-06-30 13:19:42 / 天气: 晴朗 / 心情: 高兴 / 个人分类:Backup
Verilog本质上也是一门高级语言,因而也提供了丰富打印信息、输出信息的系统函数。
/n|!nF\A0Verilog提供的打印系统函数分为三类:
+k[@*M HoWM0显示/写系统函数(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等八个函数。其使用语法如下:
3fS;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\Q E%V
下表给出各个函数默认的输出格式:EDA中国门户网站|F9N!PX)Vn9`Yq~
系统函数 默认制式 例子(a[7:0]=31)
z~8\+NRFT0$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中基本的转义符定义和意义说明: