VIVADO 综合属性 ASYNC_REG = “TRUE“

本文深入探讨了ASYNC_REG属性在跨时钟域数据同步中的应用,解释了它如何帮助在时序违例时输出已知值,避免不定态传播。文章还详细介绍了该属性在综合过程中的影响,包括对寄存器优化、布局和MTBF提升的作用。

非原创 ,从知乎转载过来的 ,转载地址

https://zhuanlan.zhihu.com/p/36790736

ASYNC_REG属性一般用于跨时钟域的数据同步上,该属性指定:寄存器可以接受异步数据或者该寄存器是一个位于同步链上的同步寄存器。

在仿真过程中,当发生时序违例时,寄存器默认行为会输出X或不定态,从而进可能在多个路径上传输不定态。ASYNC_REG能够使得在发生时许违例时输出上次已知值。

在附加了ASYNCREG属性后,在综合的过程中将不会优化该寄存器及其周边逻辑,同时也影响optimization,place&routing以提高MTBF(mean time between failure)。在布局时,将会确保同步链上的寄存器摆放尽可能接近一最大化MTBF,直接相连的带有该属性的寄存器将会直接放进单个SLICE/CLB(如果寄存器同时带有ASYNC_REG和IOB属性,IOB将优先于ASYNC_REG,寄存器将会被存放至ILOGIC block)。

如下例所示,,sync_0,sync_1将会被放至同一个SLICE/CLB内:

(*ASYNC_REG="TRUE"*)reg sync_0,sync_1;
always @(posedge clk)
begin
sync_1<=sync_0;
sync_0<=en;

其电路图及布局图分别如下图所示:

综合电路图

布局图

属性原语:

verilog:

(* ASYNC_REG = "{TRUE|FALSE}" *)

Verilog Syntax Example

// Designates sync_regs as receiving asynchronous data

(* ASYNC_REG = "TRUE" *) reg [2:0] sync_regs;

XDC Syntax

set_property ASYNC_REG value [getcells <instance_name>]

Where

• <instance_name> is a register cell.

XDC Syntax Example

# Designates sync_regs as receiving asynchronous data

set_property ASYNC_REG TRUE [get_cells sync_regs*]

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值