Re: [問題] 一些verilog的問題...
※ 引述《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
12/30 13:22, 3F
→
12/30 13:22, , 4F
12/30 13:22, 4F
→
12/30 13:24, , 5F
12/30 13:24, 5F
→
12/30 13:24, , 6F
12/30 13:24, 6F
→
12/30 13:26, , 7F
12/30 13:26, 7F
→
12/30 13:33, , 8F
12/30 13:33, 8F
→
12/30 13:36, , 9F
12/30 13:36, 9F
→
12/30 13:39, , 10F
12/30 13:39, 10F
→
12/30 13:39, , 11F
12/30 13:39, 11F
→
12/30 13:42, , 12F
12/30 13:42, 12F
→
12/30 13:43, , 13F
12/30 13:43, 13F
→
12/30 13:45, , 14F
12/30 13:45, 14F
→
12/30 13:46, , 15F
12/30 13:46, 15F
→
12/30 13:47, , 16F
12/30 13:47, 16F
→
12/30 13:47, , 17F
12/30 13:47, 17F
→
12/30 13:47, , 18F
12/30 13:47, 18F
→
12/30 14:04, , 19F
12/30 14:04, 19F
→
12/30 14:09, , 20F
12/30 14:09, 20F
→
12/30 14:10, , 21F
12/30 14:10, 21F
→
12/30 14:14, , 22F
12/30 14:14, 22F
→
12/30 14:16, , 23F
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
08/13 18:54, 26F
→
09/17 22:49, , 27F
09/17 22:49, 27F
→
11/11 15:37, , 28F
11/11 15:37, 28F
→
01/04 22:06,
7年前
, 29F
01/04 22:06, 29F
討論串 (同標題文章)