## **Constraints**

The constraint files have constraint lines turned on or commented out. This is because the design has been

used and tested for different types of FPGA, and to allow one to easily modify the design to the needs of a new design.

## **Files**

## Bitstream\_Cnstrnts.xdc

File containing constraints that have only to do with bit stream generation. The file is checked by the Vivado

synthesis tool (syntax errors, ...) but is only used when the software creates a bitstream for downloading of the FPGA.

# \${FILE\_NAME}\_Impl.xdc

File containing implementation constraints, example are constraints for clock routing. his file is created to

contain those constraints creating warnings during synthesis of the design. The Vivado synthesis tool checks

the file for syntax errors but the file is further only used during implementation (place & route).

# \${FILE\_NAME}.xdc

This is the designs constraint file containing timing and placement options. This is the constraints file that

probably needs to be modified when another FPGA part type is used or the design is placed into another IOBank, or ...

### **VIO** related constraints

- set\_property C\_CLK\_INPUT\_FREQ\_HZ (125000000, 300000000, or other)
  - o ILA/VIO related constraint.
  - Constraint defining the input frequency of the ILA/debug core in Hz.
  - The debug hub requires a free running clock.
    - That free running clock can be the cause of many timing related issues, from timing related warnings to a design missing the requested timing due to the addition of the ILA/debug core.
    - When after implementation of the design the timing has degraded or a lot of warnings are generated about the debug core then this constraint can be used.
- set\_property C\_ENABLE\_CLK\_DIVIDER (TRUE or FALSE)
  - This constraint must be set to TRUE when the C\_CLK\_INPUT\_FREQ\_HZ constraint is used.
    - It puts a divider in place to adjust the clock in the ILA/debug core to the requested clock

- set\_property CLOCK\_DEDICATED\_ROUTE < Clock route option> (SAME\_CMT\_COLUMN, FALSE, ...)
  - When a the clock input of a MMCM and/or PLL is not coming from a source (IO) in the same clock area as used by the MMCM and/or PLL, Vivado will error out during implementation of the design.
  - This constraint make sure Vivado does not see the IO/Clock buffer placement and the MMCM/PLL placement as an error but as a warning. When this constraint is used Vivado will thus issue a warning about sub optimal placement of the clock source and the MMCM/PLL it is connected to.
  - This attribute must be placed on a net segment at the highest level of the design hierarchy.
  - By default this constraint is turned on (TRUE), forcing the sofwtare to use dedicated and local to the clock area clock routes.
  - This design uses the options SAME\_CMT\_COLUMN or FALSE
    - SAME\_CMT\_COLUMN
       Clock driver and its load must be placed in the same Clock Management Tile (CMT)
       column. The clock routing uses dedicated global clock routing resources.
    - FALSE

Clock driver and its load can be placed anywhere in the device.

The clock net can be routed using global clock routing resources, standard fabric routing resources or a mix of both. This can adversely affect the timing and performance of the clock net.

This is meanly the only option to make Vivado place and route a design when the source and destination of the clock route are place in total different parts of the FPGA (Clock input and clock buffer at the left side and the MMCM and/or PLL at the right side of the FPGA die.)

# **Global Timing Constraints**

create\_clock -period 1.600 -name -waveform {0.000 0.800}

Create a clock object with the specified period or waveform defined in nanoseconds (ns). This command defines primary clocks which are used by the timing engine as the delay propagation starting point of any clock edge. The defined clock can be added to the definition of an existing clock, or overwrite the existing clock.

#### set\_clock\_groups -asynchronous -group

Define clocks, or groups of clocks, that are exclusive with or asynchronous to other clocks in the design. Exclusive clocks are not active at the same time, and paths between them can be ignored during timing analysis. Asynchronous clocks are clocks with no known phase relationship, which typically happens when they do not share the same primary clock or do not have a common period.

Using this command is similar to defining false path constraints for data paths moving between exclusive or asynchronous clock domains.

#### set\_max\_delay

Sets the maximum delay allowed on a timing path, specified in nanoseconds (ns). The specified delay value is assigned to both the rising and falling edges of the defined timing paths unless the -rise or -fall arguments are specified.

Here it is used to minimise the delay between certain asynchronously clocked FFs.

### • set\_false\_path

Set this constraint on nets that are ignored during timing analysis.

• Next are a set of constraints that must be used together in order to force the software to place logic, primitives and other in a user defined area.

#### o create\_pblock <pblock\_name>

Defines a Pblock to allow one to add logic instances for floorplanning purposes. A Pblock consists of a group of cells that can be assigned to one or more independent or

overlapping rectangles. <pblock\_name> is a unique user defined name.

### add\_cells\_to\_pblock [get\_pblocks <pblock\_name>] [get\_cells

Adds specified logic instances to a pblock in an open implemented design. Once cells have been add to a pblock, you can place the pblocks onto the fabric of the FPGA using the resize\_pblock command.

The <pblock\_name> needed by this constant is the same name as given to the create\_pblock constraint.

The are hierarchical parts of the design.

o resize\_pblock [get\_pblocks <pblock\_name>] -add {<left\_bottom>:<top\_right>}

Place, resize, move, or remove the specified Pblock.

The <pblock\_name> needed by this constant is the same name as given to the create\_pblock constraint.

