- 1、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
verilog系统任务之读写文件
verilog系统任务之读写文件1.$fopen打开文件用法1.$fopen(文件名);用法2.文件句柄=$fopen(文件名);注意:用$fopen打开文件会将原来的文件清空,若要读数据就用$readmemb,$readmemh就可以了,这个语句不会清空原来文件中的数据。用$fopen的情况是为了取得句柄,即文件地址,也就是写文件时用$fdisplay(desc,display1);时才用。用法1自然无须多解释,对于用法2,句柄就是任务$fopen返回的多通道描述符,默认为32位,最低位(第0位)默认被设置1,默认开放标准输出通道,即transcript窗口。module disp;integer handle1,handle2,handle3;initialbeginhandle1=$fopen(file1.dat);handle2=$fopen(file2.dat);handle3=$fopen(file3.dat);$display(%h %h %h,handle1,handle2,handle3);endendmodule输出handle1=32‘h0000_0002handle2=32h0000_0004handle3=32h0000_0008即对每一次使用$fopen函数后都打开了一个新的通道,并且返回了一个设置为1的位相对应。默认应该是0001,以上每调用分别设置为0010 ,0100,1000(只考虑最低四位)。这个句柄对我们非常有用,因为在写文件时会用到。2.写文件我们用到系统任务$fdisplay,$fwrite.两者用法相似,前者写完就会自动换行,后者不会换行。用法:$fdisplay(文件描述符(句柄,用于确定是写哪一个文件),p1,p2(写入内容));描述符是很有意思的(默认为32位),如上我们知道,文件句柄最多只能有一个1,但是描述符可以是有多个1,哪一个位上有1,就同时在这些位对应的输出文件上写文件。因此可以同时写多个文件。只考虑后四位情况:1,0001时,只进行在transcript对话框中的输出,2,0101时,即对file2文件写又在transcript框输出、3,1111时,对全部文件写,同时在transcript框输出。由于每个句柄只有一个位置上是1,因此我们想在哪些文件中同时输出我们就可以用以下语句来写desc=handleI | handleK | handleM | handleN | 1(一般与1或,最低位置1再transcript框输出。)一个例子如下:module disp;integer handle1,handle2,handle3;integer desc1,desc2,desc3;initialbeginhandle1=$fopen(file1.dat);handle2=$fopen(file2.dat);handle3=$fopen(file3.dat);$display(%h %h %h,handle1,handle2,handle3);desc1=handle1|1;$fwrite(desc1,display 1);$fmoniter(desc1,display 1);$fstrobe(desc1,display 1);desc2=handle2|handle1|1;$fdisplay(desc2,display 2);desc3=handle3|1;$fdisplay(32d15,display 3);endendmodule$monitor系统任务提供了监控和输出参数列表中的表达式和变量值的功能,其参数列表中输出控制格式字符串和输出表列的规则和$display一样,当启动一个带有一个或多个参数的$monitor任务时,每当参数列表中的变量或表达式的值发生变化时整个参数列表中变量或表达式的值都将输出显示。如果同一时刻有两个或多个表达式的值发生变化,只输出一次。参数可以是$time,用于标明变化时刻。如$monitor ($time,,rxd=%b txd=%b,rxd,txd);这里的“,,”用来表示空格参数在输出时显示为空格$monitor的打开和关闭分别用$monitoron和$monitoroff表示,用来控制任务的启动和停止,使得很容易控制任务何时发生,何时结束。$monitor用于initial块中,只要不调用$monitoroff,该任务就可以不间断的对所设定信号进行监视。例子如下(对一个4位加法计数器counter信号进行监控):`timescale 1ns/1nsmodule moni_test();reg[3:0]counter;reg clk;reg rst;initialbeginrst=0;#10 rst=1;$monitor (
文档评论(0)