1.always@后面內容是敏感變量,always@(*)里面的敏感變量為*,意思是說敏感變量由綜合器根據always里面的輸入變量自動添加,也就是所有變量都是敏感列表,不用自己考慮。2.如果沒有@,那就是不會滿足特定條件才執行,而是執行完一次后立馬執行下一次,一直重復執行,比如testbench里面產生50Mhz的時鐘就(假設時間尺度是1ns)可以寫成
always #25 CLK_50Mhz = ~CLK_50Mhz;
一般always@(*)是指里面的語句是組合邏輯的。*代替了敏感變量。
而一般時序邏輯要寫成
always@(posedge clk or negedge rst)
時鐘信號clk上升沿或者復位信號rst下降沿的時候執行always塊內的代碼。
assign 用于描述組合邏輯always@(敏感事件列表) 用于描述時序邏輯敏感事件 上升沿 posedge,下降沿 negedge,或電平敏感事件列表中可以包含多個敏感事件,但不可以同時包括電平敏感事件和邊沿敏感事件,也不可以同時包括同一個信號的上升沿和下降沿,這兩個事件可以合并為一個電平敏感事件。在新的verilog2001中“,”和“or”都可以用來分割敏感事件了,可以用“*”代表所有輸入信號,這可以防止遺漏。合法的寫法:
always@ *
always@ (posedge clk1,negedge clk2)
always@ (a or b)
所有的assign 和 always 塊都是并行發生的!并行塊、順序塊將要并行執行的語句寫在`timescale 100ns/100ns //定義仿真基本周期為100ns
always #1 clk=~clk //#1代表一個仿真周期即100ns
將要順序執行的語句寫在fork
//語句并行執行
join
并行塊和順序塊都可以寫在initial 或 always@ 之后,也就是說寫在塊中的語句是時序邏輯的對assign之后不能加塊,實現組合邏輯只能用逐句的使用assign組合邏輯如果不考慮門的延時的話當然可以理解為瞬時執行的,因此沒有并行和順序之分,并行和順序是針對時序邏輯來說的。值得注意的是所有的時序塊都是并行執行的。initial塊只在信號進入模塊后執行1次而always塊是由敏感事件作為中斷來觸發執行的。begin
//語句順序執行
end
2:assign 組合邏輯和always@(*)組合邏輯verilog描述組合邏輯一般常用的有兩種:assign賦值語句和always@(*)語句。兩者之間的差別有: 1. 被assign賦值的信號定義為wire型,被always@(*)結構塊下的信號定義為reg型,值得注意的是,這里的reg并不是一個真正的觸發器,只有敏感列表為上升沿觸發的寫法才會綜合為觸發器,在仿真時才具有觸發器的特性。 2. 另外一個區別則是更細微的差別:舉個例子,
在這種情況下,做仿真時a將會正常為0, 但是b卻是不定態。這是為什么?verilog規定,always@(*)中的*是指該always塊內的所有輸入信號的變化為敏感列表,也就是仿真時只有當always@(*)塊內的輸入信號產生變化,該塊內描述的信號才會產生變化,而像always@(*) b = 1'b0;這種寫法由于1'b0一直沒有變化,所以b的信號狀態一直沒有改變,由于b是組合邏輯輸出,所以復位時沒有明確的值(不定態),而又因為always@(*)塊內沒有敏感信號變化,因此b的信號狀態一直保持為不定態。事實上該語句的綜合結果有可能跟assign一樣(本人沒有去嘗試),但是在功能仿真時就差之千里了。wire a;
reg b;
assign a = 1'b0;
always@(*)
b = 1'b0;
聲明:本文內容及配圖由入駐作者撰寫或者入駐合作網站授權轉載。文章觀點僅代表作者本人,不代表電子發燒友網立場。文章及其配圖僅供工程師學習之用,如有內容侵權或者其他違規問題,請聯系本站處理。
舉報投訴
-
電平
+關注
關注
5文章
361瀏覽量
40013 -
組合邏輯
+關注
關注
0文章
47瀏覽量
10073 -
代碼
+關注
關注
30文章
4828瀏覽量
69064
原文標題:Verilog 里面,always,assign和always@(*)區別
文章出處:【微信號:zhuyandz,微信公眾號:FPGA之家】歡迎添加關注!文章轉載請注明出處。
發布評論請先 登錄
相關推薦
明德揚點撥FPGA高手進階 第五章 verilog快速掌握---5.3 組合邏輯
Verilog的程序代碼,組合邏輯的代碼結構如下:always@(*) begin代碼語句;end或者是assign 代碼語句;代碼中@后是敏感列表,當括號內的條件滿足時,就執行一次。
發表于 11-21 09:23
【技巧分享】時序邏輯和組合邏輯的區別和使用
根據邏輯電路的不同特點,數字電路分為組合邏輯和時序邏輯,明德揚粉絲里的同學提出,無法正確區分,今天讓我跟一起來學習一下兩種邏輯的
發表于 03-01 19:50
在FPGA中何時用組合邏輯或時序邏輯
必須要用組合邏輯或者時序邏輯?例如:在verilog中,在always中被賦值了就必須是reg類型,assign賦值了就必須是wire類型。
發表于 03-06 16:31
組合邏輯電路的分析與設計-邏輯代數
組合邏輯電路的分析與設計-邏輯代數
在任何時刻,輸出狀態只決定于同一時刻各輸入狀態的組合,而與先前狀態無關的邏輯電路稱為
發表于 04-07 10:07
?3275次閱讀
![<b class='flag-5'>組合</b><b class='flag-5'>邏輯</b>電路的分析與設計-<b class='flag-5'>邏輯</b>代數](https://file1.elecfans.com//web2/M00/A4/B5/wKgZomUMNV-AT_H1AAALUYcb8Go756.gif)
組合邏輯電路的設計
組合邏輯電路的設計
組合邏輯電路的設計與分析過程相反,其步驟大致如下: (1)根據對電路邏輯功能的要求,列出真值表; (2)由真值表寫
發表于 04-07 10:12
?1.3w次閱讀
![<b class='flag-5'>組合</b><b class='flag-5'>邏輯</b>電路的設計](https://file1.elecfans.com//web2/M00/A4/B6/wKgZomUMNV-ACFoMAAAgA68FnIc070.gif)
FPGA中組合邏輯和時序邏輯的區別
數字電路根據邏輯功能的不同特點,可以分成兩大類,一類叫組合邏輯電路(簡稱組合電路),另一類叫做時序邏輯電路(簡稱時序電路)。
發表于 11-20 12:26
?8895次閱讀
你們知道always,assign和always@(*)之間的區別嗎
@,那就是不會滿足特定條件才執行,而是執行完一次后立馬執行下一次,一直重復執行,比如testbench里面產生50Mhz的時鐘就(假設時間尺度是1ns)可以寫成 always #25 CLK_50Mhz = ~CLK_50Mhz; 一般always@(*)是指里面的語句是
組合邏輯電路和時序邏輯電路的區別和聯系
,與電路原來的狀態無關。而時序邏輯電路在邏輯功能上的特點是任意時刻的輸出不僅取決于當時的輸入信號,而且還取決于電路原來的狀態,或者說,還與以前的輸入有關。下面小編給大家介紹一下“組合邏輯
![<b class='flag-5'>組合</b><b class='flag-5'>邏輯</b>電路和時序<b class='flag-5'>邏輯</b>電路的<b class='flag-5'>區別</b>和聯系](https://file.elecfans.com//web2/M00/98/8B/pYYBAGQQOSqAVA6NAACVUJcYAZg590.jpg)
assign語句和always語句的用法
Assign語句和Always語句是在硬件描述語言(HDL)中常用的兩種語句,用于對數字電路建模和設計。Assign語句用于連續賦值,而Always語句用于時序
評論