看板 Electronics 關於我們 聯絡資訊
※ 引述《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)
karyuuissen:感謝!! 看來很多都要用模擬才能判斷先後了.... 12/30 13:06
zxvc:樓上,這不是一個好做法。 12/30 13:20
zxvc:如果你今天專為某個simulator寫一個design,那很可能把你的 12/30 13:22
zxvc:code拿到另一個simulator就掛了。 12/30 13:22
zxvc:你應該是避開Verilog那些未定義的部分,去寫一個design 12/30 13:24
zxvc:在所有simulator都有一致的結果。 12/30 13:24
zxvc:不只是Verilog有未定義的行為,C/C++也有所謂的未定義的行為 12/30 13:26
zxvc:。sequential block通常就是用來解決這誰先誰後的問題,因為 12/30 13:33
zxvc:它的計算是有順序的。雖然實際的電路是同時運行的,但只要你 12/30 13:36
zxvc:仔細的設計,你可以讓sequential block在每個clock edge所求 12/30 13:39
zxvc:出的值與真實電路一樣。 12/30 13:39
zxvc:所以HDL只是對真實硬體的一種modeling,它不等價真實硬體, 12/30 13:42
zxvc:的所有行為,你可以說它很"像",但就是有不一樣的地方。 12/30 13:43
karyuuissen:可是我現在這個大架構中有很多module和很多不同倍數的 12/30 13:45
karyuuissen:clock,這樣用sequential在真實電路下還會同時運作嗎 12/30 13:46
karyuuissen:就像我問的第2點和第3點那樣@@ 12/30 13:47
zxvc:而Synthesis & Physcial IC Design就是把這些擬真的電路轉成 12/30 13:47
zxvc:真實的電路。 12/30 13:47
zxvc:k大,我想我上面兩句已回答你的問題。 12/30 14:04
zxvc:講坦白的,連simulator本身都是用software去寫的,它本身就是 12/30 14:09
zxvc:sequential去執行的(不談multi-thread)。 12/30 14:10
zxvc:但sequential的simulator卻可以去simulate"同時運行的硬體", 12/30 14:14
zxvc:你說神不神奇?其實也不神奇,simulate中文就是"模擬"的意思 12/30 14:16
zxvc:,不是"完全等價"的意思。 12/30 14:16
karyuuissen:喔喔 了解^^ 12/30 14:37
sneak: 感謝!! 看來很多都 https://muxiv.com 08/13 18:54
sneak: clock,這樣用se https://daxiv.com 09/17 22:49
sneak: 的所有行為,你可以說它 https://muxiv.com 11/11 15:37
sneak: 的所有行為,你可以說它 https://muxiv.com 01/04 22:06