This <left\_bottom>:<top\_right> specifies the location in the FPGA logic area. Example: *SLICE\_X66Y180:SLICE\_X77Y239* 

- For convenience and to make the software not place logic all over the place in the FPGA, the different parts of the design are placed and routed in user restricted areas of an lo-Bank. Pbocks are in this design not only used to keep the design elements nicely together, but also used to make the design meet timing.
- An IO-Bank fits to a clock area (References for 7\_Series FPGA).
   Find just behind the IO-Bank a column of IO and clock primitives (ISERDES, IDELAY, OSERDES, ODELAY, MMCM and PLL). Then find a grid of SLICEs, Block-RAM, DSP-Blocks and other. All is arranged as shown in the figure.

IO Bank

IO & Clock Primitives

GRID OF SLICEs, BLOCK-RAMs, DSP-BLOCKs, and ...

All the IOB, IO-primitives and grid of logic elements in a clock area in an FPGA have XY location information. That information can be found when opening the device view in

the Vivado software. Some examples:

IOB\_X0Y0 IOB is the location for input and output buffers. HPIOBDIFFINBUF\_X0Y0 Use this when a differential IO is used in an HP bank.

OLOGIC\_X1Y33 Is a OSERDES ILOGIC\_X1Y15 This is a ISERDES

IDELAY\_X1Y15 ODELAY\_X1Y33 SLICE\_X49Y254

| DSP48_X8Y101<br>RAMB36_X6Y50 | One name for all RAM derivatives (FIFO,) |
|------------------------------|------------------------------------------|
|                              |                                          |

The XY grid starts down-left in the FPGA logic area and end top-right with XY coordinates depending the size of the FPGA.

- General rules for 7-Series FPGA
  - An IO-Bank column has 50 IO divided in two halve columns'
  - The 50 single ended IO, can be used as 24 differential IO provided. The two remaining IO stay single ended (one on top and one in the bottom of the IO Bank).
  - For each IOB there is one IDELAY, ILOGIC (ISERDES), OLOGIC (OSERDES) and ODELAY available.
  - A PLLs and a MMCM are available per IO-bank, easy to figure out the grid of those.
  - Behind the IO primitives columns the grid of logic starts.
  - The logic of a clock area behind an IO-Bank column takes an Y (vertical) range of 50 slices
    - and an X size of 80 slices on the right side and 74 slices on the left side of the FPGA die.
  - A Block-RAM column takes up to 10 RAMB36 primitives, were each RAMB36 can be divided in two RAMB18 blocks. A clock area has 3 Block-RAM columns.
  - The same applies to the DSP blocks, a column takes up to 20 DSP primitives and the
    - clock area has 3 of these columns.
  - The XY coordinates in the grid change depending the position of the IO-Bank and clock
    - area in the device. In most device there are two IO-Bank columns and IO-Banks are
    - stacked up. The bottom-left IO-Bank has thus a column of IO starting from *IO\_X0Y0 to IOB\_X0Y49*. The IO-Bank on top of this bottom-left IO-Bank starts at *IOB\_X0Y50* to location and counts 50 IO up to \*X0Y99, and so on.

■ The clock area as described in above text shown in a figure:



■ The IO-Bank structure for a 7-Series FPGA as discussed in above text in a figure:

| Io-Bank and grid of logic  | Io-Bank and grid of logic |
|----------------------------|---------------------------|
| X0Y300 - X79Y349           | X80Y300 - X145Y349        |
|                            |                           |
|                            |                           |
|                            |                           |
|                            |                           |
|                            |                           |
|                            |                           |
| La Bask and anid of la sin |                           |
| Io-Bank and grid of logic  | Io-Bank and grid of logic |
| X0Y50 - X79Y99             | X80Y50 - X153Y99          |
| Io-Bank and grid of logic  | Io-Bank and grid of logic |
| X0Y0 - X79Y49              | X80Y0 - X153Y49           |

- The is the theory behind the pblock constraints in the XDC constraints file.
- How to setup pblocks for a user create design
  - Start Vivado and create a new IO-Planning project for for device that is going to

be used.

Open the device view and browse in the view to the IO-Bank that is going to be used

for the design.

- Record the position of the IO-Bank in the FPGA logic.
- Select the left-bottom SLICE of the clock area and record the XY position.
- Select the top-right SLICE of the clock area and record the Xy value of that SLICE.
- With these values it is possible, using the given "General Rules", to position every

primitive inside the given clock area

- These locations change thus when:
  - Changing the FPGA part type.
  - Changing the IO-Bank the interface is placed in.
- set\_property DIFF\_TERM\_ADV TERM\_100 It is used to enable or disable the built-in, 100 Ohm, differential termination.
- set\_property DQS\_BIAS FALSE
   DQS\_BIAS must be set to TRUE for AC coupled LVDS standards, else it must be set to FALSE.

- set\_property EQUALIZATION EQ\_NONE
   Must be set to an EQ\_LEVELn when the design uses and AC coupled LVDS setup else it must be set to EQ\_NONE. Determine the correct equalization factor experimentally.
- set\_property LVDS\_PRE\_EMPHASIS FALSE
- set\_property IOSTANDARD LVDS
   Define the IO standard for IO not created by the synthesis tool form constraints set in the VHDL source code.

Kind regards,