晓灰灰 发表于 2018-9-27 16:52:07

always block內省略else所代表的電路 (SOC) (Verilog)

Abstract
在Verilog中,always block可以用來代表Flip-Flop, Combination Logic與Latch,本文比較在不寫else下,always block所代表的電路。

Introduction
在C語言裡,省略else只是代表不處理而;已但在Verilog裡,省略else所代表的是不同的電路。

always@(a or b or en)
if (en)
    c = a & b;
在combination logic中省略else,由於必須在~en保留原本的值,所以會產生latch。



always@(posedge clk)
if (en)
    c <= a & b;
雖然也必須在~en保留原本的值,但由於flip-flop就有記憶的功能,所以不會產生latch。if將產生mux,並將flip-flop的值拉回給mux。



Conclusion
在Verilog中,雖然只是小小的差異,但結果卻有天大的差異。

全文完。

晓灰灰 发表于 2018-9-27 16:52:23

always block內省略else所代表的電路 (SOC) (Verilog)

Sunlife 发表于 2018-9-27 18:19:54

                  :)

zhangyukun 发表于 2018-9-28 09:39:50

always block內省略else所代表的電路 (SOC) (Verilog)

晓灰灰 发表于 2018-9-28 14:56:30

always block內省略else所代表的電路 (SOC) (Verilog)

晓灰灰 发表于 2018-10-8 10:42:46

always block內省略else所代表的電路 (SOC) (Verilog)
页: [1]
查看完整版本: always block內省略else所代表的電路 (SOC) (Verilog)