Re: [問題] 一些verilog的問題...

看板Electronics作者 (執著)時間16年前 (2009/12/30 12:44), 編輯推噓2(2027)
留言29則, 3人參與, 7年前最新討論串2/9 (看更多)
※ 引述《karyuuissen ()》之銘言: : 我想先問關於blocking和nonblocking assignment的問題 : 1. 像以下這種2個if的是同時做嗎? : always@(posedge clk) begin : if(condition1) : A <= B; : if(condition2) : C <= D; : end 如果你問的是simulator會先做誰。 答案是第一個if先做。因為begin...end是sequential block。 但真實的電路是同時運作的。 : 2. 兩個一樣的always分開寫是誰先誰後?舉例如下: : always@(posedge clk) begin : A <= B; : end : always@(posedge clk) begin : C <= D; : end 如果是在同一個module,那IEEE 1364無定義。誰先誰後都有可能, 跟你用的simulatior有關。 : 3. 同上一個問題,若分別在不同的.v檔下,但clk是連起來的,如: : //test1.v : always@(posedge clk1) begin : A <= B; : end : --------------------------- : //test2.v : always@(posedge clk2) begin : C <= D; : end : 這樣的話又是誰快? 如果是在不同的module...,我不清楚。 : 如果always裡面同時有blocking又有nonblocking的情況我就更搞不清楚了... : 4. wire的assign和always@(*)分別是等號右邊和判斷式變了就變的 : 那誰會比較先做? : 像是: : assign A= (B==C)? D:E; : 和 : always@(*)begin : B = F; : end 同2.。 : 最後想問有關FPGA合成電路critical path warning的問題... : 要怎樣才能減少這些warning? : 明明一個posedge觸發間if..else和case的層數以及運算都很少了 : 它還是會產生critical path或setup和hold time不夠的情形 我不清楚FPGA的這些問題, 但像SoC Encounter、IC Compiler這些physical IC design的tools 可以作timing optimization降低setup/hold time slack。 但如果setup time slack optimize一直都不過, 可能你的電路就是跑不到這麼快,就只好改架構。 有時候timing violations也可能是testbench寫得不合理。 : 難道只能一直去改code的寫法直到沒有warning為止嗎? : 抱歉問了這麼多問題XD : 因為project的架構太大,時序搞混會讓bug很難找出來.... : Thx -- ※ 發信站: 批踢踢實業坊(ptt.cc) ◆ From: 140.115.71.32 ※ 編輯: zxvc 來自: 140.115.71.32 (12/30 12:45)

12/30 13:06, , 1F
感謝!! 看來很多都要用模擬才能判斷先後了....
12/30 13:06, 1F

12/30 13:20, , 2F
樓上,這不是一個好做法。
12/30 13:20, 2F

12/30 13:22, , 3F
如果你今天專為某個simulator寫一個design,那很可能把你的
12/30 13:22, 3F

12/30 13:22, , 4F
code拿到另一個simulator就掛了。
12/30 13:22, 4F

12/30 13:24, , 5F
你應該是避開Verilog那些未定義的部分,去寫一個design
12/30 13:24, 5F

12/30 13:24, , 6F
在所有simulator都有一致的結果。
12/30 13:24, 6F

12/30 13:26, , 7F
不只是Verilog有未定義的行為,C/C++也有所謂的未定義的行為
12/30 13:26, 7F

12/30 13:33, , 8F
。sequential block通常就是用來解決這誰先誰後的問題,因為
12/30 13:33, 8F

12/30 13:36, , 9F
它的計算是有順序的。雖然實際的電路是同時運行的,但只要你
12/30 13:36, 9F

12/30 13:39, , 10F
仔細的設計,你可以讓sequential block在每個clock edge所求
12/30 13:39, 10F

12/30 13:39, , 11F
出的值與真實電路一樣。
12/30 13:39, 11F

12/30 13:42, , 12F
所以HDL只是對真實硬體的一種modeling,它不等價真實硬體,
12/30 13:42, 12F

12/30 13:43, , 13F
的所有行為,你可以說它很"像",但就是有不一樣的地方。
12/30 13:43, 13F

12/30 13:45, , 14F
可是我現在這個大架構中有很多module和很多不同倍數的
12/30 13:45, 14F

12/30 13:46, , 15F
clock,這樣用sequential在真實電路下還會同時運作嗎
12/30 13:46, 15F

12/30 13:47, , 16F
就像我問的第2點和第3點那樣@@
12/30 13:47, 16F

12/30 13:47, , 17F
而Synthesis & Physcial IC Design就是把這些擬真的電路轉成
12/30 13:47, 17F

12/30 13:47, , 18F
真實的電路。
12/30 13:47, 18F

12/30 14:04, , 19F
k大,我想我上面兩句已回答你的問題。
12/30 14:04, 19F

12/30 14:09, , 20F
講坦白的,連simulator本身都是用software去寫的,它本身就是
12/30 14:09, 20F

12/30 14:10, , 21F
sequential去執行的(不談multi-thread)。
12/30 14:10, 21F

12/30 14:14, , 22F
但sequential的simulator卻可以去simulate"同時運行的硬體",
12/30 14:14, 22F

12/30 14:16, , 23F
你說神不神奇?其實也不神奇,simulate中文就是"模擬"的意思
12/30 14:16, 23F

12/30 14:16, , 24F
,不是"完全等價"的意思。
12/30 14:16, 24F

12/30 14:37, , 25F
喔喔 了解^^
12/30 14:37, 25F

08/13 18:54, , 26F
感謝!! 看來很多都 https://muxiv.com
08/13 18:54, 26F

09/17 22:49, , 27F
clock,這樣用se https://daxiv.com
09/17 22:49, 27F

11/11 15:37, , 28F
的所有行為,你可以說它 https://muxiv.com
11/11 15:37, 28F

01/04 22:06, 7年前 , 29F
的所有行為,你可以說它 https://muxiv.com
01/04 22:06, 29F
文章代碼(AID): #1BEjgZPC (Electronics)
討論串 (同標題文章)
文章代碼(AID): #1BEjgZPC (Electronics)