作者gecer (gecer)
看板Electronics
標題[問題] Dual edge triggered flip flop
時間Mon Nov 4 19:54:22 2019
https://hdlbits.01xz.net/wiki/Dualedge
在hdlbits上dual edge flip flop 小弟code 如下
module top_module (
input clk,
input d,
output q
);
wire invert_clk;
assign invert_clk=~clk;
always@(posedge clk or posedge invert_clk) begin
q<=d;
end
endmodule
但是得到的結果如下圖 好像是 assign q=d 不用clock 觸發
https://imgur.com/2ErzdfZ
已知解答是下列code 但是小弟不能理解為什麼上面code無法有flip flop的效果
module top_module (
input clk,
input d,
output q
);
reg q1, q2;
assign q = clk?q1:q2;
always @ (posedge clk)
begin
q1 <= d;
end
always @ (negedge clk)
begin
q2 <= d;
end
endmodule
--
※ 發信站: 批踢踢實業坊(ptt.cc), 來自: 122.121.18.119 (臺灣)
※ 文章網址: https://webptt.com/m.aspx?n=bbs/Electronics/M.1572868466.A.CCD.html
※ 編輯: gecer (122.121.18.119 臺灣), 11/04/2019 19:56:00
1F:→ samm3320: 你沒有宣告q為reg,預設是wire所以就接一起了 11/04 21:35
2F:→ samm3320: dual edge trigger物理上需要兩個dff跟一個mux實現 11/04 21:47
3F:→ samm3320: 下面的code寫法會比較合理 11/04 21:48
module top_module (
input clk,
input d,
output reg q
);
wire invert_clk;
assign invert_clk=~clk;
always@(posedge clk or posedge invert_clk) begin
q<=d;
end
endmodule
我把q用 reg 宣告後 仍然是
https://imgur.com/2ErzdfZ
似乎只有下面的code可呈現 dual edge trigger
※ 編輯: gecer (122.121.18.119 臺灣), 11/05/2019 08:35:17
4F:→ samm3320: 主要是你的code對電路來說不知道怎麼實現,要看tool怎 11/05 09:22
5F:→ samm3320: 麼理解你的code,目前看來他不知道怎麼辦就直接接起來 11/05 09:22
6F:推 tkhan: 有雙向的flip-flop嗎?數位不及格 11/05 13:29
一樣的code 我用 icarus verilog 模擬 便出現 flip flop 的功能
https://imgur.com/a/E0Fcusc
跟samm3320 大大說得符合 端看tool理解code的方式
※ 編輯: gecer (122.121.18.119 臺灣), 11/05/2019 19:43:31
※ 編輯: gecer (122.121.18.119 臺灣), 11/05/2019 19:44:15
7F:推 tkhan: 硬體描述語言,你真的懂硬體嗎?.. 11/05 19:57
8F:→ samm3320: 不過你的寫法不符合硬體的原理,建議你還是建立良好的 11/05 21:38
9F:→ samm3320: 習慣讓code跟硬體連結,比較不會出事。 11/05 21:38