new*_*bie 10 verilog register-transfer-level system-verilog vlsi
我在我的设计中为时钟控制了一些锁存和逻辑.我在合成和布局方面没有太多经验.在RTL中实现时钟门控的正确方法是什么?
例1:
always_comb begin
gated_clk = clk & latch_update_en;
end
always_latch begin
if(gated_clk) begin
latch_data <= new_data;
end
end
Run Code Online (Sandbox Code Playgroud)
例2:在对RTL时钟门控的良好实践进行一些研究时,我偶然发现了一个RTL示例.该示例实现了上面的代码:
clock_gator cg_cell (.clk(clk), .en(latch_update_en), .scan_en(scan_en_in), .gated_clk(gated_clk));
always_latch begin
if(gated_clk) begin
latch_data <= new_data;
end
end
Run Code Online (Sandbox Code Playgroud)
使用自定义时钟门控单元的目的是什么?如果clk在带有另一个使能信号的always_comb块中直接"和"处理,那么该工具是否在合成中有困难时间?我感觉使用特殊时钟门控单元是生成门控时钟信号的标准方法.我试图理解为什么会这样.
Gre*_*reg 12
时钟门控信号应仅在闩锁闭合时切换,否则可能出现毛刺和亚稳态问题.对于有效的高锁存器,门控信号应在时钟的下降沿切换.有源低锁存器的上升沿.
通常情况下,您需要保持边缘敏感的触发器latch_update_en以防止门控信号上的噪声.
always_ff @(negedge clk)
latch_update_en <= next_latch_update_en;
always_comb
gated_clk = (* clock_gating = "clk" *) clk & latch_update_en;
always_latch
if(gated_clk)
latch_data <= new_data;
Run Code Online (Sandbox Code Playgroud)
提醒:如果你只有一个锁存器设计:边沿触发器只是主/从锁存器
always_latch
if (clk)
sync_latch_update_en <= next_latch_update_en;
always_latch
if (!clk)
latch_update_en <= sync_latch_update_en;
Run Code Online (Sandbox Code Playgroud)
大多数综合确实存在直接和时钟相关的问题.如何使用门控并不总是直观的.合成器通常在库中有许多AND门可供选择,每个都有不同的转换,偏斜和加载,非常适合输入组合.虽然功能相同,但A & B会得到不同的时间结果B & A.
从合成器库中实例化显式单元格可以缩小知道和预期行为的可能性.预定义的时钟门控单元还具有合成器使用的属性.属性包括用于平衡时钟树的定时信息(用于管理负载和寄生的设计中的缓冲器放置).
某些合成器支持在RTL中设置属性标记(例如:// synthesis attributes或(* attributes *)),而不需要显式实例化单元格.这里没有标准,请参阅您的用户手册.
自定义单元格是合成库中的每个定义单元格,具有已知的时序信息,负载平衡和其他属性.有了这些信息,合成器就知道在时钟树中添加或校准缓冲延迟的位置和方法.这样可以确保非门控触发器在门控翻转之前没有看到时钟边沿.
_____ _____
IN -------------|D Q|-----|D Q|--- OUT
| | | |
|\ |\ | | | |
+-| >| >---|> | +-|> |
| |/ |/ |_____| | |_____|
| ___ |
CLK -+-| \ |
| & )-------------+ BALANCED CLOCK : correct data sampled
GATE --|___/
Run Code Online (Sandbox Code Playgroud)
没有指导,门控翻牌可能会得到一个延迟的时钟.偏斜会导致错误的数据被采样.
_____ _____
IN -------------|D Q|-----|D Q|--- OUT
| | | |
| | | |
+----------|> | +-|> |
| |_____| | |_____|
| ___ |
CLK -+-| \ |\ |\ |
| & )---| >| >----+ UNBALANCED CLOCK : wrong data sampled
GATE --|___/ |/ |/
Run Code Online (Sandbox Code Playgroud)