xilinx Vivado工具使用技巧

时间:2025-06-15  作者:Diven  阅读:0

综合属性

xilinx Vivado工具使用技巧

在Vivado Design Suite中,Vivado综合能够合成多种类型的属性。在大多数情况下,这些属性具有相同的语法和相同的行为。

•如果Vivado综合支持该属性,将使用该属性,并创建反映已使用属性的逻辑。

•如果工具无法识别指定的属性,则Vivado综合会将属性及其值传递给生成的网表。

1.ASYNC_REG

ASYNC_REG是影响Vivado工具流中许多进程的属性。此属性的目的是通知工具寄存器能够在D输入引脚中接收相对于源时钟的异步数据,或者该寄存器是同步链中的同步寄存器。

当遇到此属性时,Vivado综合会将其视为DONT_TOUCH属性,并在网表中向前推送ASYNC_REG属性。此过程可确保具有ASYNC_REG属性的对象未进行优化,并且流程中稍后的工具会接收属性以正确处理。

您可以将此属性放在任何寄存器上; 值为FALSE(默认值)和TRUE。可以在RTL或XDC中设置此属性。

ASYNC_REG Verilog Example:

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

2.CLOCK_BUFFER_TYPE

在输入时钟上应用CLOCK_BUFFER_TYPE以描述要使用的时钟缓冲器类型。

默认情况下,Vivado综合使用BUFG作为时钟缓冲器。支持的值是“BUFG”,“BUFH”,“BUFIO”,“BUFMR”,“BUFR”或“无”。 CLOCK_BUFFER_TYPE属性可以放在任何顶级时钟端口上。可以在RTL和XDC中设置。

CLOCK_BUFFER_TYPE Verilog Example

(* clock_buffer_type = “none”*) input clk1;

CLOCK_BUFFER_TYPE XDC Example

set_property CLOCK_BUFFER_TYPEBUFG [get_ports clk]

3. FSM_ENCODING

FSM_ENCODING控制状态机上的编码。通常,Vivado工具会根据最适合大多数设计的启发式方法为状态机选择编码协议。某些设计类型使用特定的编码协议可以更好地工作

FSM_ENCODING可以放在状态机寄存器上。其合法价值是“one_hot”,“sequential”,“johnson”,“grey”,“auto”和“none”。 “auto”值是默认值,允许工具确定最佳编码。可以在RTL或XDC中设置此属性。

FSM_ENCODING Example (Verilog)

(* fsm_encoding = “one_hot” *)reg [7:0] my_state;

4. KEEP

使用KEEP属性可防止信号优化或被吸收到逻辑块中的优化。此属性指示综合工具保持其所处的信号,并将该信号放入网表中。

例如,如果信号是2位AND门的输出,并且驱动另一个AND门,则KEEP属性可用于防止该信号合并到包含两个AND门的较大LUT中。

KEEP也常用于时序约束。如果对通常会优化的信号存在时序约束,KEEP会阻止该操作,并允许使用正确的时序规则

KEEP Example (Verilog)

(* keep = “true” *) wire sig1;

assign sig1 = in1 & in2;

assign out1 = sig1 & in2;

5 RAM_STYLE

RAM_STYLE指示Vivado综合工具如何推断内存。可接受的值是:

•block:指示工具推断RAMB类型组件。

•distributed:指示工具推断LUT RAM。

•寄存器:指示工具推断寄存器而不是RAM。

•ultra:指示工具使用UltraScale +™URAM原语。

默认情况下,该工具根据启发式选择要推断的RAM,以便为大多数设计提供最佳结果。将此属性放在为RAM声明的数组或层次结构级别上。

•如果设置了信号,该属性将影响该特定信号。

•如果设置在层次结构级别上,则会影响该层次结构级别中的所有RAM。

层次结构的子级别不受影响。

这可以在RTL或XDC中设置。

RAM_STYLE Example (Verilog)

(* ram_style = “distributed” *)reg [data_size-1:0] myram [2**addr_size-1:0];

6 ROM_STYLE

ROM_STYLE指示综合工具如何推断ROM存储器。可接受的值是:

•block:指示工具推断RAMB类型组件

•distributed:指示工具推断LUT ROM。默认情况下,该工具根据启发式选择要推断的ROM,以便为大多数设计提供最佳结果。

这可以在RTL和XDC中设置。

ROM_STYLE Example (Verilog)

(* rom_style = “distributed” *)reg [data_size-1:0] myrom [2**addr_size-1:0];

猜您喜欢

电流采样电阻作为关键的测量元件,应用于电源管理、电机控制以及各种智能设备中。奥斯特(OST)作为业内知名品牌,其电流采样电阻以高精度、高稳定性和优良的品质受到市...
2014-01-11 12:22:30

这份常用贴片电阻阻值速查表提供了工程师和电子爱好者快速查找常用贴片电阻(SMD电阻)阻值的信息。它涵盖了E系列的标准阻值,包括E6、E12、E24、E48、E9...
2024-11-26 11:29:15

FPGA开发过程中,vivado和quartus等开发软件都会提供时序报告,以方便开发者判断自己的工程时序是否满足时序要求。本文将详细介绍如何读懂Vivado时...
2023-06-26 15:29:00

粉碎机和研磨机是工业生产中不可少的设备,应用于食品、化工、药品等领域。根据不同的工作原理和用途,可以分为多种类型。根据工作原理,粉碎机可分为机械粉碎机和气流粉碎...
2014-03-06 00:00:00

温度保险丝作为保护电路安全的重要元件,越来越受到重视。中熔电气作为国内知名的电气元件制造企业,其温度保险丝系列产品在市场上拥有良好的口碑和的应用。本文将围绕“中...
2025-01-18 07:24:30

贴片电阻体积小巧,其阻值通常用印在表面的数字代码表示,而不是直接标注数值和单位。理解这些代码对于电子爱好者和工程师至关重要。三位数字代码是最常见的形式。前两位数...
2025-04-14 15:01:59

U型防撬锁因其独特的结构设计和优越的安全性能,应用于多个领域。在自行车行业,U型防撬锁成为了保护自行车安全的重要工具,能够有效防止盗窃,保障车主的财产安全。在户...
2008-08-25 00:00:00


美容蒸脸器的使用是通过喷洒仪器甚至沸水来完成的,因此安全性和舒适性不容忽视。为确保安全,使用过程中应随时密切观察喷雾情况,容器中的水量不应超过水位警戒线,以免煮...
2023-06-26 10:22:00

现代生活中,配件的使用越来越普遍。无论是在电子产品、家居用品还是各类机械设备中,配件都扮演着非常重要的角色。其中,11.5X1.5MM配件因其独特的尺寸和多样的...
2025-02-26 21:33:48