加入星計劃,您可以享受以下權(quán)益:

  • 創(chuàng)作內(nèi)容快速變現(xiàn)
  • 行業(yè)影響力擴散
  • 作品版權(quán)保護
  • 300W+ 專業(yè)用戶
  • 1.5W+ 優(yōu)質(zhì)創(chuàng)作者
  • 5000+ 長期合作伙伴
立即加入
  • 正文
    • 4.1  task和function說明語句的區(qū)別
  • 相關(guān)推薦
申請入駐 產(chǎn)業(yè)圖譜

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

2013/08/23
加入交流群
掃碼加入
獲取工程師必備禮包
參與熱點資訊討論

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

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

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

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

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

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

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

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

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

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

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

switch_bytes(old_word,new_word);

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

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

new_word = switch_bytes(old_word);

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

相關(guān)推薦

登錄即可解鎖
  • 海量技術(shù)文章
  • 設計資源下載
  • 產(chǎn)業(yè)鏈客戶資源
  • 寫文章/發(fā)需求
立即登錄

華清遠見(www.farsight.com.cn)是國內(nèi)領先嵌入師培訓機構(gòu),2004年注冊于中國北京海淀高科技園區(qū),除北京總部外,上海、深圳、成都、南京、武漢、西安、廣州均有直營分公司。華清遠見除提供嵌入式相關(guān)的長期就業(yè)培訓、短期高端培訓、師資培訓及企業(yè)員工內(nèi)訓等業(yè)務外,其下屬研發(fā)中心還負責嵌入式、Android及物聯(lián)網(wǎng)方向的教學實驗平臺的研發(fā)及培訓教材的出版,截止目前為止已公開出版70余本嵌入式/移動開發(fā)/物聯(lián)網(wǎng)相關(guān)圖書。企業(yè)理念:專業(yè)始于專注 卓識源于遠見。企業(yè)價值觀:做良心教育、做專業(yè)教育,更要做受人尊敬的職業(yè)教育。