網站首頁 編程語言 正文
關于reg和logic的區別,在SystemVerilog驗證測試平臺編寫指南中有所提出,如下所示:
SystemVerilog對經典的reg數據類型進行了改進,使得他除了作為一個變量以外,還可以被連續賦值、門單元和模塊所驅動。為了與寄存器類型相區別,這種改進的數據類型稱為logic。任何使用線網的地方均可以使用logic,但是要求logic不能有多個結構性的驅動,例如在對雙向總線建模的時候,此時,需要使用線網類型,例如wire,SystemVerilog會對多個數據來源解析后確定最終值。
logic數據類型的使用:
module logic_data_type(input logic rst_h);
parameter CYCLE=20;
logic q, q_l, d, clk, rst_l;
initial begin
clk = 0; //過程賦值
forever #(CYCLE/2) clk = ~clk;
end
assign rst_l = ~rst_h; //連續賦值
not n1(q_l, q); //q_l被門驅動
my_diff(q, d, clk, rst_l); //q被模塊驅動
endmodule
由于logic類型只能有一個驅動,所以你可以使用它來查找網單中的漏洞。把你所有的信號都聲明為logic而不是reg或wire,如果存在多個驅動,那么編譯時就會出現錯誤。當然,有些信號你本來就希望有多個驅動,例如雙向總線,這些信號就需要被定義成線網類型,例如wire。
verilog中對reg類型的解釋如下:
寄存器是數據存儲單元的抽象。寄存器數據類型的關鍵字是reg。通過賦值語句可以改變寄存器儲存的值,其作用于改變觸發器儲存的值相當。
reg型數據常用來表示always模塊內指定信號,常代表觸發器。通常在設計中要由always模塊通過使用行為描述語句來表達邏輯關系。在always模塊內被賦值的每一個信號都必須定義成reg型。
原文鏈接:https://blog.csdn.net/Michael177/article/details/125711023
相關推薦
- 2022-10-18 Python?numpy下幾種fft函數的使用方式_python
- 2022-05-04 配置Spring.Net框架開發環境_實用技巧
- 2022-06-26 Android如何使用圓形揭露動畫巧妙地隱藏或顯示View詳解_Android
- 2022-03-03 text-overflow:ellipsis,當對象內文本溢出時顯示省略標記(...)
- 2022-02-06 pecl 安裝出現No releases available for package 解決方案
- 2022-04-09 node sass下載失敗解決方案
- 2022-07-03 kali安裝docker及搭建漏洞環境的詳細教程_docker
- 2022-12-11 C語言冷知識之預處理字符串操作符詳解_C 語言
- 最近更新
-
- window11 系統安裝 yarn
- 超詳細win安裝深度學習環境2025年最新版(
- Linux 中運行的top命令 怎么退出?
- MySQL 中decimal 的用法? 存儲小
- get 、set 、toString 方法的使
- @Resource和 @Autowired注解
- Java基礎操作-- 運算符,流程控制 Flo
- 1. Int 和Integer 的區別,Jav
- spring @retryable不生效的一種
- Spring Security之認證信息的處理
- Spring Security之認證過濾器
- Spring Security概述快速入門
- Spring Security之配置體系
- 【SpringBoot】SpringCache
- Spring Security之基于方法配置權
- redisson分布式鎖中waittime的設
- maven:解決release錯誤:Artif
- restTemplate使用總結
- Spring Security之安全異常處理
- MybatisPlus優雅實現加密?
- Spring ioc容器與Bean的生命周期。
- 【探索SpringCloud】服務發現-Nac
- Spring Security之基于HttpR
- Redis 底層數據結構-簡單動態字符串(SD
- arthas操作spring被代理目標對象命令
- Spring中的單例模式應用詳解
- 聊聊消息隊列,發送消息的4種方式
- bootspring第三方資源配置管理
- GIT同步修改后的遠程分支