User manual
172 www.xilinx.com Ethernet 1000BASE-X PCS/PMA or SGMII v9.1
UG155 March 24, 2008
Chapter 12: Constraining the Core
R
Virtex-5 Devices
Figure 6-6, page 75 illustrates the TBI input logic provided by the example design for the 
Virtex-5 family. IODELAY elements are instantiated on the TBI data input path as 
illustrated: the number of tap delays is currently set to zero. This can be modified in the 
UCF file, if desired, to de-skew the bus for PCB routing. A fixed tap delay is applied to 
delay the pma_rx_clk0 clock so that it correctly samples the TBI data at the IOB IDDR 
register, thereby meeting TBI setup and hold timing.
The tap delays are applied using the following UCF syntax.
#-----------------------------------------------------------
# To Adjust TBI Rx Input Setup/Hold Timing 
#-----------------------------------------------------------
INST "core_wrapper/delay_pma_rx_clk" IDELAY_VALUE = "63";
INST "core_wrapper/tbi_rx_data_bus[9].delay_tbi_rx_data" IDELAY_VALUE 
= "0";
INST "core_wrapper/tbi_rx_data_bus[8].delay_tbi_rx_data" IDELAY_VALUE 
= "0";
INST "core_wrapper/tbi_rx_data_bus[7].delay_tbi_rx_data" IDELAY_VALUE 
= "0";
INST "core_wrapper/tbi_rx_data_bus[6].delay_tbi_rx_data" IDELAY_VALUE 
= "0";
INST "core_wrapper/tbi_rx_data_bus[5].delay_tbi_rx_data" IDELAY_VALUE 
= "0";
INST "core_wrapper/tbi_rx_data_bus[4].delay_tbi_rx_data" IDELAY_VALUE 
= "0";
INST "core_wrapper/tbi_rx_data_bus[3].delay_tbi_rx_data" IDELAY_VALUE 
= "0";
INST "core_wrapper/tbi_rx_data_bus[2].delay_tbi_rx_data" IDELAY_VALUE 
= "0";
INST "core_wrapper/tbi_rx_data_bus[1].delay_tbi_rx_data" IDELAY_VALUE 
= "0";
INST "core_wrapper/tbi_rx_data_bus[0].delay_tbi_rx_data" IDELAY_VALUE 
= "0";
The value of IDELAY_VALUE for the pma_rx_clk0 clock is preconfigured in the example 
designs to meet the setup and hold constraints for the example TBI pinout in the particular 
device. The setup/hold timing which is achieved after place-and-route is reported in the 
datasheet section of the TRCE report (created by the implement script). See 
“Understanding Timing Reports for Setup/Hold Timing.”
Constraints When Implementing an External GMII
The constraints defined in this section are implemented in the UCF for the example 
designs delivered with the core. Sections from this UCF have been copied into the 
following examples, and should be studied in conjunction with the HDL source code for 
the example design. See also the section, “Implementing External GMII,” page 61.
Clock Period Constraints
When implementing an external GMII, the Transmitter Elastic Buffer delivered with the 
example design (or similar logic) must be used. The input transmitter GMII signals are 
then synchronous to their own clock domain (gmii_tx_clk is used in the example 
design). This clock must be constrained for a clock frequency of 125 MHz. The following 
UCF syntax shows the necessary constraints being applied to the example design.










