<meter id="pryje"><nav id="pryje"><delect id="pryje"></delect></nav></meter>
          <label id="pryje"></label>

          新聞中心

          EEPW首頁(yè) > 嵌入式系統(tǒng) > 設(shè)計(jì)應(yīng)用 > 硬件描述語(yǔ)言Verilog HDL設(shè)計(jì)進(jìn)階之: Verilog HDL高級(jí)語(yǔ)法結(jié)構(gòu)—任務(wù)

          硬件描述語(yǔ)言Verilog HDL設(shè)計(jì)進(jìn)階之: Verilog HDL高級(jí)語(yǔ)法結(jié)構(gòu)—任務(wù)

          作者: 時(shí)間:2017-06-05 來(lái)源:網(wǎng)絡(luò) 收藏

          4.2 Verilog HDL高級(jí)語(yǔ)法結(jié)構(gòu)——(TASK)

          本文引用地址:http://www.ex-cimer.com/article/201706/348833.htm


          如果傳給的變量值和完成后接收結(jié)果的變量已定義,就可以用一條語(yǔ)句啟動(dòng)任務(wù)。任務(wù)完成以后控制就傳回啟動(dòng)過(guò)程。如任務(wù)內(nèi)部有定時(shí)控制,則啟動(dòng)的時(shí)間可以與控制返回的時(shí)間不同。
          任務(wù)可以啟動(dòng)其他的任務(wù),其他任務(wù)又可以啟動(dòng)別的任務(wù),可以啟動(dòng)的任務(wù)數(shù)是沒(méi)有限制的。不管有多少任務(wù)啟動(dòng),只有當(dāng)所有的啟動(dòng)任務(wù)完成以后,控制才能返回。


          1.任務(wù)定義
          定義任務(wù)的語(yǔ)法如下:

          任務(wù):
          任務(wù)名>;
          端口及數(shù)據(jù)類(lèi)型聲明語(yǔ)句>
          語(yǔ)句1>
          語(yǔ)句2>
          ...
          語(yǔ)句n>
          end

          這些聲明語(yǔ)句的語(yǔ)法與模塊定義中的對(duì)應(yīng)聲明語(yǔ)句的語(yǔ)法是一致的。


          2.任務(wù)調(diào)用及變量傳遞
          調(diào)用任務(wù)并傳遞輸入/輸出變量的聲明語(yǔ)句的語(yǔ)法如下:

          任務(wù)名>(端口1,端口2,...,端口n);

          下面的例子說(shuō)明怎樣定義任務(wù)和調(diào)用任務(wù)。
          任務(wù)定義如下所示:

          my_task;
          input a, b;
          inout c;
          output d, e;

          語(yǔ)句> //執(zhí)行任務(wù)工作相應(yīng)的語(yǔ)句

          c = foo1; //賦初始值
          d = foo2; //對(duì)任務(wù)的輸出變量賦值
          e = foo3;
          endtask

          任務(wù)調(diào)用如下所示:

          my_task(v,w,x,y,z);

          任務(wù)調(diào)用變量(v、w、x、y、z)和任務(wù)定義的I/O變量(a、b、c、d、e)之間是一一對(duì)應(yīng)的。當(dāng)任務(wù)啟動(dòng)時(shí),由v、w和x傳入的變量賦給了a、b和c。當(dāng)任務(wù)完成后的輸出又通過(guò)c、d和e賦給了x、y和z。下面用一個(gè)具體的例子用來(lái)說(shuō)明怎樣在模塊的設(shè)計(jì)中使用任務(wù),使程序容易讀懂。

          module traffic_lights;
          reg clock, red, amber, green;
          parameter on=1, off=0, red_tics=350,
          amber_tics=30,green_tics=200;
          initial red=off; //交通燈初始化
          initial amber=off;
          initial green=off;

          always begin //交通燈控制時(shí)序
          red=on; //開(kāi)紅燈
          light(red,red_tics); //調(diào)用等待任務(wù)
          green=on; //開(kāi)綠燈
          light(green,green_tics); //等待
          amber=on; //開(kāi)黃燈
          light(amber,amber_tics); //等待
          end

          task light(color,tics); //定義交通燈開(kāi)啟時(shí)間的任務(wù)
          output color;
          input[31:0] tics;
          begin
          repeat(tics) @(posedge clock); //等待tics個(gè)時(shí)鐘的上升沿
          color=off; //關(guān)燈
          end
          endtask

          always begin //產(chǎn)生時(shí)鐘脈沖的always塊
          #100 clock=0;
          #100 clock=1;
          end
          endmodule

          這個(gè)例子描述了一個(gè)簡(jiǎn)單的交通燈的時(shí)序控制,并且該交通燈有它自己的時(shí)鐘產(chǎn)生器。



          關(guān)鍵詞: VerilogHDL 任務(wù) task

          評(píng)論


          相關(guān)推薦

          技術(shù)專(zhuān)區(qū)

          關(guān)閉
          看屁屁www成人影院,亚洲人妻成人图片,亚洲精品成人午夜在线,日韩在线 欧美成人 (function(){ var bp = document.createElement('script'); var curProtocol = window.location.protocol.split(':')[0]; if (curProtocol === 'https') { bp.src = 'https://zz.bdstatic.com/linksubmit/push.js'; } else { bp.src = 'http://push.zhanzhang.baidu.com/push.js'; } var s = document.getElementsByTagName("script")[0]; s.parentNode.insertBefore(bp, s); })();