Verilog——任務task的調用

来源:https://www.cnblogs.com/BMer-ICer/archive/2022/10/03/16751576.html
-Advertisement-
Play Games

參考自以下鏈接處:http://t.csdn.cn/4ws4t 下麵直接看代碼,代碼中會有註意事項。 `timescale 1ns/10ps module traffic_lights ; reg clk ; reg red ; reg amber ; reg green ; //產生時鐘脈衝的al ...


參考自以下鏈接處:
http://t.csdn.cn/4ws4t

下麵直接看代碼,代碼中會有註意事項。

`timescale 1ns/10ps

module  traffic_lights  ;

reg             clk         ;
reg             red         ;
reg             amber       ;
reg             green       ;

//產生時鐘脈衝的always塊
always #10  clk = ~clk;

parameter  on  = 1  ; 
parameter  off = 0  ; 
            
//定義交通燈開啟時間的任務
task light;//task<任務名>
    input  [31:0] tics;
    output reg color;//<埠及數據類型聲明語句>,建議先輸入後輸出

begin
    repeat(tics) @(posedge clk);//等待tics個時鐘的上升沿
    color=off;//關燈
end

endtask

//交通燈初始化
initial red=off;
initial amber=off;
initial green=off;
//交通燈控制時序
always begin
    red=on; //開紅燈
    light('d350,red); //調用等待任務,
                      //(1)括弧中信號順序與task聲明的信號順序一致;
                      //(2)不能是參數類型的數據,比如你放的是parameter定義的數據就不行;
                      //(3)既然是調用,就是調用其中的邏輯功能,使用的信號都需要是module下定義的,而不是用task中定義的的color。
    green=on; //開綠燈
    light('d300,green); //等待
    amber=on; //開黃燈
    light('d200,amber); //等待
end

endmodule

此代碼沒法模擬出波形,只是簡單的例子而已。

task與funtion還是蠻重要的知識點,下麵從我喜歡的視角簡單總結一下二者的內容和區別:

(1)先從Verilog定義二者的寫法開始,task的定義中直接加任務名稱,中間不會有位寬的聲明;而function畢竟就是函數,邏輯上使用函數一般就是賦值操作,賦值就要考慮位寬,所以function的定義中會加個位寬範圍,如果不寫就預設是1bit。

(2)寫到了下麵一部分,對於二者都是《埠及數據類型聲明語句》,但是function只能有input輸入變數,task則沒這個限制,可以有input、output、inout;

(3)下一部分則一定要用“begin  end”來寫,這裡就是實實在在的二者想實現的邏輯功能語句了,其中task想怎麼寫怎麼寫,可以有時延符號,也可以純組合邏輯;但是function就只能是純組合邏輯,不能加時延類型的符號。所以funciton可以綜合。

(4)endtask、endfunction不能忘寫。

從中文字眼來看,也知道任務是高級一點、包容一點的東西,所以一般可以理解函數是任務的子集,任務可以調用函數,函數不能反過來調用任務的。

但是怎麼寫,怎麼用,還是得多練,多編譯,多模擬。

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 淺學Vue 引入 <script src="https://cdn.jsdelivr.net/npm/[email protected]/dist/vue.js"></script> Hello Vue <!DOCTYPE html> <html> <head> <meta charset="utf-8"> <s ...
  • ES6 部分 Typescript 部分 前端工程面經(節流防抖、https、前端攻擊、性能優化...) https://juejin.cn/post/6844903734464495623 ES6面試(點擊可展開) 為什麼選擇 ES6 ? ES6是新一代的 JS 語言標準,規範了JS的使用標準(v ...
  • CDN
    一、CDN的概念 概念:CDN(Content Delivery Network)是指一種通過互聯網互相連接的電腦網路系統,利用最靠近每位用戶的伺服器,更快、更可靠地將音樂、圖片、視頻、應用程式及其他文件發送給用戶,來提供高性能、可擴展性及低成本的網路內容傳遞給用戶。 即內容分髮網絡。 二、CDN的 ...
  • 有時需要在view頁面設置標簽的狀態為disabled,但是客戶反映radio button和checkbox的顏色很淺,難以識別,尤其是列印後,如下: 可以使用下麵的css更改原有的樣式input[type= "radio" ]:checked:disabled { appearance: non ...
  • 背景: 這兩天看了一個視頻,介紹什麼是C/S,什麼是B/S,總覺得很奇怪。裡面說到只要是app的,都是client-server,而網頁端,如h5網站,web網站,小程式等都是brower-server架構。感覺這種劃分非常“反直覺”,因為現在的軟體都是多端,連接在“同一個”伺服器下為使用者提供網路 ...
  • 一篇文章帶你掌握主流基礎框架——Spring 這篇文章中我們將會介紹Spring的框架以及本體內容,包括核心容器,註解開發,AOP以及事務等內容 那麼簡單說明一下Spring的必要性: Spring技術是JavaEE開發的必備技能,企業開發技術選型率高達90%! Spring可以幫助簡化開發,降低企 ...
  • 一、背景 使用django3 進行開發時,由於項目前端頁面使用iframe框架,瀏覽器錯誤提示信息如下 Refused to display 'http://127.0.0.1:8000/' in a frame because it set 'X-Frame-Options' to 'deny'. ...
  • 事務是資料庫操作最基本的單元,是邏輯上的一組操作,這一組操作在同一個會話中要麼都執行成功,要麼都失敗,這也是事務的最基本特性--原子性。事務的作用是為了保證系統數據的正確性,因此,資料庫應用程式中是會經常用到事務。下麵就說一下在Spring里怎麼做事務操作。 Spring事務使用方式 Spring事 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...