溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

verilog中的task和funtion

發(fā)布時間:2020-10-21 17:29:24 來源:網(wǎng)絡(luò) 閱讀:2797 作者:lihaichuan 欄目:開發(fā)技術(shù)

 

任務(wù)和函數(shù)主要有以下一些不同:
(1)函數(shù)只能與主模塊共用一個仿真單位時間,而任務(wù)可以定義自己的仿真時間單位。
(2)函數(shù)不能啟動任務(wù),可以啟動其它函數(shù)。而任務(wù)可以啟動其他任務(wù)和函數(shù)。
(3)函數(shù)至少有一個輸入變量(不能有inout或out)等,而任務(wù)可以沒有或有任意個(輸入或輸出變量)。
(4)函數(shù)返回一個值,而任務(wù)不返回值。
函數(shù)的目的是通過返回一個值來響應(yīng)輸入信號的值。任務(wù)卻能支持多種目的,能計算多個結(jié)果值,這些值只能通過被調(diào)用的任務(wù)的輸出或總線端口送出。
任務(wù)不可綜合,函數(shù)可綜合。
函數(shù)的使用規(guī)則:
(1)函數(shù)的定義不能包含有任何的時間控制語句,即任何用#,@,wait來標(biāo)識的語句。
(2)函數(shù)不能啟動任務(wù)。
(3)定義函數(shù)至少有一個輸入變量。
(4)在函數(shù)的定義中必須有一條賦值語句給函數(shù)中的一個內(nèi)部變量賦以函數(shù)的結(jié)果值,該內(nèi)部變量具有和函數(shù)名相同的名字。
1、函數(shù)和任務(wù)都要用begin和end。
如:task light;
              output color; //聲明端口順序,任務(wù)調(diào)用時也要按這個順序?qū)?yīng)
              input [31:0] tics;
              begin   
                            #(10*tics) color=off; //函數(shù)體只有一句,begin和end可有可無
              end
       endtask
       task light;
              output color;
              input [31:0] tics;
              begin   
                            #(10*tics); color=off; //函數(shù)體有兩句(以上),begin和end必須有
              end
       endtask
2、上述任務(wù)可寫成這樣,把端口聲明寫成這樣。
       task light(output color,input [31:0] tics);
              begin   
                            #(10*tics); color=off; //函數(shù)體有兩句(以上),begin和end必須有
              end
       endtask
向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI