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

          新聞中心

          EEPW首頁 > 嵌入式系統(tǒng) > 設(shè)計應(yīng)用 > 硬件描述語言Verilog HDL設(shè)計進(jìn)階之:task和function說明語句的區(qū)別

          硬件描述語言Verilog HDL設(shè)計進(jìn)階之:task和function說明語句的區(qū)別

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

          4.1 說明語句的區(qū)別

          說明語句分別用來定義任務(wù)和函數(shù)。利用任務(wù)和函數(shù)可以把一個很大的程序模塊分解成許多較小的任務(wù)和函數(shù)便于理解和調(diào)試。輸入、輸出和總線信號的值可以傳入或傳出任務(wù)和函數(shù)。

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

          任務(wù)和函數(shù)往往是大的程序模塊中在不同地點多次用到的相同的程序段。學(xué)會使用語句可以簡化程序的結(jié)構(gòu),使程序明白易懂,是編寫大型模塊的基本功。

          任務(wù)和函數(shù)有些不同,主要的不同有以下4點。

          (1)函數(shù)只能與主模塊共用同一個仿真時間單位,而任務(wù)可以定義自己的仿真時間單位。

          (2)函數(shù)不能啟動任務(wù),而任務(wù)能啟動其他任務(wù)和函數(shù)。

          (3)函數(shù)至少要有一個輸入變量,而任務(wù)可以沒有或有多個任何類型的變量。

          (4)函數(shù)返回一個值,而任務(wù)則不返回值。

          函數(shù)的目的是通過返回一個值來響應(yīng)輸入信號的值。任務(wù)卻能支持多種目的,能計算多個結(jié)果值,這些結(jié)果值只能通過被調(diào)用的任務(wù)的輸出或總線端口送出。Verilog HDL模塊使用函數(shù)時是把它當(dāng)作表達(dá)式中的操作符,這個操作的結(jié)果值就是這個函數(shù)的返回值。下面讓我們用例子來說明。

          例如,定義一任務(wù)或函數(shù)對一個16位的字進(jìn)行操作讓高字節(jié)與低字節(jié)互換,把它變?yōu)榱硪粋€字(假定這個任務(wù)或函數(shù)名為:switch_bytes)。

          任務(wù)返回的新字是通過輸出端口的變量,16位字的字節(jié)互換任務(wù)的調(diào)用源碼如下:

          switch_bytes(old_word,new_word);

          任務(wù)switch_bytes把輸入old_word的字的高、低字節(jié)互換放入new_word端口輸出。

          而函數(shù)返回的新字是通過函數(shù)本身的返回值,16位字的字節(jié)互換函數(shù)的調(diào)用源碼如下:

          new_word = switch_bytes(old_word);

          下面分別介紹任務(wù)和函數(shù)語句的要點。



          關(guān)鍵詞: VerilogHDL task function

          評論


          相關(guān)推薦

          技術(shù)專區(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); })();