色哟哟视频在线观看-色哟哟视频在线-色哟哟欧美15最新在线-色哟哟免费在线观看-国产l精品国产亚洲区在线观看-国产l精品国产亚洲区久久

0
  • 聊天消息
  • 系統(tǒng)消息
  • 評(píng)論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會(huì)員中心
創(chuàng)作中心

完善資料讓更多小伙伴認(rèn)識(shí)你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

簡(jiǎn)談FPGA verilog中的task用法

FPGA學(xué)習(xí)交流 ? 2018-08-09 18:59 ? 次閱讀

大家好,又到了每日學(xué)習(xí)的時(shí)間了,今天我們來(lái)聊一聊FPGA verilog中的task用法。
任務(wù)就是一段封裝在“task-endtask”之間的程序。任務(wù)是通過(guò)調(diào)用來(lái)執(zhí)行的,而且只有在調(diào)用時(shí)才執(zhí)行,如果定義了任務(wù),但是在整個(gè)過(guò)程中都沒(méi)有調(diào)用它,那么這個(gè)任務(wù)是不會(huì)執(zhí)行的。調(diào)用某個(gè)任務(wù)時(shí)可能需要它處理某些數(shù)據(jù)并返回操作結(jié)果,所以任務(wù)應(yīng)當(dāng)有接收數(shù)據(jù)的輸入端和返回?cái)?shù)據(jù)的輸出端。另外,任務(wù)可以彼此調(diào)用,而且任務(wù)內(nèi)還可以調(diào)用函數(shù)。

1.任務(wù)定義
任務(wù)定義的形式如下:
task task_id;
[declaration]
procedural_statement
endtask

其中,關(guān)鍵詞 task 和 endtask 將它們之間的內(nèi)容標(biāo)志成一個(gè)任務(wù)定義,task 標(biāo)志著一個(gè)任務(wù)定義結(jié)構(gòu)的開(kāi)始;task_id 是任務(wù)名;可選項(xiàng) declaration 是端口聲明語(yǔ)句和變量聲明語(yǔ)句,任務(wù)接收輸入值和返回輸出值就是通過(guò)此處聲明的端口進(jìn)行的;procedural_statement是一段用來(lái)完成這個(gè)任務(wù)操作的過(guò)程語(yǔ)句,如果過(guò)程語(yǔ)句多于一條,應(yīng)將其放在語(yǔ)句塊內(nèi);endtask 為任務(wù)定義結(jié)構(gòu)體結(jié)束標(biāo)志。下面給出一個(gè)任務(wù)定義的實(shí)例。

task task_demo; //任務(wù)定義結(jié)構(gòu)開(kāi)頭,命名為 task_demo
input [7:0] x,y; //輸入端口說(shuō)明
output [7:0] tmp; //輸出端口說(shuō)明

if(x>y) //給出任務(wù)定義的描述語(yǔ)句
tmp = x;
else
tmp = y;

endtask

上述代碼定義了一個(gè)名為“task_demo”的任務(wù),求取兩個(gè)數(shù)的最大值。在定義任務(wù)時(shí),

有下列六點(diǎn)需要注意:
(1)在第一行“task”語(yǔ)句中不能列出端口名稱;
(2)任務(wù)的輸入、輸出端口和雙向端口數(shù)量不受限制,甚至可以沒(méi)有輸入、輸出以及雙向端口。
(3)在任務(wù)定義的描述語(yǔ)句中,可以使用出現(xiàn)不可綜合操作符合語(yǔ)句(使用最為頻繁的就是延遲控制語(yǔ)句) ,但這樣會(huì)造成該任務(wù)不可綜合。
(4)在任務(wù)中可以調(diào)用其他的任務(wù)或函數(shù),也可以調(diào)用自身。
(5)在任務(wù)定義結(jié)構(gòu)內(nèi)不能出現(xiàn) initial和 always過(guò)程塊。
(6)在任務(wù)定義中可以出現(xiàn)“disable 中止語(yǔ)句” ,將中斷正在執(zhí)行的任務(wù),但其是不可綜合的。當(dāng)任務(wù)被中斷后,程序流程將返回到調(diào)用任務(wù)的地方繼續(xù)向下執(zhí)行。

