你知道Verilog HDL程式是如何構成的嗎

来源:https://www.cnblogs.com/cniot/archive/2019/12/30/12121458.html
-Advertisement-
Play Games

本節通過硬體描述語言Verilog HDL對二十進位編碼器的描述,介紹Verilog HDL程式的基本結構及特點。 二十進位編碼器及Verilog HDL描述 二十進位編碼器是數字電路中常用的電路單元,它的輸入是代表0~9這10個輸入端的狀態信息。輸入信號為高電平時,輸出相應的BCD碼,因此也稱為1 ...


本節通過硬體描述語言Verilog HDL對二十進位編碼器的描述,介紹Verilog HDL程式的基本結構及特點。

二十進位編碼器及Verilog HDL描述

二十進位編碼器是數字電路中常用的電路單元,它的輸入是代表0~9這10個輸入端的狀態信息。輸入信號為高電平時,輸出相應的BCD碼,因此也稱為10線4線編碼器。其功能表及電路符號如圖3-1所示。

 

圖3-1 二十進位編碼器

【例3-1】利用Verilog HDL對二十進位編碼器進行設計。

 

Verilog HDL程式的基本構成

從例3-1可以看出,一個完整的Verilog HDL程式由3個基本部分構成,分別是:模塊埠定義部分、信號類型說明部分和邏輯功能描述語句部分。其結構圖如3-2所示。

 

圖3-2 Verilog HDL程式基本結構

模塊埠定義部分

對於硬體描述語言來說,一個程式代表了一個具有某種邏輯功能的電路,模塊埠定義部分描述了該電路的介面部分的信息,即輸入輸出信號的信息。

模塊埠定義部分的語法結構如下:

module模塊名(埠信號1,埠信號2,埠信號3,埠信號4,……);

input[width:0]埠信號1,埠信號3,……;

output[width:0]埠信號2,埠信號4,……;

程式以關鍵詞module引導,模塊名是設計者對於設計的電路所取的名字,在模塊埠定義的第1行列出了所有進出該電路模塊的埠信號,在第2行和第3行中定義了各埠信號流動方向。流動方向包括輸入(input)、輸出(output)和雙向(inout),[width:0]表示信號的位寬,如果位寬沒有特別說明,則系統預設為1位寬度。

【例3-2】模塊埠定義舉例。

 

信號類型說明部分

在Verilog HDL語法中,信號共有兩種數據類型,分別為:網線類型(net型)和寄存器類型(register型)。在信號類型說明部分除了要對輸入/輸出埠的信號類型進行說明之外,還要對程式中定義的中間量的數據類型進行說明。

信號類型說明部分的語法結構如下:

wire[width:0]信號1,信號2,……;

reg[width:0]信號3,信號4,……;

【例3-3】信號類型說明舉例。

 

 

 

邏輯功能描述語句部分

邏輯功能描述語句部分對輸入/輸出信號之間的邏輯關係進行了描述,是Verilog HDL程式設計中最主要的部分,在電路上相當於器件的內部電路結構。在Verilog HDL語言中,常用的邏輯功能描述語句可以分為以下3種:

例化語句:調用已進行元件化封裝的程式。這種語句常應用於層次化設計的頂層文件設計中。

【例3-4】例化語句舉例。

 

該語句分別調用了一個非門和與門電路模塊。

連續賦值語句:描述信號之間簡單的賦值關係。在連續賦值語句中,右邊表達式使用的操作數無論何時發生變化,右邊表達式都重新計算。這類描述通常以關鍵詞assign引導。

【例3-5】連續賦值語句舉例。

 

該語句描述了輸出信號與輸入信號的賦值關係。

過程語句:以關鍵詞always、initial等關鍵詞引導的語句,描述了一定條件下信號之間的賦值關係。這種變數數據被賦值後,其值保持不變,直到下一次條件具備時對它們重新賦值。

【例3-6】過程語句舉例。

 

與連續賦值語句一樣,always和initial也描述了輸出信號與輸入信號的賦值關係,但是這種賦值往往是一種比較複雜的條件賦值,例如,例3-6就用了if……else語句描述了輸出信號與輸入信號的條件關係。

 

本文轉自小平頭電子技術社區:https://www.xiaopingtou.cn/article-104211.html 嵌入式,物聯網,硬體PCB,電子技術盡在小平頭


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

-Advertisement-
Play Games
更多相關文章
  • 場景 Dubbo環境搭建-管理控制台dubbo-admin實現服務監控: https://blog.csdn.net/BADAO_LIUMANG_QIZHI/article/details/103624846 Dubbo搭建HelloWorld-搭建服務提供者與服務消費者並完成遠程調用(附代碼下載) ...
  • 本系列筆記主要基於《深入理解Java虛擬機:JVM高級特性與最佳實踐 第2版》,是這本書的讀書筆記。 在 Java 虛擬機記憶體區域中,除了程式計數器外,其他幾個記憶體區域都可能會發生OutOfMemoryError,這次通過一些代碼來驗證虛擬機各個記憶體區域存儲的內容。 在實際工作中遇到記憶體溢出異常時, ...
  • 一、add 將傳進來的參數添加到原來的值上面。這個過濾器會嘗試將“值”和“參數”轉換成整形然後進行相加。如果轉換成整形過程中失敗了,那麼將會將“值”和“參數”進行拼接。如果是字元串,那麼會拼接成字元串,如果是列表,那麼會拼接成一個列表。實例代碼如下: {{ value|add:"2"}} 如果val ...
  • Composer 是新一代的PHP依賴管理工具。本文介紹使用Composer的五個小技巧,希望能給你的PHP開髮帶來方便。 1. 僅更新單個庫 只想更新某個特定的庫,不想更新它的所有依賴,很簡單 composer update foo/bar 此外,這個技巧還可以用來解決“警告信息問題”。你一定見過 ...
  • 本篇文章主要介紹了PHP組件、框架以及Composer,具有一定的學習價值,感興趣的朋友可以瞭解一下。 什麼是組件 組件是一組打包的代碼,是一系列相關的類、介面和Trait,用於幫助我們解決PHP應用中某個具體問題。例如,你的PHP應用需要收發HTTP請求,可以使用現成的組件如guzzle/guzz ...
  • Composer是一個非常流行的PHP包依賴管理工具,已經取代PEAR包管理器,對於PHP開發者來說掌握Composer是必須的. 對於使用者來說Composer非常的簡單,通過簡單的一條命令將需要的代碼包下載到vendor目錄下,然後開發者就可以引入包並使用了. 其中的關鍵在於你項目定義的comp ...
  • 原先在《演算法競賽入門經典》看過這題,當時沒想出來選擇百度。結果洛谷再次跳出來了。很尷尬,忘了做題方法的我繼續百度。重做了一遍,很慚愧 1 #include <stdio.h> 2 #include <string.h> 3 int main(void) 4 { 5 int a, b; 6 int s ...
  • 【編寫程式,輸人一個大於2的自然數,然後輸出小於該數字的所有素數組成的列表。】所謂素數,是指除了1和自身之外沒有其他因數的自然數,最小的素數是2,後面依次是3、5、7、11、13... c++代碼: #include<iostream> #include<bits/stdc++.h> #define ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...