## Vivado从此开始(To Learn Vivado From Here)



#### 本书围绕Vivado四大主题

- 设计流程
- 时序约束
- 时序分析
- Tcl脚本的使用



作者: 高亚军 (Xilinx战略应用高级工程师)

- 2012年2月,出版《基于FPGA的数字信号处理(第1版)》
- 2012年9月,发布网络视频课程《Vivado入门与提高》
- 2015年7月,出版《基于FPGA的数字信号处理(第2版)》
- 2016年7月,发布网络视频课程《跟Xilinx SAE学HLS》

◆ 内容翔实全面: 涵盖Vivado所有基本功能

◆ 讲解深入浅出:结合大量案例,帮助读者加强对基本概念的理解
◆ 描述图文并茂:给出具体操作步骤,易于快速动手实践

#### XILINX > ALL PROGRAMMABLE...

# **ALL PROGRAMMABLE**

## **XDC Precedence**

Lauren Gao

## **Organizing the Design Constraints**

#### Recommended constraint files



– Complex design



XILINX > ALL PROGRAMMABLE.

## **Include IP Constraints**

#### > Many cores have their own constraints / exceptions

– PCIE, MIG, RAM-based asynchronous FIFOs...

#### > Non-native IP: Be careful!

- Very easy to drop the IP constraints especially if provided as .ngc files

#### > Native IP: Constraints included

- Sources window in IDE: Compile Order  $\rightarrow$  Constraints
- Use **report\_compile\_order constraints** to identify constraint file sources

| Tcl Console                                              |             |                                                                 |                                      |               |                 |                           |                                                                                                                                                                                                                                                                                             |  |
|----------------------------------------------------------|-------------|-----------------------------------------------------------------|--------------------------------------|---------------|-----------------|---------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| <pre>     report_compile_order -constraints     a </pre> |             |                                                                 |                                      |               |                 |                           |                                                                                                                                                                                                                                                                                             |  |
| ×                                                        | Synthe      | Synthesis Constraint Evaluation Order (sources_1 & constrs_1)   |                                      |               |                 |                           |                                                                                                                                                                                                                                                                                             |  |
|                                                          | Index       | rile Name                                                       | used_in                              | Scoped_10_Ker | Scoped_10_Cells | Processing_order          | rull rach Name                                                                                                                                                                                                                                                                              |  |
|                                                          | 1 2         | clk_core.xdc<br>wave_gen_timing.xdc                             | Synth & Impl<br>Synth & Impl         | clk_core      | inst            | EARLY<br>NORMAL           | c:/projects/project_wave_gen/project_wave_gen.srcs/sources_1/ip/clk_core/clk_core.xdc<br>C:/projects/project wave gen/project wave gen.srcs/constrs 1/imports/verilog/wave gen timing.xdc                                                                                                   |  |
|                                                          | 3           | char_fifo.xdc                                                   | Synth & Impl                         | char_fifo     | υο              | NORMAL                    | <pre>c:/projects/project_wave_gen/project_wave_gen.srcs/sources_1/ip/char_fifo/char_fifo/char_fifo.xdc</pre>                                                                                                                                                                                |  |
|                                                          | Implem      | Implementation Evaluation Compile Order (sources 1 & constrs 1) |                                      |               |                 |                           |                                                                                                                                                                                                                                                                                             |  |
|                                                          | Index       | File Name                                                       | Used_In                              | Scoped_To_Ref | Scoped_To_Cells | Processing_Order          | Full Path Name                                                                                                                                                                                                                                                                              |  |
|                                                          | 1<br>2<br>3 | clk_core.xdc<br>wave_gen_timing.xdc<br>wave_gen_pins.xdc        | Synth & Impl<br>Synth & Impl<br>Impl | clk_core      | inst            | EARLY<br>NORMAL<br>NORMAL | c:/projects/project_wave_gen/project_wave_gen.srcs/sources_1/ip/clk_core/clk_core.xdc<br>C:/projects/project_wave_gen/project_wave_gen.srcs/constrs_1/imports/verilog/wave_gen_timing.xdc<br>C:/projects/project_wave_gen/project_wave_gen.srcs/constrs_1/imports/verilog/wave_gen_pins.xdc |  |
|                                                          | 1 <b>4</b>  | char_filo.xdc                                                   | SAucu # Imbi                         | char_1110     | 00              | NORMAL                    | c./projects/project_wave_gen/project_wave_gen.srts/SOURCes_1/1D/Char_1110/Char_1110/Char_1110.xdC                                                                                                                                                                                           |  |

## **Managing IP Constraint Files**

#### Some IP come with their own XDC constraints

- Example: The clocking wizard



#### > The order of constraint files matters!

- To report the order of XDC files: report\_compile\_order -constraints
- Always verify the clocks using report\_clocks
- To change the default processing order

set\_property set\_processing\_order early | late IP\_XDC\_File

– If necessary, *IP\_XDC\_files* can be enabled/disabled

### **Defining Timing Constraints in Four Steps**



XILINX > ALL PROGRAMMABLE...

## **Create Synthesis Constraints**



- The net delay modeling is approximate and does not reflect placement constraints or complex effects such as congestion
- The main objective is to obtain a netlist which meets timing, or fails by a small amount, with realistic and simple constraints
- Synthesis constraints must use names from the elaborated netlist, preferably ports and sequential cells
  - During elaboration, some RTL signals can disappear and it is not possible to attach XDC constraints to them
- Once synthesis has completed, Xilinx recommends that you review the timing and utilization reports to validate that the netlist quality meets the application requirements and can be used for implementation

## **Create Synthesis Constraints**

- The synthesis engine accepts all XDC commands, but only some have a real effect
  - Timing constraints related to setup/recovery analysis influence the QoR
    - create\_clock, create\_generated\_clock
    - set\_input\_delay , set\_output\_delay
    - set\_clock\_groups, set\_false\_path, set\_max\_delay, set\_multicycle\_path
  - Timing constraints related to hold and removal analysis are ignored during synthesis
    - set\_false\_path -hold
    - set\_min\_delay
    - set\_multicycle\_path -hold



## **Recommended Constraints Sequence**

> XDC is based on Tcl syntax and interpretation rules. Like Tcl, XDC is a sequential language

- > Variables must be defined before they can be used
  - Similarly, timing clocks must be defined before they can be used in other constraints
- > For equivalent constraints that cover the same paths and have the same precedence, the last one applies



## **Timing Exceptions Priority**

- Clock Groups
- False Path
- > Max/min Delay Path
- > Multicycle Paths
- > The precedence rule for the filters, from highest to lowest
  - -from -through -to
  - -from -to
  - -from -through
  - -from
  - -through -to
  - -to
  - -through

(set\_clock\_groups) (set\_false\_path) (set\_max/min\_delay)

(set\_multicycle\_path)





## Example





You must avoid using several timing exceptions on the same paths, so that the timing analysis results are not dependent on priority rules, and it is easier to validate the effect of your constraints

XILINX > ALL PROGRAMMABLE..