2.任務(wù)調(diào)用
雖然任務(wù)中不能出現(xiàn) initial 語(yǔ)句和 always 語(yǔ)句語(yǔ)句, 但任務(wù)調(diào)用語(yǔ)句可以在 initial 語(yǔ)句和 always 語(yǔ)句中使用,其語(yǔ)法形式如下: task_id[(端口1, 端口 2, ........, 端口 N)]; 其中 task_id是要調(diào)用的任務(wù)名,端口 1、端口 2,…是參數(shù)列表。參數(shù)列表給出傳入任務(wù)的數(shù)據(jù)(進(jìn)入任務(wù)的輸入端)和接收返回結(jié)果的變量(從任務(wù)的輸出端接收返回結(jié)果) 。
任務(wù)調(diào)用語(yǔ)句中,參數(shù)列表的順序必須與任務(wù)定義中的端口聲明順序相同。任務(wù)調(diào)用語(yǔ)句是過(guò)程性語(yǔ)句,所以任務(wù)調(diào)用中接收返回?cái)?shù)據(jù)的變量必須是寄存器類型。下面給出一個(gè)任務(wù)調(diào)用實(shí)例。

例:通過(guò) Verilog HDL 的任務(wù)調(diào)用實(shí)現(xiàn)一個(gè) 4 比特全加器。

module EXAMPLE (A, B, CIN, S, COUT);

input [3:0] A, B;
input CIN;
output [3:0] S;
output COUT;

reg [3:0] S;
reg COUT;
reg [1:0] S0, S1, S2, S3;

task ADD;

input A, B, CIN;
output [1:0] C;

reg [1:0] C;
reg S, COUT;

begin

S = A ^ B ^ CIN;
COUT = (A&B) | (A&CIN) | (B&CIN);
C = {COUT, S};
end
endtask

always @(A or B or CIN) begin
ADD (A[0], B[0], CIN, S0);
ADD (A[1], B[1], S0[1], S1);
ADD (A[2], B[2], S1[1], S2);
ADD (A[3], B[3], S2[1], S3);
S = {S3[0], S2[0], S1[0], S0[0]};
COUT = S3[1];
end
endmodule

在調(diào)用任務(wù)時(shí),需要注意以下幾點(diǎn):
(1)任務(wù)調(diào)用語(yǔ)句只能出現(xiàn)在過(guò)程塊內(nèi);
(2)任務(wù)調(diào)用語(yǔ)句和一條普通的行為描述語(yǔ)句的處理方法一致;
(3)當(dāng)被調(diào)用輸入、輸出或雙向端口時(shí),任務(wù)調(diào)用語(yǔ)句必須包含端口名列表,且信號(hào)端口順序和類型必須和任務(wù)定義結(jié)構(gòu)中的順序和類型一致。需要說(shuō)明的是,任務(wù)的輸出端口必須和寄存器類型的數(shù)據(jù)變量對(duì)應(yīng)。
(4)可綜合任務(wù)只能實(shí)現(xiàn)組合邏輯,也就是說(shuō)調(diào)用可綜合任務(wù)的時(shí)間為“0” 。而在面向仿真的任務(wù)中可以帶有時(shí)序控制,如時(shí)延,因此面向仿真的任務(wù)的調(diào)用時(shí)間不為“0” 。

今天就聊到這里,各位,加油。

聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點(diǎn)僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場(chǎng)。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問(wèn)題,請(qǐng)聯(lián)系本站處理。 舉報(bào)投訴
  • FPGA
    +關(guān)注

    關(guān)注

    1630

    文章

    21796

    瀏覽量

    605177
