Verilog 实现双边沿触发器Dual Edge_triggered_flip Flop
Verilog 实现双边沿触发器Dual Edge_triggered_flip Flop 在做HDLbits时,有一道很有趣的双边沿触发器问题 ,这里记录一下相关内容和解答方式。 问题描述 实现一个双边沿触发器,即在时钟的上升沿和下降沿都被触发。 module top_module ( input clk, input d, output q ); 问题 无法直接通过always @(posedge clk or negedge clk)直接创建双边沿触发器,FPGA 中只能存在单边沿触发器。 但是你可以创建两个触发器,分别是上升沿和下降沿。 解决方案(1) 虽然我们无法直接创建双边沿触发器,但是可以通过使用两个触发器和一个多路选择器实现相同的功能。 module top_module ( input clk, input d, output q ); reg q1; reg q2; always @(posedge clk) begin q1 <= d; end always @(negedge clk) begin q2 <= d; end assign q = clk ? q1 : q2; endmodule 注意,你可能想要两个触发器内都填写q <= d,这在思维上是合理的,但是在实现中会引入多驱问题。 但这又引入了另一个问题:毛刺(glitch)的出现,因为触发器的输出会存在一个延迟。 ...