新聞中心

        EEPW首頁 > 嵌入式系統 > 設計應用 > 硬件描述語言Verilog HDL設計進階之:task和function說明語句的區別

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

        作者: 時間:2017-06-05 來源:網絡 收藏

        4.1 說明語句的區別

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

        本文引用地址:http://www.104case.com/article/201706/348834.htm

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

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

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

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

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

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

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

        例如,定義一任務或函數對一個16位的字進行操作讓高字節與低字節互換,把它變為另一個字(假定這個任務或函數名為:switch_bytes)。

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

        switch_bytes(old_word,new_word);

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

        而函數返回的新字是通過函數本身的返回值,16位字的字節互換函數的調用源碼如下:

        new_word = switch_bytes(old_word);

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



        關鍵詞: VerilogHDL task function

        評論


        相關推薦

        技術專區

        關閉
        主站蜘蛛池模板: 任丘市| 山阴县| 玛多县| 永兴县| 新干县| 仙游县| 滦平县| 天水市| 城口县| 新巴尔虎左旗| 临夏市| 普陀区| 南汇区| 郑州市| 邹城市| 南丹县| 吉首市| 新野县| 灵山县| 民县| 长子县| 阿图什市| 新源县| 永福县| 安阳市| 丹江口市| 白沙| 油尖旺区| 通道| 德州市| 大名县| 兴城市| 陕西省| 桃江县| 涞水县| 汨罗市| 怀来县| 平舆县| 得荣县| 读书| 巨野县|