Visible to Intel only — GUID: bhc1410932160593
Ixiasoft
Visible to Intel only — GUID: bhc1410932160593
Ixiasoft
8.1. Creating Clock Constraints
You can specify the clock requirement in the timing constraint file using the following command:
create_clockFor example, for a new clock named "reg_clk", with a 50 MHz clock targeted to the top level input port "clk", enter the following command line:
create_clock -name "reg_clk" -period "50 MHz" [get_ports "clk"]Figure below shows an example of how you can create a timing constraint file to constrain the Triple-Speed Ethernet Intel® FPGA IP clocks.
The example above consists of the following Verilog modules:
- TOP.v—The top level design module which contains an Intel® FPGA PLL and a user-defined instance. The top level input clocks consist of pll_inclk, ext_clk, and xcvr_ref_clk.
- user_instance.v—The user-defined instance that instantiates the Triple-Speed Ethernet Intel® FPGA IP.
- tse_variation.v—A Triple-Speed Ethernet Intel® FPGA IP variation. This example uses a 10/100/1000-Mbps Ethernet MAC with an internal FIFO buffer, a 1000BASE-X/SGMII PCS, and an embedded PMA.
The frequency for the PLL clock input, inclk0, is 100 MHz, and the frequency for the PLL clock output, c0, is 100 MHz. The Triple-Speed Ethernet MAC Avalon streaming clocks, ff_tx_clk and ff_rx_clk, use c0 as the clock source. The input clock frequency for the transceiver reference clock, xcvr_ref_clk, is 125 MHz.
Example of the Triple-Speed Ethernet IP timing constraint file:
# PLL clock input, 100 MHz create_clock -name pll_inclk -period 10.000 [get_ports {pll_inclk}] # ext_clk, 50 MHz create_clock -name ext_clk -period 20.000 [get_ports {ext_clk}] # xcvr_ref_clk, 125 MHz create_clock -name xcvr_ref_clk -period 8.000 [get_ports {xcvr_ref_clk}] # Derive PLL generated output clocks. derive_pll_clocks