收藏 人收藏

    評(píng)論

    相關(guān)推薦

    Verilog 測(cè)試平臺(tái)設(shè)計(jì)方法 Verilog FPGA開(kāi)發(fā)指南

    Verilog測(cè)試平臺(tái)設(shè)計(jì)方法是Verilog FPGA開(kāi)發(fā)的重要環(huán)節(jié),它用于驗(yàn)證Verilog設(shè)計(jì)的正確性和性能。以下是一個(gè)詳細(xì)的
    的頭像 發(fā)表于 12-17 09:50 ?382次閱讀

    Verilog vhdl fpga

    相關(guān)專業(yè),具有良好的專業(yè)基礎(chǔ)知識(shí)。 感興趣可滴滴 JYHXDX534 2.工作年限不限,有工作經(jīng)驗(yàn)或優(yōu)秀應(yīng)屆畢業(yè)生亦可。 3.對(duì)FPGA芯片架構(gòu)和資源有深入的理解,精通Verilog HDL、VHDL
    發(fā)表于 11-12 16:40

    Verilog語(yǔ)法運(yùn)算符的用法

    verilog語(yǔ)法中使用以下兩個(gè)運(yùn)算符可以簡(jiǎn)化我們的位選擇代碼。
    的頭像 發(fā)表于 10-25 15:17 ?1219次閱讀
    <b class='flag-5'>Verilog</b>語(yǔ)法<b class='flag-5'>中</b>運(yùn)算符的<b class='flag-5'>用法</b>

    【招聘】verilog vhdl FPGA

    1.熟悉FPGA架構(gòu)及應(yīng)用,熟悉圖像算法的FPGA實(shí)現(xiàn)。 2.熟悉verilog vhdl,熟悉Xilinx或Intel等開(kāi)發(fā)工具。 3.有AI算法 fpga實(shí)現(xiàn)經(jīng)驗(yàn)優(yōu)先。 4.本科及
    發(fā)表于 09-02 15:50

    FPGA設(shè)計(jì) Verilog HDL實(shí)現(xiàn)基本的圖像濾波處理仿真

    今天給大俠帶來(lái)FPGA設(shè)計(jì)中用Verilog HDL實(shí)現(xiàn)基本的圖像濾波處理仿真,話不多說(shuō),上貨。 1、用matlab代碼,準(zhǔn)備好把圖片轉(zhuǎn)化成Vivado Simulator識(shí)別的格式,即每行一
    發(fā)表于 05-20 16:44

    簡(jiǎn)FPGA研發(fā)設(shè)計(jì)相關(guān)規(guī)范(很實(shí)用)

    ,trior,real,disable,forever,arrays,memories,repeat,task,while。 建立可綜合模型的原則 要保證Verilog HDL賦值語(yǔ)句的可綜合性,在建
    發(fā)表于 05-13 15:39

    簡(jiǎn)Xilinx Zynq-7000嵌入式系統(tǒng)設(shè)計(jì)與實(shí)現(xiàn)

    今天給大俠帶來(lái)簡(jiǎn)Xilinx Zynq-7000嵌入式系統(tǒng)設(shè)計(jì)與實(shí)現(xiàn),話不多說(shuō),上貨。 Xilinx的ZYNQ系列FPGA是二種看上去對(duì)立面的思想的融合,ARM處理器的串行執(zhí)行+FP
    發(fā)表于 05-08 16:23

    哪有FPGAverilog編程基礎(chǔ)知識(shí)?

    沒(méi)接觸過(guò)FPGA開(kāi)發(fā),那個(gè)verilog編程有什么入門基礎(chǔ)知識(shí)學(xué)習(xí)的?
    發(fā)表于 04-29 23:09

    簡(jiǎn)FPGA研發(fā)設(shè)計(jì)相關(guān)規(guī)范(很實(shí)用)

    組合邏輯,應(yīng)在敏感信號(hào)列表列出所有的輸入信號(hào)。(8)所有的內(nèi)部寄存器都應(yīng)該能夠被復(fù)位,在使用FPGA實(shí)現(xiàn)設(shè)計(jì)時(shí),應(yīng)盡量使用器件的全局復(fù)位端作為系統(tǒng)總的復(fù)位。(9)對(duì)時(shí)序邏輯描述和建模,應(yīng)盡量使用非阻塞
    發(fā)表于 04-16 15:42

    簡(jiǎn)Xilinx Zynq-7000嵌入式系統(tǒng)設(shè)計(jì)與實(shí)現(xiàn)

    今天給大俠帶來(lái)簡(jiǎn)Xilinx Zynq-7000嵌入式系統(tǒng)設(shè)計(jì)與實(shí)現(xiàn),話不多說(shuō),上貨。 Xilinx的ZYNQ系列FPGA是二種看上去對(duì)立面的思想的融合,ARM處理器的串行執(zhí)行+FP
    發(fā)表于 04-10 16:00

    fpga是用c語(yǔ)言還是verilog

    FPGA(現(xiàn)場(chǎng)可編程邏輯門陣列)開(kāi)發(fā)主要使用的編程語(yǔ)言是硬件描述語(yǔ)言(HDL),其中Verilog是最常用的編程語(yǔ)言之一。而C語(yǔ)言通常用于傳統(tǒng)的軟件編程,與FPGA的硬件編程有所區(qū)別。
    的頭像 發(fā)表于 03-27 14:38 ?2137次閱讀

    verilog inout用法與仿真

    Verilog語(yǔ)言是一種硬件描述語(yǔ)言(HDL),用于描述數(shù)字邏輯電路和系統(tǒng)。它是一種非常強(qiáng)大且廣泛使用的語(yǔ)言,在數(shù)字電路設(shè)計(jì)扮演著重要的角色。其中, inout 是Verilog
    的頭像 發(fā)表于 02-23 10:15 ?3252次閱讀

    verilog task和function區(qū)別

    verilogtask和function都是用于實(shí)現(xiàn)模塊的可重復(fù)的功能,并且可以接收參數(shù)和返回結(jié)果。但是它們?cè)诰帉懞褪褂蒙嫌幸恍﹨^(qū)別。下面將詳細(xì)介紹
    的頭像 發(fā)表于 02-22 15:53 ?1169次閱讀

    verilog function函數(shù)的用法

    Verilog 中被廣泛用于對(duì)電路進(jìn)行模塊化設(shè)計(jì),以簡(jiǎn)化和組織代碼。 本文將詳細(xì)介紹 Verilog 函數(shù)的用法,并探討函數(shù)在硬件設(shè)計(jì)的重要性和實(shí)際應(yīng)用場(chǎng)景。 一.
    的頭像 發(fā)表于 02-22 15:49 ?5997次閱讀

    verilogfunction和task的區(qū)別

    Verilog,F(xiàn)unction和Task是用于模塊化設(shè)計(jì)和重用代碼的兩種重要元素。它們?cè)试S開(kāi)發(fā)人員將復(fù)雜的操作分解為更小的功能單元,并在需要時(shí)調(diào)用它們。雖然Function和Task
    的頭像 發(fā)表于 02-22 15:40 ?1996次閱讀
    主站蜘蛛池模板: 日本老师xxxxx18 | 污文乖不疼的 | 日本漫画之无彩翼漫画 | 果冻传媒剧情在线观看 | 全球真实小U女视频合集 | 纯肉高H种马艳遇风流多 | 在线色av | 伊人久久大香线蕉综合高清 | 成人 迅雷下载 | 亚洲一区电影在线观看 | 台湾佬休闲中性娱乐网 | 亚洲欧美一区二区成人片 | 成年人免费观看的视频 | 9797在线看片亚洲精品 | 中文字幕乱码一区久久麻豆樱花 | xiao77唯美清纯 | 色尼玛亚洲 | 中文中幕无码亚洲在线 | 德国黄色录像 | 妖精视频一区二区免费 | 国产成人综合在线观看 | 国内精品乱码卡一卡2卡三卡新区 | 国产69精品久久久久无码麻豆 | 国产在线中文字幕 | 国产婷婷色综合AV蜜臀AV | 超污视频带污疼免费视频 | 四虎国产精品免费观看视频 | 久久精品亚洲热综合一本 | 日本无码欧美激情在线视频 | 久久这里只有精品视频9 | 法国剧丝袜情版h级在线电影 | 十八禁久久成人一区二区 | 闺蜜撬开我的腿用黄瓜折磨我 | 青青青伊人| 综合人妻久久一区二区精品 | 羞羞答答dc视频 | 国产免费人成在线视频有码 | 国产精品路线1路线2路线 | 99国内精精品久久久久久婷婷 | 亚洲理论片在线中文字幕 | 别停好爽好深好大好舒服视频 |