码迷,mamicode.com
首页 > 其他好文 > 详细

verilog task1

时间:2016-03-19 17:54:52      阅读:192      评论:0      收藏:0      [点我收藏+]

标签:

问题描述:

  设计中需要重复多次施加一种激励,每一次激励的施加过程,都可以划分为4个部分,如图所示。

技术分享

  每一次施加的激励只有第二部分的数据有变化(数据格式无变化)。所以顶层的Testbench代码如下:

 1 reg [4:0]    j;
 2     task bian_chen;
 3         begin
 4             for(j=0;j<=27;j=j+1)begin
 5                 initial_task();
 6                 send_weiliu(j);
 7                 latch_weiliu();
 8                 shaolu();
 9             end    
10         end
11     endtask

  第二部分中有90位数据需要发送,首先申明变量存储数据,如下所述:

1     reg [90:0] TDI_REG [0:27];
2     initial begin
3         $readmemb("weiliu.dat",TDI_REG);
4     end

  第二部分数据发送的具体实现,如下所示:

 1  task send_weiliu;
 2         input [4:0] num;
 3         begin
 4             fork
 5                 TCK_gen();
 6                 TDI_weiliu(num);
 7             join
 8         end
 9     endtask
10     
11     task TCK_gen;
12     begin
13         TCK = 1b0;
14         repeat(182) #5 TCK = ~TCK;
15         #5 TCK = 1b0;
16     end
17     endtask
18     
19     reg [6:0] i;
20     task TDI_weiliu;
21         input [4:0] n;    
22         begin
23             for(i=90;i>=0;i=i-1)begin
24                 @(negedge TCK);
25                 TDI = TDI_REG[n][i];
26             end
27         end
28     endtask

说明:

  1)位流数据在时钟上升沿被采样进入编程链寄存器中,所以需要在时钟下降沿处产生好要发送的数据。(见代码24行25行。)

  2)由于编程链是按照D01到D90的顺序串接的,所以最高的D90的位流数据应该最先发送。

  3)由于数据先要在下降沿产生,再在下一个上升沿到来时被采样,所以产生的TCK的数目为182,而非180。同时在TCK的第一次上升延处,由于TDI数据是无效的(还没产生),所以位流文件也要额外的附加一位,位流文件是91位,最高位第91位时无效的。下面通过一个简单时序波形理解这种情形。如下图:

技术分享

                    图2-1

图2-1中,要发送8位数据D8-D1,TCK信号需要翻转2x8+2=18次,第一个上升沿发送无效数据,第一个下降沿处,产生数据D8。

仿真结果:

技术分享

上图所示,为多28次数据发送过程的仿真波形图。

技术分享

上图所示,为多每一次数据发送过程的仿真波形图。

总结:

1.用verilog 写Testbench时,本文介绍的,数据的发送过程中TDI、TCk的产生方式值得借鉴。如在模拟键盘的时钟与数据时可以用到。

  fork
    TCK_gen();
    TDI_weiliu(num);
   join

2.熟悉了for 循环处理重复性工作的用法,特别是语法。


 

verilog task1

标签:

原文地址:http://www.cnblogs.com/littleMa/p/5295567.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!