為什麼這篇Verilog for 迴圈鄉民發文收入到精華區:因為在Verilog for 迴圈這個討論話題中,有許多相關的文章在討論,這篇最有參考價值!作者bw51 (路人甲)看板Electronics標題[問題] verilog for loop?時...
問題:
由於需要access大量的資料,需要使用 for loop
for loop 使用 synchronous reset 寫法可以 synthesis
而使用 asynchronous reset 寫法無法 synthesis
如何改寫 asynchronous reset的寫法讓他可以合成(必須使用asynchronous flip-flop)
input [63:0] data_in [8191:0];
reg[63:0]data[8191:0];
Synchronous reset:
always_ff@(posedge clk)
for(i=0;i<8192;i=i+1)
if(!rst_n)
data[i] <= 0;
else if(en)
data[i] <= data_in;
Asynchronous reset:
always_ff@(posedge clk or negedge rst_n)
for(i=0;i<8192;i=i+1)
if(!rst_n)
data[i] <= 0;
else if(en)
data[i] <= data_in[i];
--
※ 發信站: 批踢踢實業坊(ptt.cc), 來自: 118.160.196.206
※ 文章網址: http://www.ptt.cc/bbs/Electronics/M.1404744412.A.D83.html
※ 編輯: bw51 (118.160.196.206), 07/07/2014 22:49:22
Asynchronous reset:
always_ff@(posedge clk or negedge rst_n)
if(!rst_n)
for(i=0;i<8192;i=i+1)
begin
data[i] <= 0;
end
else if(en)
for(i=0;i<8192;i=i+1)
begin
data[i] <= data_in[i];
end
※ 編輯: bw51 (118.160.196.206), 07/08/2014 20:12:03