[1852] | 1 | #Debug header LOC constraints (manually entered) |
---|
| 2 | NET "debug_status<0>" LOC = "AG27" | IOSTANDARD = LVCMOS25; #pin 0 |
---|
| 3 | NET "debug_status<1>" LOC = "AE26" | IOSTANDARD = LVCMOS25; #pin 1 |
---|
| 4 | |
---|
[1818] | 5 | NET "debug_sw_gpio<0>" LOC = "AF26" | IOSTANDARD = "LVCMOS25"; #pin 2 |
---|
| 6 | NET "debug_sw_gpio<1>" LOC = "AD25" | IOSTANDARD = "LVCMOS25"; #pin 3 |
---|
| 7 | NET "debug_sw_gpio<2>" LOC = "V24" | IOSTANDARD = "LVCMOS25"; #pin 4 |
---|
| 8 | NET "debug_sw_gpio<3>" LOC = "AA23" | IOSTANDARD = "LVCMOS25"; #pin 5 |
---|
| 9 | NET "debug_sw_gpio<4>" LOC = "AH30" | IOSTANDARD = "LVCMOS25"; #pin 6 |
---|
[1852] | 10 | NET "debug_sw_gpio<5>" LOC = "AK31" | IOSTANDARD = "LVCMOS25"; #pin 7 |
---|
| 11 | |
---|
| 12 | #User IO |
---|
| 13 | Net USERIO_hexdisp_left_pin<0> LOC=AL33 | IOSTANDARD = LVCMOS25; |
---|
| 14 | Net USERIO_hexdisp_left_pin<1> LOC=AK33 | IOSTANDARD = LVCMOS25; |
---|
| 15 | Net USERIO_hexdisp_left_pin<2> LOC=AH32 | IOSTANDARD = LVCMOS25; |
---|
| 16 | Net USERIO_hexdisp_left_pin<3> LOC=AF29 | IOSTANDARD = LVCMOS25; |
---|
| 17 | Net USERIO_hexdisp_left_pin<4> LOC=AE29 | IOSTANDARD = LVCMOS25; |
---|
| 18 | Net USERIO_hexdisp_left_pin<5> LOC=AK32 | IOSTANDARD = LVCMOS25; |
---|
| 19 | Net USERIO_hexdisp_left_pin<6> LOC=AF30 | IOSTANDARD = LVCMOS25; |
---|
| 20 | Net USERIO_hexdisp_right_pin<0> LOC=AE28 | IOSTANDARD = LVCMOS25; |
---|
| 21 | Net USERIO_hexdisp_right_pin<1> LOC=AD26 | IOSTANDARD = LVCMOS25; |
---|
| 22 | Net USERIO_hexdisp_right_pin<2> LOC=AC24 | IOSTANDARD = LVCMOS25; |
---|
| 23 | Net USERIO_hexdisp_right_pin<3> LOC=AE23 | IOSTANDARD = LVCMOS25; |
---|
| 24 | Net USERIO_hexdisp_right_pin<4> LOC=AC22 | IOSTANDARD = LVCMOS25; |
---|
| 25 | Net USERIO_hexdisp_right_pin<5> LOC=AD27 | IOSTANDARD = LVCMOS25; |
---|
| 26 | Net USERIO_hexdisp_right_pin<6> LOC=AB23 | IOSTANDARD = LVCMOS25; |
---|
| 27 | Net USERIO_hexdisp_left_dp_pin LOC=AG30 | IOSTANDARD = LVCMOS25; |
---|
| 28 | Net USERIO_hexdisp_right_dp_pin LOC=AC23 | IOSTANDARD = LVCMOS25; |
---|
| 29 | Net USERIO_leds_red_pin<0> LOC=AN34 | IOSTANDARD = LVCMOS25; |
---|
| 30 | Net USERIO_leds_red_pin<1> LOC=AM33 | IOSTANDARD = LVCMOS25; |
---|
| 31 | Net USERIO_leds_red_pin<2> LOC=AN33 | IOSTANDARD = LVCMOS25; |
---|
| 32 | Net USERIO_leds_red_pin<3> LOC=AP33 | IOSTANDARD = LVCMOS25; |
---|
| 33 | Net USERIO_leds_green_pin<0> LOC=AD22 | IOSTANDARD = LVCMOS25; |
---|
| 34 | Net USERIO_leds_green_pin<1> LOC=AE22 | IOSTANDARD = LVCMOS25; |
---|
| 35 | Net USERIO_leds_green_pin<2> LOC=AM32 | IOSTANDARD = LVCMOS25; |
---|
| 36 | Net USERIO_leds_green_pin<3> LOC=AN32 | IOSTANDARD = LVCMOS25; |
---|
| 37 | Net USERIO_rfa_led_red_pin LOC=AL34 | IOSTANDARD = LVCMOS25; |
---|
| 38 | Net USERIO_rfa_led_green_pin LOC=AK34 | IOSTANDARD = LVCMOS25; |
---|
| 39 | Net USERIO_rfb_led_red_pin LOC=AJ34 | IOSTANDARD = LVCMOS25; |
---|
| 40 | Net USERIO_rfb_led_green_pin LOC=AH34 | IOSTANDARD = LVCMOS25; |
---|
| 41 | Net USERIO_dipsw_pin<3> LOC=AM22 | IOSTANDARD = LVCMOS15; |
---|
| 42 | Net USERIO_dipsw_pin<2> LOC=AL23 | IOSTANDARD = LVCMOS15; |
---|
| 43 | Net USERIO_dipsw_pin<1> LOC=AM23 | IOSTANDARD = LVCMOS15; |
---|
| 44 | Net USERIO_dipsw_pin<0> LOC=AN23 | IOSTANDARD = LVCMOS15; |
---|
| 45 | Net USERIO_pb_u_pin LOC=AM21 | IOSTANDARD = LVCMOS15; |
---|
| 46 | Net USERIO_pb_m_pin LOC=AN22 | IOSTANDARD = LVCMOS15; |
---|
| 47 | Net USERIO_pb_d_pin LOC=AP22 | IOSTANDARD = LVCMOS15; |
---|
| 48 | |
---|
[1818] | 49 | #USB UART on WARP v3 rev 1.1 |
---|
| 50 | Net UART_USB_TX_pin LOC = H9 | IOSTANDARD=LVCMOS25; #FT230X RXD pin |
---|
| 51 | Net UART_USB_RX_pin LOC = J9 | IOSTANDARD=LVCMOS25; #FT230X TXD pin |
---|
| 52 | |
---|
[1877] | 53 | #IIC EEPROM (on board) |
---|
[1852] | 54 | Net IIC_EEPROM_iic_sda_pin LOC = AG23 | IOSTANDARD=LVCMOS25; |
---|
| 55 | Net IIC_EEPROM_iic_scl_pin LOC = AF23 | IOSTANDARD=LVCMOS25; |
---|
| 56 | |
---|
| 57 | #ETH A |
---|
| 58 | Net ETH_A_TemacPhy_RST_n_pin LOC=L9 | IOSTANDARD = LVCMOS25 | TIG; |
---|
| 59 | Net ETH_A_RGMII_TXD_0_pin<0> LOC=AF9 | IOSTANDARD = LVCMOS25; |
---|
| 60 | Net ETH_A_RGMII_TXD_0_pin<1> LOC=AF10 | IOSTANDARD = LVCMOS25; |
---|
| 61 | Net ETH_A_RGMII_TXD_0_pin<2> LOC=AD9 | IOSTANDARD = LVCMOS25; |
---|
| 62 | Net ETH_A_RGMII_TXD_0_pin<3> LOC=AD10 | IOSTANDARD = LVCMOS25; |
---|
| 63 | Net ETH_A_RGMII_TX_CTL_0_pin LOC=AG8 | IOSTANDARD = LVCMOS25; |
---|
| 64 | Net ETH_A_RGMII_TXC_0_pin LOC=AE9 | IOSTANDARD = LVCMOS25; |
---|
| 65 | Net ETH_A_RGMII_RXD_0_pin<0> LOC=AK9 | IOSTANDARD = LVCMOS25; |
---|
| 66 | Net ETH_A_RGMII_RXD_0_pin<1> LOC=AJ9 | IOSTANDARD = LVCMOS25; |
---|
| 67 | Net ETH_A_RGMII_RXD_0_pin<2> LOC=AH8 | IOSTANDARD = LVCMOS25; |
---|
| 68 | Net ETH_A_RGMII_RXD_0_pin<3> LOC=AH9 | IOSTANDARD = LVCMOS25; |
---|
| 69 | Net ETH_A_RGMII_RX_CTL_0_pin LOC=AL9 | IOSTANDARD = LVCMOS25; |
---|
| 70 | Net ETH_A_RGMII_RXC_0_pin LOC=AC10 | IOSTANDARD = LVCMOS25; |
---|
| 71 | #Fix for errata in rev 1.1 schematics |
---|
| 72 | Net ETH_A_MDC_0_pin LOC=AK8 | IOSTANDARD = LVCMOS25; |
---|
| 73 | Net ETH_A_MDIO_0_pin LOC=AP9 | IOSTANDARD = LVCMOS25 | PULLUP; |
---|
| 74 | |
---|
| 75 | #ETH B |
---|
| 76 | Net ETH_B_RGMII_TXD_0_pin<0> LOC=M10 | IOSTANDARD = LVCMOS25; |
---|
| 77 | Net ETH_B_RGMII_TXD_0_pin<1> LOC=B8 | IOSTANDARD = LVCMOS25; |
---|
| 78 | Net ETH_B_RGMII_TXD_0_pin<2> LOC=AC9 | IOSTANDARD = LVCMOS25; |
---|
| 79 | Net ETH_B_RGMII_TXD_0_pin<3> LOC=E9 | IOSTANDARD = LVCMOS25; |
---|
| 80 | Net ETH_B_RGMII_TX_CTL_0_pin LOC=D10 | IOSTANDARD = LVCMOS25; |
---|
| 81 | Net ETH_B_RGMII_TXC_0_pin LOC=AB10 | IOSTANDARD = LVCMOS25; |
---|
| 82 | Net ETH_B_RGMII_RXD_0_pin<0> LOC=A9 | IOSTANDARD = LVCMOS25; |
---|
| 83 | Net ETH_B_RGMII_RXD_0_pin<1> LOC=D9 | IOSTANDARD = LVCMOS25; |
---|
| 84 | Net ETH_B_RGMII_RXD_0_pin<2> LOC=C9 | IOSTANDARD = LVCMOS25; |
---|
| 85 | Net ETH_B_RGMII_RXD_0_pin<3> LOC=F10 | IOSTANDARD = LVCMOS25; |
---|
| 86 | Net ETH_B_RGMII_RX_CTL_0_pin LOC=A8 | IOSTANDARD = LVCMOS25; |
---|
| 87 | Net ETH_B_RGMII_RXC_0_pin LOC=L10 | IOSTANDARD = LVCMOS25; |
---|
| 88 | Net ETH_B_MDC_0_pin LOC=AN9 | IOSTANDARD = LVCMOS25; |
---|
| 89 | Net ETH_B_MDIO_0_pin LOC=AL8 | IOSTANDARD = LVCMOS25; |
---|
| 90 | |
---|
| 91 | #DDR3 SO-DIMM |
---|
| 92 | Net DDR3_2GB_SODIMM_Clk_pin LOC=AC15 | IOSTANDARD = DIFF_SSTL15; |
---|
| 93 | Net DDR3_2GB_SODIMM_Clk_n_pin LOC=AD15 | IOSTANDARD = DIFF_SSTL15; |
---|
| 94 | Net DDR3_2GB_SODIMM_CE_pin LOC=AF18 | IOSTANDARD = SSTL15; |
---|
| 95 | Net DDR3_2GB_SODIMM_CS_n_pin LOC=AL16 | IOSTANDARD = SSTL15; |
---|
| 96 | Net DDR3_2GB_SODIMM_ODT_pin LOC=AP15 | IOSTANDARD = SSTL15; |
---|
| 97 | Net DDR3_2GB_SODIMM_RAS_n_pin LOC=AM16 | IOSTANDARD = SSTL15; |
---|
| 98 | Net DDR3_2GB_SODIMM_CAS_n_pin LOC=AJ17 | IOSTANDARD = SSTL15; |
---|
| 99 | Net DDR3_2GB_SODIMM_WE_n_pin LOC=AF15 | IOSTANDARD = SSTL15; |
---|
| 100 | Net DDR3_2GB_SODIMM_BankAddr_pin<0> LOC=AG15 | IOSTANDARD = SSTL15; |
---|
| 101 | Net DDR3_2GB_SODIMM_BankAddr_pin<1> LOC=AP16 | IOSTANDARD = SSTL15; |
---|
| 102 | Net DDR3_2GB_SODIMM_BankAddr_pin<2> LOC=AD17 | IOSTANDARD = SSTL15; |
---|
| 103 | Net DDR3_2GB_SODIMM_Addr_pin<0> LOC=AM17 | IOSTANDARD = SSTL15; |
---|
| 104 | Net DDR3_2GB_SODIMM_Addr_pin<1> LOC=AF16 | IOSTANDARD = SSTL15; |
---|
| 105 | Net DDR3_2GB_SODIMM_Addr_pin<2> LOC=AN17 | IOSTANDARD = SSTL15; |
---|
| 106 | Net DDR3_2GB_SODIMM_Addr_pin<3> LOC=AG17 | IOSTANDARD = SSTL15; |
---|
| 107 | Net DDR3_2GB_SODIMM_Addr_pin<4> LOC=AK16 | IOSTANDARD = SSTL15; |
---|
| 108 | Net DDR3_2GB_SODIMM_Addr_pin<5> LOC=AG16 | IOSTANDARD = SSTL15; |
---|
| 109 | Net DDR3_2GB_SODIMM_Addr_pin<6> LOC=AK17 | IOSTANDARD = SSTL15; |
---|
| 110 | Net DDR3_2GB_SODIMM_Addr_pin<7> LOC=AG18 | IOSTANDARD = SSTL15; |
---|
| 111 | Net DDR3_2GB_SODIMM_Addr_pin<8> LOC=AE16 | IOSTANDARD = SSTL15; |
---|
| 112 | Net DDR3_2GB_SODIMM_Addr_pin<9> LOC=AD16 | IOSTANDARD = SSTL15; |
---|
| 113 | Net DDR3_2GB_SODIMM_Addr_pin<10> LOC=AH15 | IOSTANDARD = SSTL15; |
---|
| 114 | Net DDR3_2GB_SODIMM_Addr_pin<11> LOC=AH18 | IOSTANDARD = SSTL15; |
---|
| 115 | Net DDR3_2GB_SODIMM_Addr_pin<12> LOC=AE17 | IOSTANDARD = SSTL15; |
---|
| 116 | Net DDR3_2GB_SODIMM_Addr_pin<13> LOC=AJ16 | IOSTANDARD = SSTL15; |
---|
| 117 | Net DDR3_2GB_SODIMM_Addr_pin<14> LOC=AK18 | IOSTANDARD = SSTL15; |
---|
| 118 | Net DDR3_2GB_SODIMM_DQ_pin<0> LOC=AK29 | IOSTANDARD = SSTL15_T_DCI; |
---|
| 119 | Net DDR3_2GB_SODIMM_DQ_pin<1> LOC=AN30 | IOSTANDARD = SSTL15_T_DCI; |
---|
| 120 | Net DDR3_2GB_SODIMM_DQ_pin<2> LOC=AL29 | IOSTANDARD = SSTL15_T_DCI; |
---|
| 121 | Net DDR3_2GB_SODIMM_DQ_pin<3> LOC=AN29 | IOSTANDARD = SSTL15_T_DCI; |
---|
| 122 | Net DDR3_2GB_SODIMM_DQ_pin<4> LOC=AP31 | IOSTANDARD = SSTL15_T_DCI; |
---|
| 123 | Net DDR3_2GB_SODIMM_DQ_pin<5> LOC=AP30 | IOSTANDARD = SSTL15_T_DCI; |
---|
| 124 | Net DDR3_2GB_SODIMM_DQ_pin<6> LOC=AH28 | IOSTANDARD = SSTL15_T_DCI; |
---|
| 125 | Net DDR3_2GB_SODIMM_DQ_pin<7> LOC=AH27 | IOSTANDARD = SSTL15_T_DCI; |
---|
| 126 | Net DDR3_2GB_SODIMM_DQ_pin<8> LOC=AK28 | IOSTANDARD = SSTL15_T_DCI; |
---|
| 127 | Net DDR3_2GB_SODIMM_DQ_pin<9> LOC=AL28 | IOSTANDARD = SSTL15_T_DCI; |
---|
| 128 | Net DDR3_2GB_SODIMM_DQ_pin<10> LOC=AJ27 | IOSTANDARD = SSTL15_T_DCI; |
---|
| 129 | Net DDR3_2GB_SODIMM_DQ_pin<11> LOC=AH25 | IOSTANDARD = SSTL15_T_DCI; |
---|
| 130 | Net DDR3_2GB_SODIMM_DQ_pin<12> LOC=AP29 | IOSTANDARD = SSTL15_T_DCI; |
---|
| 131 | Net DDR3_2GB_SODIMM_DQ_pin<13> LOC=AM27 | IOSTANDARD = SSTL15_T_DCI; |
---|
| 132 | Net DDR3_2GB_SODIMM_DQ_pin<14> LOC=AJ25 | IOSTANDARD = SSTL15_T_DCI; |
---|
| 133 | Net DDR3_2GB_SODIMM_DQ_pin<15> LOC=AH24 | IOSTANDARD = SSTL15_T_DCI; |
---|
| 134 | Net DDR3_2GB_SODIMM_DQ_pin<16> LOC=AJ24 | IOSTANDARD = SSTL15_T_DCI; |
---|
| 135 | Net DDR3_2GB_SODIMM_DQ_pin<17> LOC=AK24 | IOSTANDARD = SSTL15_T_DCI; |
---|
| 136 | Net DDR3_2GB_SODIMM_DQ_pin<18> LOC=AL24 | IOSTANDARD = SSTL15_T_DCI; |
---|
| 137 | Net DDR3_2GB_SODIMM_DQ_pin<19> LOC=AK23 | IOSTANDARD = SSTL15_T_DCI; |
---|
| 138 | Net DDR3_2GB_SODIMM_DQ_pin<20> LOC=AP27 | IOSTANDARD = SSTL15_T_DCI; |
---|
| 139 | Net DDR3_2GB_SODIMM_DQ_pin<21> LOC=AM26 | IOSTANDARD = SSTL15_T_DCI; |
---|
| 140 | Net DDR3_2GB_SODIMM_DQ_pin<22> LOC=AN25 | IOSTANDARD = SSTL15_T_DCI; |
---|
| 141 | Net DDR3_2GB_SODIMM_DQ_pin<23> LOC=AN24 | IOSTANDARD = SSTL15_T_DCI; |
---|
| 142 | Net DDR3_2GB_SODIMM_DQ_pin<24> LOC=AD21 | IOSTANDARD = SSTL15_T_DCI; |
---|
| 143 | Net DDR3_2GB_SODIMM_DQ_pin<25> LOC=AE21 | IOSTANDARD = SSTL15_T_DCI; |
---|
| 144 | Net DDR3_2GB_SODIMM_DQ_pin<26> LOC=AK22 | IOSTANDARD = SSTL15_T_DCI; |
---|
| 145 | Net DDR3_2GB_SODIMM_DQ_pin<27> LOC=AL18 | IOSTANDARD = SSTL15_T_DCI; |
---|
| 146 | Net DDR3_2GB_SODIMM_DQ_pin<28> LOC=AN19 | IOSTANDARD = SSTL15_T_DCI; |
---|
| 147 | Net DDR3_2GB_SODIMM_DQ_pin<29> LOC=AP19 | IOSTANDARD = SSTL15_T_DCI; |
---|
| 148 | Net DDR3_2GB_SODIMM_DQ_pin<30> LOC=AM18 | IOSTANDARD = SSTL15_T_DCI; |
---|
| 149 | Net DDR3_2GB_SODIMM_DQ_pin<31> LOC=AN18 | IOSTANDARD = SSTL15_T_DCI; |
---|
| 150 | Net DDR3_2GB_SODIMM_DM_pin<0> LOC=AM30 | IOSTANDARD = SSTL15; |
---|
| 151 | Net DDR3_2GB_SODIMM_DM_pin<1> LOC=AL26 | IOSTANDARD = SSTL15; |
---|
| 152 | Net DDR3_2GB_SODIMM_DM_pin<2> LOC=AP26 | IOSTANDARD = SSTL15; |
---|
| 153 | Net DDR3_2GB_SODIMM_DM_pin<3> LOC=AJ22 | IOSTANDARD = SSTL15; |
---|
| 154 | Net DDR3_2GB_SODIMM_Reset_n_pin LOC=AP17 | IOSTANDARD = SSTL15; |
---|
| 155 | Net DDR3_2GB_SODIMM_DQS_pin<0> LOC=AG25 | IOSTANDARD = DIFF_SSTL15_T_DCI; |
---|
| 156 | Net DDR3_2GB_SODIMM_DQS_pin<1> LOC=AN28 | IOSTANDARD = DIFF_SSTL15_T_DCI; |
---|
| 157 | Net DDR3_2GB_SODIMM_DQS_pin<2> LOC=AM25 | IOSTANDARD = DIFF_SSTL15_T_DCI; |
---|
| 158 | Net DDR3_2GB_SODIMM_DQS_pin<3> LOC=AG22 | IOSTANDARD = DIFF_SSTL15_T_DCI; |
---|
| 159 | Net DDR3_2GB_SODIMM_DQS_n_pin<0> LOC=AG26 | IOSTANDARD = DIFF_SSTL15_T_DCI; |
---|
| 160 | Net DDR3_2GB_SODIMM_DQS_n_pin<1> LOC=AM28 | IOSTANDARD = DIFF_SSTL15_T_DCI; |
---|
| 161 | Net DDR3_2GB_SODIMM_DQS_n_pin<2> LOC=AL25 | IOSTANDARD = DIFF_SSTL15_T_DCI; |
---|
| 162 | Net DDR3_2GB_SODIMM_DQS_n_pin<3> LOC=AH22 | IOSTANDARD = DIFF_SSTL15_T_DCI; |
---|
| 163 | |
---|
| 164 | #System clock (80MHz, from sampling clock buffer) |
---|
| 165 | NET samp_clk_n_pin LOC = V23 | IOSTANDARD = LVDS_25 | DIFF_TERM = TRUE; |
---|
| 166 | NET samp_clk_p_pin LOC = U23 | IOSTANDARD = LVDS_25 | DIFF_TERM = TRUE; |
---|
| 167 | Net samp_clk_p_pin TNM_NET = samp_clk_pin; |
---|
| 168 | TIMESPEC TS_samp_clk_pin = PERIOD samp_clk_pin 80000 kHz; |
---|
| 169 | |
---|
| 170 | #System clock (200MHz, from LVDS oscillator) |
---|
| 171 | Net osc200_p_pin LOC = A10 | IOSTANDARD=LVDS_25 | DIFF_TERM = TRUE; |
---|
| 172 | Net osc200_n_pin LOC = B10 | IOSTANDARD=LVDS_25 | DIFF_TERM = TRUE; |
---|
| 173 | Net osc200_p_pin TNM_NET = osc200_p_pin; |
---|
| 174 | TIMESPEC TS_osc200_p_pin = PERIOD osc200_p_pin 200000 kHz; |
---|
| 175 | |
---|
| 176 | #Processor reset (RESET button on board) |
---|
| 177 | Net rst_1_sys_rst_pin LOC = AH13 | IOSTANDARD=LVCMOS15 | TIG; |
---|
| 178 | Net rst_1_sys_rst_pin TIG; |
---|
| 179 | |
---|
| 180 | INST clock_generator_MPMC_Clocks/*/MMCM0_INST*/MMCM_ADV_inst LOC = MMCM_ADV_X0Y2; |
---|
| 181 | |
---|
[1877] | 182 | ############################# |
---|
| 183 | #On-board RF interfaces |
---|
| 184 | ############################# |
---|
| 185 | |
---|
[1818] | 186 | #MAX2829 transceivers and RF front end |
---|
| 187 | NET RFA_SPI_SCLK_pin LOC=T34 | IOSTANDARD=LVCMOS25; |
---|
| 188 | NET RFA_SPI_MOSI_pin LOC=T33 | IOSTANDARD=LVCMOS25; |
---|
| 189 | NET RFA_SPI_CSn_pin LOC=U32 | IOSTANDARD=LVCMOS25; |
---|
| 190 | NET RFA_SHDN_pin LOC=U27 | IOSTANDARD=LVCMOS25; |
---|
| 191 | NET RFA_TxEn_pin LOC=T31 | IOSTANDARD=LVCMOS25; |
---|
| 192 | NET RFA_RxEn_pin LOC=U33 | IOSTANDARD=LVCMOS25; |
---|
| 193 | NET RFA_RxHP_pin LOC=AG32 | IOSTANDARD=LVCMOS25; |
---|
| 194 | NET RFA_PAEn_24_pin LOC=U25 | IOSTANDARD=LVCMOS25; |
---|
| 195 | NET RFA_PAEn_5_pin LOC=U28 | IOSTANDARD=LVCMOS25; |
---|
| 196 | NET RFA_ANTSW_pin<0> LOC=U31 | IOSTANDARD=LVCMOS25; |
---|
| 197 | NET RFA_ANTSW_pin<1> LOC=U30 | IOSTANDARD=LVCMOS25; |
---|
| 198 | NET RFA_LD_pin LOC=U26 | IOSTANDARD=LVCMOS25; |
---|
[1852] | 199 | NET RFA_B_pin<0> LOC=AG33 | IOSTANDARD=LVCMOS25; |
---|
| 200 | NET RFA_B_pin<1> LOC=AF31 | IOSTANDARD=LVCMOS25; |
---|
| 201 | NET RFA_B_pin<2> LOC=AF33 | IOSTANDARD=LVCMOS25; |
---|
| 202 | NET RFA_B_pin<3> LOC=AG31 | IOSTANDARD=LVCMOS25; |
---|
| 203 | NET RFA_B_pin<4> LOC=AF34 | IOSTANDARD=LVCMOS25; |
---|
| 204 | NET RFA_B_pin<5> LOC=AE33 | IOSTANDARD=LVCMOS25; |
---|
| 205 | NET RFA_B_pin<6> LOC=AE34 | IOSTANDARD=LVCMOS25; |
---|
[1818] | 206 | |
---|
| 207 | NET RFB_SPI_SCLK_pin LOC=H34 | IOSTANDARD=LVCMOS25; |
---|
| 208 | NET RFB_SPI_MOSI_pin LOC=H33 | IOSTANDARD=LVCMOS25; |
---|
| 209 | NET RFB_SPI_CSn_pin LOC=J32 | IOSTANDARD=LVCMOS25; |
---|
| 210 | NET RFB_SHDN_pin LOC=J34 | IOSTANDARD=LVCMOS25; |
---|
| 211 | NET RFB_TxEn_pin LOC=H32 | IOSTANDARD=LVCMOS25; |
---|
| 212 | NET RFB_RxEn_pin LOC=J31 | IOSTANDARD=LVCMOS25; |
---|
| 213 | NET RFB_RxHP_pin LOC=R28 | IOSTANDARD=LVCMOS25; |
---|
| 214 | NET RFB_PAEn_24_pin LOC=T25 | IOSTANDARD=LVCMOS25; |
---|
| 215 | NET RFB_PAEn_5_pin LOC=T28 | IOSTANDARD=LVCMOS25; |
---|
| 216 | NET RFB_ANTSW_pin<0> LOC=T30 | IOSTANDARD=LVCMOS25; |
---|
| 217 | NET RFB_ANTSW_pin<1> LOC=T29 | IOSTANDARD=LVCMOS25; |
---|
| 218 | NET RFB_LD_pin LOC=K33 | IOSTANDARD=LVCMOS25; |
---|
[1852] | 219 | NET RFB_B_pin<0> LOC=P27 | IOSTANDARD=LVCMOS25; |
---|
| 220 | NET RFB_B_pin<1> LOC=R27 | IOSTANDARD=LVCMOS25; |
---|
| 221 | NET RFB_B_pin<2> LOC=R29 | IOSTANDARD=LVCMOS25; |
---|
| 222 | NET RFB_B_pin<3> LOC=R26 | IOSTANDARD=LVCMOS25; |
---|
| 223 | NET RFB_B_pin<4> LOC=R32 | IOSTANDARD=LVCMOS25; |
---|
| 224 | NET RFB_B_pin<5> LOC=T26 | IOSTANDARD=LVCMOS25; |
---|
| 225 | NET RFB_B_pin<6> LOC=R31 | IOSTANDARD=LVCMOS25; |
---|
| 226 | |
---|
[1818] | 227 | NET RFA_AD_spi_sclk_pin LOC = AB33 | IOSTANDARD = LVCMOS25;# |
---|
| 228 | NET RFA_AD_spi_sdio LOC = AC30 | IOSTANDARD = LVCMOS25;# |
---|
| 229 | NET RFA_AD_spi_cs_n_pin LOC = AB31 | IOSTANDARD = LVCMOS25;# |
---|
| 230 | NET RFA_AD_reset_n_pin LOC = AA34 | IOSTANDARD = LVCMOS25;# |
---|
| 231 | |
---|
| 232 | NET RFB_AD_spi_sclk_pin LOC = P32 | IOSTANDARD = LVCMOS25;# |
---|
| 233 | NET RFB_AD_spi_sdio LOC = P34 | IOSTANDARD = LVCMOS25;# |
---|
| 234 | NET RFB_AD_spi_cs_n_pin LOC = N32 | IOSTANDARD = LVCMOS25;# |
---|
| 235 | NET RFB_AD_reset_n_pin LOC = N34 | IOSTANDARD = LVCMOS25;# |
---|
| 236 | |
---|
| 237 | NET clk_rfref_spi_sclk_pin LOC = V25 | IOSTANDARD = LVCMOS25;# |
---|
| 238 | NET clk_rfref_spi_mosi_pin LOC = W25 | IOSTANDARD = LVCMOS25;# |
---|
| 239 | NET clk_rfref_spi_cs_n_pin LOC = W27 | IOSTANDARD = LVCMOS25;# |
---|
| 240 | NET clk_rfref_spi_miso_pin LOC = Y27 | IOSTANDARD = LVCMOS25;# |
---|
| 241 | NET clk_rfref_func_pin LOC = L26 | IOSTANDARD = LVCMOS25; |
---|
| 242 | |
---|
| 243 | NET clk_samp_spi_sclk_pin LOC = W32 | IOSTANDARD = LVCMOS25;# |
---|
| 244 | NET clk_samp_spi_mosi_pin LOC = Y29 | IOSTANDARD = LVCMOS25;# |
---|
| 245 | NET clk_samp_spi_cs_n_pin LOC = W31 | IOSTANDARD = LVCMOS25;# |
---|
| 246 | NET clk_samp_spi_miso_pin LOC = Y28 | IOSTANDARD = LVCMOS25;# |
---|
| 247 | NET clk_samp_func_pin LOC = R33 | IOSTANDARD = LVCMOS25;# |
---|
[1852] | 248 | |
---|
| 249 | #TRXCLK pins driven by AD9963's; assuming 80MHz worst case |
---|
| 250 | Net RFA_AD_TRXCLK TNM_NET = RFA_AD_TRXCLK; |
---|
| 251 | TIMESPEC TS_RFA_AD_TRXCLK = PERIOD RFA_AD_TRXCLK 80 MHz; |
---|
| 252 | |
---|
| 253 | Net RFB_AD_TRXCLK TNM_NET = RFB_AD_TRXCLK; |
---|
| 254 | TIMESPEC TS_RFB_AD_TRXCLK = PERIOD RFB_AD_TRXCLK 80 MHz; |
---|
| 255 | |
---|
| 256 | #RFA AD9963 |
---|
| 257 | NET RFA_AD_TRXD<0> LOC = AC25 | IOSTANDARD = LVCMOS25; |
---|
| 258 | NET RFA_AD_TRXD<1> LOC = AB25 | IOSTANDARD = LVCMOS25; |
---|
| 259 | NET RFA_AD_TRXD<2> LOC = AB32 | IOSTANDARD = LVCMOS25; |
---|
| 260 | NET RFA_AD_TRXD<3> LOC = AC29 | IOSTANDARD = LVCMOS25; |
---|
| 261 | NET RFA_AD_TRXD<4> LOC = AD29 | IOSTANDARD = LVCMOS25; |
---|
| 262 | NET RFA_AD_TRXD<5> LOC = AC33 | IOSTANDARD = LVCMOS25; |
---|
| 263 | NET RFA_AD_TRXD<6> LOC = AD34 | IOSTANDARD = LVCMOS25; |
---|
| 264 | NET RFA_AD_TRXD<7> LOC = AC32 | IOSTANDARD = LVCMOS25; |
---|
| 265 | NET RFA_AD_TRXD<8> LOC = AD31 | IOSTANDARD = LVCMOS25; |
---|
| 266 | NET RFA_AD_TRXD<9> LOC = AD32 | IOSTANDARD = LVCMOS25; |
---|
| 267 | NET RFA_AD_TRXD<10> LOC = AE31 | IOSTANDARD = LVCMOS25; |
---|
| 268 | NET RFA_AD_TRXD<11> LOC = AE32 | IOSTANDARD = LVCMOS25; |
---|
| 269 | |
---|
| 270 | NET RFA_AD_TRXCLK LOC = AD30 | IOSTANDARD = LVCMOS25; |
---|
| 271 | NET RFA_AD_TRXIQ LOC = AC34 | IOSTANDARD = LVCMOS25; |
---|
| 272 | |
---|
| 273 | NET RFA_AD_TXCLK LOC = AA31 | IOSTANDARD = LVCMOS25; |
---|
| 274 | NET RFA_AD_TXIQ LOC = AA33 | IOSTANDARD = LVCMOS25; |
---|
| 275 | |
---|
| 276 | NET RFA_AD_TXD<0> LOC = AA25 | IOSTANDARD = LVCMOS25; |
---|
| 277 | NET RFA_AD_TXD<1> LOC = AB26 | IOSTANDARD = LVCMOS25; |
---|
| 278 | NET RFA_AD_TXD<2> LOC = Y26 | IOSTANDARD = LVCMOS25; |
---|
| 279 | NET RFA_AD_TXD<3> LOC = AA26 | IOSTANDARD = LVCMOS25; |
---|
| 280 | NET RFA_AD_TXD<4> LOC = AA28 | IOSTANDARD = LVCMOS25; |
---|
| 281 | NET RFA_AD_TXD<5> LOC = AA29 | IOSTANDARD = LVCMOS25; |
---|
| 282 | NET RFA_AD_TXD<6> LOC = AA30 | IOSTANDARD = LVCMOS25; |
---|
| 283 | NET RFA_AD_TXD<7> LOC = AB30 | IOSTANDARD = LVCMOS25; |
---|
| 284 | NET RFA_AD_TXD<8> LOC = AB28 | IOSTANDARD = LVCMOS25; |
---|
| 285 | NET RFA_AD_TXD<9> LOC = AB27 | IOSTANDARD = LVCMOS25; |
---|
| 286 | NET RFA_AD_TXD<10> LOC = AC28 | IOSTANDARD = LVCMOS25; |
---|
| 287 | NET RFA_AD_TXD<11> LOC = AC27 | IOSTANDARD = LVCMOS25; |
---|
| 288 | |
---|
| 289 | #RFB |
---|
| 290 | NET RFB_AD_TRXD<0> LOC = N25 | IOSTANDARD = LVCMOS25; |
---|
| 291 | NET RFB_AD_TRXD<1> LOC = M25 | IOSTANDARD = LVCMOS25; |
---|
| 292 | NET RFB_AD_TRXD<2> LOC = N28 | IOSTANDARD = LVCMOS25; |
---|
| 293 | NET RFB_AD_TRXD<3> LOC = N27 | IOSTANDARD = LVCMOS25; |
---|
| 294 | NET RFB_AD_TRXD<4> LOC = P29 | IOSTANDARD = LVCMOS25; |
---|
| 295 | NET RFB_AD_TRXD<5> LOC = M30 | IOSTANDARD = LVCMOS25; |
---|
| 296 | NET RFB_AD_TRXD<6> LOC = N30 | IOSTANDARD = LVCMOS25; |
---|
| 297 | NET RFB_AD_TRXD<7> LOC = N29 | IOSTANDARD = LVCMOS25; |
---|
| 298 | NET RFB_AD_TRXD<8> LOC = P26 | IOSTANDARD = LVCMOS25; |
---|
| 299 | NET RFB_AD_TRXD<9> LOC = P31 | IOSTANDARD = LVCMOS25; |
---|
| 300 | NET RFB_AD_TRXD<10> LOC = P25 | IOSTANDARD = LVCMOS25; |
---|
| 301 | NET RFB_AD_TRXD<11> LOC = P30 | IOSTANDARD = LVCMOS25; |
---|
| 302 | |
---|
| 303 | NET RFB_AD_TRXCLK LOC = N33 | IOSTANDARD = LVCMOS25; |
---|
| 304 | NET RFB_AD_TRXIQ LOC = M33 | IOSTANDARD = LVCMOS25; |
---|
| 305 | |
---|
[1818] | 306 | NET RFB_AD_TXCLK LOC = L28 | IOSTANDARD = LVCMOS25; |
---|
| 307 | NET RFB_AD_TXIQ LOC = L29 | IOSTANDARD = LVCMOS25; |
---|
| 308 | |
---|
| 309 | NET RFB_AD_TXD<0> LOC = K32 | IOSTANDARD = LVCMOS25; |
---|
| 310 | NET RFB_AD_TXD<1> LOC = M26 | IOSTANDARD = LVCMOS25; |
---|
| 311 | NET RFB_AD_TXD<2> LOC = M32 | IOSTANDARD = LVCMOS25; |
---|
| 312 | NET RFB_AD_TXD<3> LOC = K34 | IOSTANDARD = LVCMOS25; |
---|
| 313 | NET RFB_AD_TXD<4> LOC = M31 | IOSTANDARD = LVCMOS25; |
---|
| 314 | NET RFB_AD_TXD<5> LOC = L30 | IOSTANDARD = LVCMOS25; |
---|
| 315 | NET RFB_AD_TXD<6> LOC = L33 | IOSTANDARD = LVCMOS25; |
---|
| 316 | NET RFB_AD_TXD<7> LOC = L31 | IOSTANDARD = LVCMOS25; |
---|
| 317 | NET RFB_AD_TXD<8> LOC = M28 | IOSTANDARD = LVCMOS25; |
---|
| 318 | NET RFB_AD_TXD<9> LOC = L34 | IOSTANDARD = LVCMOS25; |
---|
| 319 | NET RFB_AD_TXD<10> LOC = M27 | IOSTANDARD = LVCMOS25; |
---|
| 320 | NET RFB_AD_TXD<11> LOC = K31 | IOSTANDARD = LVCMOS25; |
---|
[1852] | 321 | |
---|
[1818] | 322 | NET RF_RSSI_CLK LOC = B32 | IOSTANDARD = LVCMOS25; |
---|
| 323 | NET RF_RSSI_PD LOC = B34 | IOSTANDARD = LVCMOS25; |
---|
| 324 | NET RFB_RSSI_D<0> LOC = A33 | IOSTANDARD = LVCMOS25; |
---|
| 325 | NET RFB_RSSI_D<1> LOC = B33 | IOSTANDARD = LVCMOS25; |
---|
| 326 | NET RFB_RSSI_D<2> LOC = C33 | IOSTANDARD = LVCMOS25; |
---|
| 327 | NET RFB_RSSI_D<3> LOC = C34 | IOSTANDARD = LVCMOS25; |
---|
| 328 | NET RFB_RSSI_D<4> LOC = C32 | IOSTANDARD = LVCMOS25; |
---|
| 329 | NET RFB_RSSI_D<5> LOC = D31 | IOSTANDARD = LVCMOS25; |
---|
| 330 | NET RFB_RSSI_D<6> LOC = G30 | IOSTANDARD = LVCMOS25; |
---|
| 331 | NET RFB_RSSI_D<7> LOC = E31 | IOSTANDARD = LVCMOS25; |
---|
| 332 | NET RFB_RSSI_D<8> LOC = D32 | IOSTANDARD = LVCMOS25; |
---|
| 333 | NET RFB_RSSI_D<9> LOC = D34 | IOSTANDARD = LVCMOS25; |
---|
| 334 | NET RFA_RSSI_D<0> LOC = E32 | IOSTANDARD = LVCMOS25; |
---|
| 335 | NET RFA_RSSI_D<1> LOC = E33 | IOSTANDARD = LVCMOS25; |
---|
| 336 | NET RFA_RSSI_D<2> LOC = E34 | IOSTANDARD = LVCMOS25; |
---|
| 337 | NET RFA_RSSI_D<3> LOC = F30 | IOSTANDARD = LVCMOS25; |
---|
| 338 | NET RFA_RSSI_D<4> LOC = F31 | IOSTANDARD = LVCMOS25; |
---|
| 339 | NET RFA_RSSI_D<5> LOC = F34 | IOSTANDARD = LVCMOS25; |
---|
| 340 | NET RFA_RSSI_D<6> LOC = F33 | IOSTANDARD = LVCMOS25; |
---|
| 341 | NET RFA_RSSI_D<7> LOC = G31 | IOSTANDARD = LVCMOS25; |
---|
| 342 | NET RFA_RSSI_D<8> LOC = G33 | IOSTANDARD = LVCMOS25; |
---|
| 343 | NET RFA_RSSI_D<9> LOC = G32 | IOSTANDARD = LVCMOS25; |
---|
[1852] | 344 | |
---|
| 345 | |
---|
[1877] | 346 | ############################# |
---|
| 347 | # FMC-RF-2X245 RF Interfaces |
---|
| 348 | ############################# |
---|
| 349 | #User LEDs |
---|
| 350 | NET "RFC_LED_G" LOC = L19 | IOSTANDARD = LVCMOS25; |
---|
| 351 | NET "RFC_LED_R" LOC = L18 | IOSTANDARD = LVCMOS25; |
---|
| 352 | |
---|
| 353 | NET "RFD_LED_G" LOC = D16 | IOSTANDARD = LVCMOS25; |
---|
| 354 | NET "RFD_LED_R" LOC = A15 | IOSTANDARD = LVCMOS25; |
---|
| 355 | |
---|
| 356 | #FMC module I2C EEPROM |
---|
| 357 | NET "FMC_IIC_EEPROM_scl_pin" LOC = F23 | IOSTANDARD = LVCMOS25; |
---|
| 358 | NET "FMC_IIC_EEPROM_sda_pin" LOC = F24 | IOSTANDARD = LVCMOS25; |
---|
| 359 | |
---|
| 360 | #RSSI ADC |
---|
| 361 | NET "RFC_RSSI_D<0>" LOC = D21 | IOSTANDARD = LVCMOS25; |
---|
| 362 | NET "RFC_RSSI_D<1>" LOC = E19 | IOSTANDARD = LVCMOS25; |
---|
| 363 | NET "RFC_RSSI_D<2>" LOC = G20 | IOSTANDARD = LVCMOS25; |
---|
| 364 | NET "RFC_RSSI_D<3>" LOC = E22 | IOSTANDARD = LVCMOS25; |
---|
| 365 | NET "RFC_RSSI_D<4>" LOC = E23 | IOSTANDARD = LVCMOS25; |
---|
| 366 | NET "RFC_RSSI_D<5>" LOC = F21 | IOSTANDARD = LVCMOS25; |
---|
| 367 | NET "RFC_RSSI_D<6>" LOC = B20 | IOSTANDARD = LVCMOS25; |
---|
| 368 | NET "RFC_RSSI_D<7>" LOC = B23 | IOSTANDARD = LVCMOS25; |
---|
| 369 | NET "RFC_RSSI_D<8>" LOC = C19 | IOSTANDARD = LVCMOS25; |
---|
| 370 | NET "RFC_RSSI_D<9>" LOC = C23 | IOSTANDARD = LVCMOS25; |
---|
| 371 | |
---|
| 372 | NET "RFD_RSSI_D<0>" LOC = D19 | IOSTANDARD = LVCMOS25; |
---|
| 373 | NET "RFD_RSSI_D<1>" LOC = E21 | IOSTANDARD = LVCMOS25; |
---|
| 374 | NET "RFD_RSSI_D<2>" LOC = A23 | IOSTANDARD = LVCMOS25; |
---|
| 375 | NET "RFD_RSSI_D<3>" LOC = A24 | IOSTANDARD = LVCMOS25; |
---|
| 376 | NET "RFD_RSSI_D<4>" LOC = F19 | IOSTANDARD = LVCMOS25; |
---|
| 377 | NET "RFD_RSSI_D<5>" LOC = H19 | IOSTANDARD = LVCMOS25; |
---|
| 378 | NET "RFD_RSSI_D<6>" LOC = F20 | IOSTANDARD = LVCMOS25; |
---|
| 379 | NET "RFD_RSSI_D<7>" LOC = H20 | IOSTANDARD = LVCMOS25; |
---|
| 380 | NET "RFD_RSSI_D<8>" LOC = C20 | IOSTANDARD = LVCMOS25; |
---|
| 381 | NET "RFD_RSSI_D<9>" LOC = J20 | IOSTANDARD = LVCMOS25; |
---|
| 382 | |
---|
| 383 | NET "FMC_RF_RSSI_CLK" LOC = G13 | IOSTANDARD = LVCMOS25; |
---|
| 384 | NET "FMC_RF_RSSI_PD" LOC = A21 | IOSTANDARD = LVCMOS25; |
---|
| 385 | |
---|
| 386 | #FMC module RF A pins (probably renamed RF C in user project) |
---|
| 387 | |
---|
| 388 | #ADC/DAC |
---|
| 389 | NET "RFC_AD_spi_sclk_pin" LOC = B25 | IOSTANDARD = LVCMOS25; |
---|
| 390 | NET "RFC_AD_SPI_SDIO" LOC = D26 | IOSTANDARD = LVCMOS25 | PULLDOWN; |
---|
| 391 | NET "RFC_AD_spi_cs_n_pin" LOC = D27 | IOSTANDARD = LVCMOS25; |
---|
| 392 | NET "RFC_AD_reset_n_pin" LOC = B27 | IOSTANDARD = LVCMOS25; |
---|
| 393 | |
---|
| 394 | NET "RFC_AD_TRXCLK" LOC = C28 | IOSTANDARD = LVCMOS25; |
---|
| 395 | NET "RFC_AD_TRXIQ" LOC = D29 | IOSTANDARD = LVCMOS25; |
---|
| 396 | |
---|
| 397 | NET "RFC_AD_TRXD<0>" LOC = C29 | IOSTANDARD = LVCMOS25; |
---|
| 398 | NET "RFC_AD_TRXD<1>" LOC = C24 | IOSTANDARD = LVCMOS25; |
---|
| 399 | NET "RFC_AD_TRXD<2>" LOC = C22 | IOSTANDARD = LVCMOS25; |
---|
| 400 | NET "RFC_AD_TRXD<3>" LOC = G27 | IOSTANDARD = LVCMOS25; |
---|
| 401 | NET "RFC_AD_TRXD<4>" LOC = G28 | IOSTANDARD = LVCMOS25; |
---|
| 402 | NET "RFC_AD_TRXD<5>" LOC = D22 | IOSTANDARD = LVCMOS25; |
---|
| 403 | NET "RFC_AD_TRXD<6>" LOC = G26 | IOSTANDARD = LVCMOS25; |
---|
| 404 | NET "RFC_AD_TRXD<7>" LOC = A25 | IOSTANDARD = LVCMOS25; |
---|
| 405 | NET "RFC_AD_TRXD<8>" LOC = A26 | IOSTANDARD = LVCMOS25; |
---|
| 406 | NET "RFC_AD_TRXD<9>" LOC = H27 | IOSTANDARD = LVCMOS25; |
---|
| 407 | NET "RFC_AD_TRXD<10>" LOC = E27 | IOSTANDARD = LVCMOS25; |
---|
| 408 | NET "RFC_AD_TRXD<11>" LOC = B26 | IOSTANDARD = LVCMOS25; |
---|
| 409 | |
---|
| 410 | NET "RFC_AD_TXCLK" LOC = C27 | IOSTANDARD = LVCMOS25; |
---|
| 411 | NET "RFC_AD_TXIQ" LOC = C30 | IOSTANDARD = LVCMOS25; |
---|
| 412 | |
---|
| 413 | NET "RFC_AD_TXD<0>" LOC = F26 | IOSTANDARD = LVCMOS25; |
---|
| 414 | NET "RFC_AD_TXD<1>" LOC = K21 | IOSTANDARD = LVCMOS25; |
---|
| 415 | NET "RFC_AD_TXD<2>" LOC = E24 | IOSTANDARD = LVCMOS25; |
---|
| 416 | NET "RFC_AD_TXD<3>" LOC = G25 | IOSTANDARD = LVCMOS25; |
---|
| 417 | NET "RFC_AD_TXD<4>" LOC = F25 | IOSTANDARD = LVCMOS25; |
---|
| 418 | NET "RFC_AD_TXD<5>" LOC = E26 | IOSTANDARD = LVCMOS25; |
---|
| 419 | NET "RFC_AD_TXD<6>" LOC = A19 | IOSTANDARD = LVCMOS25; |
---|
| 420 | NET "RFC_AD_TXD<7>" LOC = D24 | IOSTANDARD = LVCMOS25; |
---|
| 421 | NET "RFC_AD_TXD<8>" LOC = A18 | IOSTANDARD = LVCMOS25; |
---|
| 422 | NET "RFC_AD_TXD<9>" LOC = L21 | IOSTANDARD = LVCMOS25; |
---|
| 423 | NET "RFC_AD_TXD<10>" LOC = L20 | IOSTANDARD = LVCMOS25; |
---|
| 424 | NET "RFC_AD_TXD<11>" LOC = D30 | IOSTANDARD = LVCMOS25; |
---|
| 425 | |
---|
| 426 | #Front end |
---|
| 427 | NET "RFC_PAEn_24_pin" LOC = D14 | IOSTANDARD = LVCMOS25; |
---|
| 428 | NET "RFC_PAEn_5_pin" LOC = M12 | IOSTANDARD = LVCMOS25; |
---|
| 429 | NET "RFC_AntSw_pin<0>" LOC = M11 | IOSTANDARD = LVCMOS25; |
---|
| 430 | NET "RFC_AntSw_pin<1>" LOC = A13 | IOSTANDARD = LVCMOS25; |
---|
| 431 | |
---|
| 432 | #Transceiver |
---|
| 433 | NET "RFC_B_pin<0>" LOC = B30 | IOSTANDARD = LVCMOS25; |
---|
| 434 | NET "RFC_B_pin<1>" LOC = F28 | IOSTANDARD = LVCMOS25; |
---|
| 435 | NET "RFC_B_pin<2>" LOC = B31 | IOSTANDARD = LVCMOS25; |
---|
| 436 | NET "RFC_B_pin<3>" LOC = E28 | IOSTANDARD = LVCMOS25; |
---|
| 437 | NET "RFC_B_pin<4>" LOC = D25 | IOSTANDARD = LVCMOS25; |
---|
| 438 | NET "RFC_B_pin<5>" LOC = A30 | IOSTANDARD = LVCMOS25; |
---|
| 439 | NET "RFC_B_pin<6>" LOC = A31 | IOSTANDARD = LVCMOS25; |
---|
| 440 | |
---|
| 441 | NET "RFC_SPI_SCLK_pin" LOC = A29 | IOSTANDARD = LVCMOS25; |
---|
| 442 | NET "RFC_SPI_CSn_pin" LOC = B18 | IOSTANDARD = LVCMOS25; |
---|
| 443 | NET "RFC_SPI_MOSI_pin" LOC = J22 | IOSTANDARD = LVCMOS25; |
---|
| 444 | NET "RFC_RXEN_pin" LOC = H22 | IOSTANDARD = LVCMOS25; |
---|
| 445 | NET "RFC_RXHP_pin" LOC = B28 | IOSTANDARD = LVCMOS25; |
---|
| 446 | NET "RFC_SHDN_pin" LOC = K22 | IOSTANDARD = LVCMOS25; |
---|
| 447 | NET "RFC_TXEN_pin" LOC = C18 | IOSTANDARD = LVCMOS25; |
---|
| 448 | NET "RFC_LD_pin" LOC = A28 | IOSTANDARD = LVCMOS25; |
---|
| 449 | |
---|
| 450 | #FMC module RF B pins (probably renamed RF D in user project) |
---|
| 451 | |
---|
| 452 | #ADC/DAC |
---|
| 453 | NET "RFD_AD_spi_sclk_pin" LOC = K17 | IOSTANDARD = LVCMOS25; |
---|
| 454 | NET "RFD_AD_SPI_SDIO" LOC = B17 | IOSTANDARD = LVCMOS25 | PULLDOWN; |
---|
| 455 | NET "RFD_AD_spi_cs_n_pin" LOC = D15 | IOSTANDARD = LVCMOS25; |
---|
| 456 | NET "RFD_AD_reset_n_pin" LOC = G15 | IOSTANDARD = LVCMOS25; |
---|
| 457 | |
---|
| 458 | NET "RFD_AD_TRXCLK" LOC = L15 | IOSTANDARD = LVCMOS25; |
---|
| 459 | NET "RFD_AD_TRXIQ" LOC = K18 | IOSTANDARD = LVCMOS25; |
---|
| 460 | |
---|
| 461 | NET "RFD_AD_TRXD<0>" LOC = J16 | IOSTANDARD = LVCMOS25; |
---|
| 462 | NET "RFD_AD_TRXD<1>" LOC = H17 | IOSTANDARD = LVCMOS25; |
---|
| 463 | NET "RFD_AD_TRXD<2>" LOC = J17 | IOSTANDARD = LVCMOS25; |
---|
| 464 | NET "RFD_AD_TRXD<3>" LOC = L16 | IOSTANDARD = LVCMOS25; |
---|
| 465 | NET "RFD_AD_TRXD<4>" LOC = G18 | IOSTANDARD = LVCMOS25; |
---|
| 466 | NET "RFD_AD_TRXD<5>" LOC = M18 | IOSTANDARD = LVCMOS25; |
---|
| 467 | NET "RFD_AD_TRXD<6>" LOC = H18 | IOSTANDARD = LVCMOS25; |
---|
| 468 | NET "RFD_AD_TRXD<7>" LOC = M17 | IOSTANDARD = LVCMOS25; |
---|
| 469 | NET "RFD_AD_TRXD<8>" LOC = D17 | IOSTANDARD = LVCMOS25; |
---|
| 470 | NET "RFD_AD_TRXD<9>" LOC = J19 | IOSTANDARD = LVCMOS25; |
---|
| 471 | NET "RFD_AD_TRXD<10>" LOC = K19 | IOSTANDARD = LVCMOS25; |
---|
| 472 | NET "RFD_AD_TRXD<11>" LOC = E18 | IOSTANDARD = LVCMOS25; |
---|
| 473 | |
---|
| 474 | NET "RFD_AD_TXCLK" LOC = C17 | IOSTANDARD = LVCMOS25; |
---|
| 475 | NET "RFD_AD_TXIQ" LOC = E17 | IOSTANDARD = LVCMOS25; |
---|
| 476 | |
---|
| 477 | NET "RFD_AD_TXD<0>" LOC = B16 | IOSTANDARD = LVCMOS25; |
---|
| 478 | NET "RFD_AD_TXD<1>" LOC = J15 | IOSTANDARD = LVCMOS25; |
---|
| 479 | NET "RFD_AD_TXD<2>" LOC = A16 | IOSTANDARD = LVCMOS25; |
---|
| 480 | NET "RFD_AD_TXD<3>" LOC = H15 | IOSTANDARD = LVCMOS25; |
---|
| 481 | NET "RFD_AD_TXD<4>" LOC = M15 | IOSTANDARD = LVCMOS25; |
---|
| 482 | NET "RFD_AD_TXD<5>" LOC = F15 | IOSTANDARD = LVCMOS25; |
---|
| 483 | NET "RFD_AD_TXD<6>" LOC = C15 | IOSTANDARD = LVCMOS25; |
---|
| 484 | NET "RFD_AD_TXD<7>" LOC = M16 | IOSTANDARD = LVCMOS25; |
---|
| 485 | NET "RFD_AD_TXD<8>" LOC = B15 | IOSTANDARD = LVCMOS25; |
---|
| 486 | NET "RFD_AD_TXD<9>" LOC = G16 | IOSTANDARD = LVCMOS25; |
---|
| 487 | NET "RFD_AD_TXD<10>" LOC = F18 | IOSTANDARD = LVCMOS25; |
---|
| 488 | NET "RFD_AD_TXD<11>" LOC = F16 | IOSTANDARD = LVCMOS25; |
---|
| 489 | |
---|
| 490 | #Front end |
---|
| 491 | NET "RFD_PAEn_24_pin" LOC = A14 | IOSTANDARD = LVCMOS25; |
---|
| 492 | NET "RFD_PAEn_5_pin" LOC = B13 | IOSTANDARD = LVCMOS25; |
---|
| 493 | NET "RFD_AntSw_pin<0>" LOC = C14 | IOSTANDARD = LVCMOS25; |
---|
| 494 | NET "RFD_AntSw_pin<1>" LOC = B12 | IOSTANDARD = LVCMOS25; |
---|
| 495 | |
---|
| 496 | #Transceiver |
---|
| 497 | NET "RFD_B_pin<0>" LOC = H12 | IOSTANDARD = LVCMOS25; |
---|
| 498 | NET "RFD_B_pin<1>" LOC = H13 | IOSTANDARD = LVCMOS25; |
---|
| 499 | NET "RFD_B_pin<2>" LOC = M13 | IOSTANDARD = LVCMOS25; |
---|
| 500 | NET "RFD_B_pin<3>" LOC = G12 | IOSTANDARD = LVCMOS25; |
---|
| 501 | NET "RFD_B_pin<4>" LOC = F14 | IOSTANDARD = LVCMOS25; |
---|
| 502 | NET "RFD_B_pin<5>" LOC = H14 | IOSTANDARD = LVCMOS25; |
---|
| 503 | NET "RFD_B_pin<6>" LOC = J12 | IOSTANDARD = LVCMOS25; |
---|
| 504 | NET "RFD_SPI_SCLK_pin" LOC = G10 | IOSTANDARD = LVCMOS25; |
---|
| 505 | NET "RFD_SPI_CSn_pin" LOC = K13 | IOSTANDARD = LVCMOS25; |
---|
| 506 | NET "RFD_SPI_MOSI_pin" LOC = F11 | IOSTANDARD = LVCMOS25; |
---|
| 507 | NET "RFD_RXEN_pin" LOC = K12 | IOSTANDARD = LVCMOS25; |
---|
| 508 | NET "RFD_RXHP_pin" LOC = L13 | IOSTANDARD = LVCMOS25; |
---|
| 509 | NET "RFD_SHDN_pin" LOC = K11 | IOSTANDARD = LVCMOS25; |
---|
| 510 | NET "RFD_TXEN_pin" LOC = H10 | IOSTANDARD = LVCMOS25; |
---|
| 511 | NET "RFD_LD_pin" LOC = L11 | IOSTANDARD = LVCMOS25; |
---|
| 512 | |
---|
| 513 | |
---|
[1818] | 514 | ###### ETH_A |
---|
| 515 | ###### Hard_Ethernet_MAC |
---|
| 516 | # This is a RGMII system |
---|
| 517 | # GTX_CLK_0 = 125MHz |
---|
| 518 | # LlinkTemac0_CLK = plb_v46 clk = host clock = 100MHz from clock generator |
---|
| 519 | # Rx/Tx Client clocks are Rx/Tx PHY clocks so CORE Gen PHY clock constraints propagate to Rx/Tx client clock periods |
---|
| 520 | # Time domain crossing constraints (DATAPATHONLY) are set for maximum bus frequency |
---|
| 521 | # allowed by IP which is the maximum option in BSB. For lower bus frequency choice in BSB, |
---|
| 522 | # the constraints are over constrained. Relaxing them for your system may reduce build time. |
---|
| 523 | |
---|
| 524 | NET "*ETH_A*/hrst*" TIG; |
---|
| 525 | |
---|
| 526 | # Locate the Tri-Mode Ethernet MAC instance |
---|
| 527 | INST "*ETH_A*v6_emac" LOC = "TEMAC_X0Y0"; |
---|
| 528 | |
---|
| 529 | ############################################################################### |
---|
| 530 | # CLOCK CONSTRAINTS |
---|
| 531 | # The following constraints are required. If you choose to not use the example |
---|
| 532 | # design level of wrapper hierarchy, the net names should be translated to |
---|
| 533 | # match your design. |
---|
| 534 | ############################################################################### |
---|
| 535 | |
---|
| 536 | # Ethernet GTX_CLK high quality 125 MHz reference clock |
---|
| 537 | NET "*/GTX_CLK_0" TNM_NET = "ref_gtx_clk"; #name of signal connected to TEMAC GTX_CLK_0 input |
---|
| 538 | TIMEGRP "v6_emac_v1_3_clk_ref_gtx" = "ref_gtx_clk"; |
---|
| 539 | TIMESPEC "TS_v6_emac_v1_3_clk_ref_gtx" = PERIOD "v6_emac_v1_3_clk_ref_gtx" 8 ns HIGH 50 %; #constant value based on constant 125 MHZ GTX clock |
---|
| 540 | |
---|
| 541 | # Ethernet RGMII PHY-side transmit clock |
---|
| 542 | # Changed NET Name - Input to bufg_tx_0 |
---|
| 543 | # ___________ |
---|
| 544 | # | | |\ |
---|
| 545 | # | Hard Core |--- tx_clk_0_o --| >---- Tx_Cl_Clk ----- |
---|
| 546 | # |___________| |/ |
---|
| 547 | # BUFG |
---|
| 548 | # |
---|
| 549 | NET "*ETH_A*/tx_cl_clk" TNM_NET = "A_phy_clk_tx"; |
---|
| 550 | TIMEGRP "A_v6_emac_v1_3_clk_phy_tx" = "A_phy_clk_tx"; |
---|
| 551 | TIMESPEC "TS_A_v6_emac_v1_3_clk_phy_tx" = PERIOD "A_v6_emac_v1_3_clk_phy_tx" 8 ns HIGH 50 %; |
---|
| 552 | |
---|
| 553 | # Ethernet RGMII PHY-side receive clock |
---|
| 554 | # Changed NET Name |
---|
| 555 | # RGMII_RXC_0 is the name of the clock net at the TEMAC Port |
---|
| 556 | # It is the input to the IODELAY |
---|
| 557 | # RxClientClk_0 is the name of the BUFG output clock net |
---|
| 558 | # |
---|
| 559 | # _________ BUFR |
---|
| 560 | # | | |\ |
---|
| 561 | # ---RGMII_RXC_0----| IODELAY |------| >----RxClientClk_0------------ |
---|
| 562 | # |_________| |/ |
---|
| 563 | # |
---|
| 564 | NET "ETH_A_RGMII_RXC_0_pin" TNM_NET = "A_phy_clk_rx"; |
---|
| 565 | TIMEGRP "A_v6_emac_v1_3_clk_phy_rx" = "A_phy_clk_rx"; |
---|
| 566 | TIMESPEC "TS_A_v6_emac_v1_3_clk_phy_rx" = PERIOD "A_v6_emac_v1_3_clk_phy_rx" 7.5 ns HIGH 50 %; |
---|
| 567 | |
---|
| 568 | # IDELAYCTRL 200 MHz reference clock |
---|
| 569 | NET "clk_200*MHz*" TNM_NET = "clk_ref_clk"; #name of signal connected to TEMAC REFCLK input |
---|
| 570 | TIMEGRP "ref_clk" = "clk_ref_clk"; |
---|
| 571 | TIMESPEC "TS_ref_clk" = PERIOD "ref_clk" 5 ns HIGH 50 %; #constant value based on constant 200 MHZ ref clock |
---|
| 572 | |
---|
| 573 | # Constrain the DCR interface clock to an example frequency of 100 MHz |
---|
| 574 | # Changed NET Name |
---|
| 575 | # NET "DCREMACCLK" TNM_NET = "host_clock"; |
---|
| 576 | #NET "*ETH_A*/SPLB_CLK" TNM_NET = "host_clock"; |
---|
| 577 | #TIMEGRP "A_clk_host" = "A_host_clock"; |
---|
| 578 | #TIMESPEC "TS_A_clk_host" = PERIOD "A_clk_host" 10 ns HIGH 50 %; |
---|
| 579 | |
---|
| 580 | ############################################################################### |
---|
| 581 | # PHYSICAL INTERFACE CONSTRAINTS |
---|
| 582 | # The following constraints are necessary for proper operation, and are tuned |
---|
| 583 | # for this example design. They should be modified to suit your design. |
---|
| 584 | ############################################################################### |
---|
| 585 | |
---|
| 586 | # RGMII physical interface constraints |
---|
| 587 | # ----------------------------------------------------------------------------- |
---|
| 588 | |
---|
| 589 | # Set the IDELAY and ODELAY values, tuned for this example design. |
---|
| 590 | # These values should be modified to suit your design. |
---|
| 591 | # original assuming equal trace lengths INST "*rgmii?rgmii_rx_ctl_delay" IDELAY_VALUE = 13; |
---|
| 592 | # original assuming equal trace lengths INST "*rgmii?rgmii_rx_d0_delay" IDELAY_VALUE = 13; |
---|
| 593 | # original assuming equal trace lengths INST "*rgmii?rgmii_rx_d1_delay" IDELAY_VALUE = 13; |
---|
| 594 | # original assuming equal trace lengths INST "*rgmii?rgmii_rx_d2_delay" IDELAY_VALUE = 13; |
---|
| 595 | # original assuming equal trace lengths INST "*rgmii?rgmii_rx_d3_delay" IDELAY_VALUE = 13; |
---|
| 596 | |
---|
| 597 | INST "*ETH_A*rgmii?rgmii_rx_ctl_delay" IDELAY_VALUE = 13; |
---|
| 598 | INST "*ETH_A*rgmii?rgmii_rx_d0_delay" IDELAY_VALUE = 13; |
---|
| 599 | INST "*ETH_A*rgmii?rgmii_rx_d1_delay" IDELAY_VALUE = 13; |
---|
| 600 | INST "*ETH_A*rgmii?rgmii_rx_d2_delay" IDELAY_VALUE = 13; |
---|
| 601 | INST "*ETH_A*rgmii?rgmii_rx_d3_delay" IDELAY_VALUE = 13; |
---|
| 602 | |
---|
| 603 | INST "*ETH_A*rgmii_rxc0_delay" IDELAY_VALUE = 0; |
---|
| 604 | INST "*ETH_A*rgmii_rxc0_delay" SIGNAL_PATTERN = CLOCK; |
---|
| 605 | |
---|
| 606 | INST "*ETH_A*rgmii?rgmii_tx_clk_delay" ODELAY_VALUE = 6; |
---|
| 607 | INST "*ETH_A*rgmii?rgmii_tx_clk_delay" SIGNAL_PATTERN = CLOCK; |
---|
| 608 | |
---|
| 609 | # Group all IODELAY-related blocks to use a single IDELAYCTRL |
---|
| 610 | |
---|
| 611 | # Change - added TNMs for trace length variations |
---|
| 612 | INST "ETH_A_RGMII_RXD_0_pin[0]" TNM = "A_rgmii_rx_d0"; |
---|
| 613 | INST "ETH_A_RGMII_RXD_0_pin[1]" TNM = "A_rgmii_rx_d1"; |
---|
| 614 | INST "ETH_A_RGMII_RXD_0_pin[2]" TNM = "A_rgmii_rx_d2"; |
---|
| 615 | INST "ETH_A_RGMII_RXD_0_pin[3]" TNM = "A_rgmii_rx_d3"; |
---|
| 616 | INST "ETH_A_RGMII_RX_CTL_0_pin" TNM = "A_rgmii_rx_ctrl"; |
---|
| 617 | |
---|
| 618 | # Spec: 1.2ns setup time, 1.2ns hold time |
---|
| 619 | # The internal PHY delays were not used to derive the OFFSET constraints |
---|
| 620 | # Changed NET Name |
---|
| 621 | # This signal trace is longer than the clock trace, and arrives at the FPGA pin 64 ps after the clock |
---|
| 622 | # Therefore the offset in constraint must have less setup time than nominal |
---|
| 623 | TIMEGRP "A_rgmii_rx_d0" OFFSET = IN 1.2 ns VALID 2.4 ns BEFORE "ETH_A_RGMII_RXC_0_pin" RISING; |
---|
| 624 | TIMEGRP "A_rgmii_rx_d0" OFFSET = IN 1.2 ns VALID 2.4 ns BEFORE "ETH_A_RGMII_RXC_0_pin" FALLING; |
---|
| 625 | |
---|
| 626 | # This signal trace is shorter than the clock trace, and arrives at the FPGA pin 376 ps before the clock |
---|
| 627 | # Therefore the offset in constraint must have more setup time than nominal |
---|
| 628 | TIMEGRP "A_rgmii_rx_d1" OFFSET = IN 1.2 ns VALID 2.4 ns BEFORE "ETH_A_RGMII_RXC_0_pin" RISING; |
---|
| 629 | TIMEGRP "A_rgmii_rx_d1" OFFSET = IN 1.2 ns VALID 2.4 ns BEFORE "ETH_A_RGMII_RXC_0_pin" FALLING; |
---|
| 630 | |
---|
| 631 | # This signal trace is shorter than the clock trace, and arrives at the FPGA pin 372 ps before the clock |
---|
| 632 | # Therefore the offset in constraint must have more setup time than nominal |
---|
| 633 | TIMEGRP "A_rgmii_rx_d2" OFFSET = IN 1.2 ns VALID 2.4 ns BEFORE "ETH_A_RGMII_RXC_0_pin" RISING; |
---|
| 634 | TIMEGRP "A_rgmii_rx_d2" OFFSET = IN 1.2 ns VALID 2.4 ns BEFORE "ETH_A_RGMII_RXC_0_pin" FALLING; |
---|
| 635 | |
---|
| 636 | # This signal trace is shorter than the clock trace, and arrives at the FPGA pin 115 ps before the clock |
---|
| 637 | # Therefore the offset in constraint must have more setup time than nominal |
---|
| 638 | TIMEGRP "A_rgmii_rx_d3" OFFSET = IN 1.2 ns VALID 2.4 ns BEFORE "ETH_A_RGMII_RXC_0_pin" RISING; |
---|
| 639 | TIMEGRP "A_rgmii_rx_d3" OFFSET = IN 1.2 ns VALID 2.4 ns BEFORE "ETH_A_RGMII_RXC_0_pin" FALLING; |
---|
| 640 | |
---|
| 641 | # This signal trace is shorter than the clock trace, and arrives at the FPGA pin 292 ps before the clock |
---|
| 642 | # Therefore the offset in constraint must have more setup time than nominal |
---|
| 643 | TIMEGRP "A_rgmii_rx_ctrl" OFFSET = IN 1.2 ns VALID 2.4 ns BEFORE "ETH_A_RGMII_RXC_0_pin" RISING; |
---|
| 644 | TIMEGRP "A_rgmii_rx_ctrl" OFFSET = IN 1.2 ns VALID 2.4 ns BEFORE "ETH_A_RGMII_RXC_0_pin" FALLING; |
---|
| 645 | |
---|
| 646 | |
---|
| 647 | NET "*ETH_A*/LlinkTemac0_CLK" TNM_NET = "A_LLCLK0"; #name of signal connected to TEMAC LlinkTemac0_CLK input |
---|
| 648 | NET "*ETH_A*/SPLB_Clk" TNM_NET = "A_PLBCLK"; #name of signal connected to TEMAC SPLB_Clk input |
---|
| 649 | NET "*ETH_A*/REFCLK" TNM_NET = "A_REFCLK"; #name of signal connected to TEMAC REFCLK input |
---|
| 650 | |
---|
| 651 | TIMESPEC "TS_A_LL_CLK0_2_RX_CLIENT_CLK0" = FROM A_LLCLK0 TO A_phy_clk_rx 8000 ps DATAPATHONLY; #constant value based on Ethernet clock |
---|
| 652 | TIMESPEC "TS_A_LL_CLK0_2_TX_CLIENT_CLK0" = FROM A_LLCLK0 TO A_phy_clk_tx 8000 ps DATAPATHONLY; #constant value based on Ethernet clock |
---|
| 653 | TIMESPEC "TS_A_RX_CLIENT_CLK0_2_LL_CLK0" = FROM A_phy_clk_rx TO A_LLCLK0 8000 ps DATAPATHONLY; #varies based on period of LocalLink clock |
---|
| 654 | TIMESPEC "TS_A_TX_CLIENT_CLK0_2_LL_CLK0" = FROM A_phy_clk_tx TO A_LLCLK0 8000 ps DATAPATHONLY; #varies based on period of LocalLink clock |
---|
| 655 | |
---|
| 656 | TIMESPEC "TS_A_REF_CLK_2_PLB_CLIENT_CLK" = FROM A_REFCLK TO A_PLBCLK 8000 ps DATAPATHONLY; #varies based on period of PLB clock |
---|
| 657 | TIMESPEC "TS_A_PLB_CLIENT_CLK_2_REF_CLK" = FROM A_PLBCLK TO A_REFCLK 5000 ps DATAPATHONLY; #constant value based on constant 200 MHZ ref clock |
---|
| 658 | |
---|
| 659 | TIMESPEC "TS_A_REF_CLK_2_TX_CLIENT_CLK0" = FROM A_REFCLK TO A_phy_clk_tx 8000 ps DATAPATHONLY; #constant value based on Ethernet clock |
---|
| 660 | TIMESPEC "TS_A_TX_CLIENT_CLK0_2_REF_CLK" = FROM A_phy_clk_tx TO A_REFCLK 5000 ps DATAPATHONLY; #constant value based on constant 200 MHZ ref clock |
---|
| 661 | |
---|
| 662 | TIMESPEC "TS_A_REF_CLK_2_RX_CLIENT_CLK0" = FROM A_REFCLK TO A_phy_clk_rx 8000 ps DATAPATHONLY; #constant value based on Ethernet clock |
---|
| 663 | TIMESPEC "TS_A_RX_CLIENT_CLK0_2_REF_CLK" = FROM A_phy_clk_rx TO A_REFCLK 5000 ps DATAPATHONLY; #constant value based on constant 200 MHZ ref clock |
---|
| 664 | |
---|
| 665 | |
---|
| 666 | |
---|
| 667 | ###### ETH_B |
---|
| 668 | ###### Hard_Ethernet_MAC |
---|
| 669 | # This is a RGMII system |
---|
| 670 | # GTX_CLK_0 = 125MHz |
---|
| 671 | # LlinkTemac0_CLK = plb_v46 clk = host clock = 100MHz from clock generator |
---|
| 672 | # Rx/Tx Client clocks are Rx/Tx PHY clocks so CORE Gen PHY clock constraints propagate to Rx/Tx client clock periods |
---|
| 673 | # Time domain crossing constraints (DATAPATHONLY) are set for maximum bus frequency |
---|
| 674 | # allowed by IP which is the maximum option in BSB. For lower bus frequency choice in BSB, |
---|
| 675 | # the constraints are over constrained. Relaxing them for your system may reduce build time. |
---|
| 676 | |
---|
| 677 | NET "*ETH_B*/hrst*" TIG; |
---|
| 678 | |
---|
| 679 | # Locate the Tri-Mode Ethernet MAC instance |
---|
| 680 | INST "*ETH_B*v6_emac" LOC = "TEMAC_X0Y1"; |
---|
| 681 | |
---|
| 682 | ############################################################################### |
---|
| 683 | # CLOCK CONSTRAINTS |
---|
| 684 | # The following constraints are required. If you choose to not use the example |
---|
| 685 | # design level of wrapper hierarchy, the net names should be translated to |
---|
| 686 | # match your design. |
---|
| 687 | ############################################################################### |
---|
| 688 | |
---|
| 689 | # Ethernet RGMII PHY-side transmit clock |
---|
| 690 | # Changed NET Name - Input to bufg_tx_0 |
---|
| 691 | # ___________ |
---|
| 692 | # | | |\ |
---|
| 693 | # | Hard Core |--- tx_clk_0_o --| >---- Tx_Cl_Clk ----- |
---|
| 694 | # |___________| |/ |
---|
| 695 | # BUFG |
---|
| 696 | # |
---|
| 697 | NET "*ETH_B*/tx_cl_clk" TNM_NET = "B_phy_clk_tx"; |
---|
| 698 | TIMEGRP "B_v6_emac_v1_3_clk_phy_tx" = "B_phy_clk_tx"; |
---|
| 699 | TIMESPEC "TS_B_v6_emac_v1_3_clk_phy_tx" = PERIOD "B_v6_emac_v1_3_clk_phy_tx" 8 ns HIGH 50 %; |
---|
| 700 | |
---|
| 701 | # Ethernet RGMII PHY-side receive clock |
---|
| 702 | # Changed NET Name |
---|
| 703 | # RGMII_RXC_0 is the name of the clock net at the TEMAC Port |
---|
| 704 | # It is the input to the IODELAY |
---|
| 705 | # RxClientClk_0 is the name of the BUFG output clock net |
---|
| 706 | # |
---|
| 707 | # _________ BUFR |
---|
| 708 | # | | |\ |
---|
| 709 | # ---RGMII_RXC_0----| IODELAY |------| >----RxClientClk_0------------ |
---|
| 710 | # |_________| |/ |
---|
| 711 | # |
---|
| 712 | NET "ETH_B_RGMII_RXC_0_pin" TNM_NET = "B_phy_clk_rx"; |
---|
| 713 | TIMEGRP "B_v6_emac_v1_3_clk_phy_rx" = "B_phy_clk_rx"; |
---|
| 714 | TIMESPEC "TS_B_v6_emac_v1_3_clk_phy_rx" = PERIOD "B_v6_emac_v1_3_clk_phy_rx" 7.5 ns HIGH 50 %; |
---|
| 715 | |
---|
| 716 | # Constrain the DCR interface clock to an example frequency of 100 MHz |
---|
| 717 | # Changed NET Name |
---|
| 718 | # NET "DCREMACCLK" TNM_NET = "host_clock"; |
---|
| 719 | NET "*ETH_B*/SPLB_CLK" TNM_NET = "host_clock"; |
---|
| 720 | TIMEGRP "B_clk_host" = "B_host_clock"; |
---|
| 721 | TIMESPEC "TS_B_clk_host" = PERIOD "B_clk_host" 10 ns HIGH 50 %; |
---|
| 722 | |
---|
| 723 | ############################################################################### |
---|
| 724 | # PHYSICAL INTERFACE CONSTRAINTS |
---|
| 725 | # The following constraints are necessary for proper operation, and are tuned |
---|
| 726 | # for this example design. They should be modified to suit your design. |
---|
| 727 | ############################################################################### |
---|
| 728 | |
---|
| 729 | # RGMII physical interface constraints |
---|
| 730 | # ----------------------------------------------------------------------------- |
---|
| 731 | |
---|
| 732 | # Set the IDELAY and ODELAY values, tuned for this example design. |
---|
| 733 | # These values should be modified to suit your design. |
---|
| 734 | # original assuming equal trace lengths INST "*rgmii?rgmii_rx_ctl_delay" IDELAY_VALUE = 13; |
---|
| 735 | # original assuming equal trace lengths INST "*rgmii?rgmii_rx_d0_delay" IDELAY_VALUE = 13; |
---|
| 736 | # original assuming equal trace lengths INST "*rgmii?rgmii_rx_d1_delay" IDELAY_VALUE = 13; |
---|
| 737 | # original assuming equal trace lengths INST "*rgmii?rgmii_rx_d2_delay" IDELAY_VALUE = 13; |
---|
| 738 | # original assuming equal trace lengths INST "*rgmii?rgmii_rx_d3_delay" IDELAY_VALUE = 13; |
---|
| 739 | |
---|
| 740 | INST "*ETH_B*rgmii?rgmii_rx_ctl_delay" IDELAY_VALUE = 13; |
---|
| 741 | INST "*ETH_B*rgmii?rgmii_rx_d0_delay" IDELAY_VALUE = 13; |
---|
| 742 | INST "*ETH_B*rgmii?rgmii_rx_d1_delay" IDELAY_VALUE = 13; |
---|
| 743 | INST "*ETH_B*rgmii?rgmii_rx_d2_delay" IDELAY_VALUE = 13; |
---|
| 744 | INST "*ETH_B*rgmii?rgmii_rx_d3_delay" IDELAY_VALUE = 13; |
---|
| 745 | |
---|
| 746 | INST "*ETH_B*rgmii_rxc0_delay" IDELAY_VALUE = 0; |
---|
| 747 | INST "*ETH_B*rgmii_rxc0_delay" SIGNAL_PATTERN = CLOCK; |
---|
| 748 | |
---|
| 749 | INST "*ETH_B*rgmii?rgmii_tx_clk_delay" ODELAY_VALUE = 6; |
---|
| 750 | INST "*ETH_B*rgmii?rgmii_tx_clk_delay" SIGNAL_PATTERN = CLOCK; |
---|
| 751 | |
---|
| 752 | # Group all IODELAY-related blocks to use a single IDELAYCTRL |
---|
| 753 | |
---|
| 754 | # Change - added TNMs for trace length variations |
---|
| 755 | INST "ETH_B_RGMII_RXD_0_pin[0]" TNM = "B_rgmii_rx_d0"; |
---|
| 756 | INST "ETH_B_RGMII_RXD_0_pin[1]" TNM = "B_rgmii_rx_d1"; |
---|
| 757 | INST "ETH_B_RGMII_RXD_0_pin[2]" TNM = "B_rgmii_rx_d2"; |
---|
| 758 | INST "ETH_B_RGMII_RXD_0_pin[3]" TNM = "B_rgmii_rx_d3"; |
---|
| 759 | INST "ETH_B_RGMII_RX_CTL_0_pin" TNM = "B_rgmii_rx_ctrl"; |
---|
| 760 | |
---|
| 761 | # Spec: 1.2ns setup time, 1.2ns hold time |
---|
| 762 | # The internal PHY delays were not used to derive the OFFSET constraints |
---|
| 763 | # Changed NET Name |
---|
| 764 | # This signal trace is longer than the clock trace, and arrives at the FPGA pin 64 ps after the clock |
---|
| 765 | # Therefore the offset in constraint must have less setup time than nominal |
---|
| 766 | TIMEGRP "B_rgmii_rx_d0" OFFSET = IN 1.2 ns VALID 2.4 ns BEFORE "ETH_B_RGMII_RXC_0_pin" RISING; |
---|
| 767 | TIMEGRP "B_rgmii_rx_d0" OFFSET = IN 1.2 ns VALID 2.4 ns BEFORE "ETH_B_RGMII_RXC_0_pin" FALLING; |
---|
| 768 | |
---|
| 769 | # This signal trace is shorter than the clock trace, and arrives at the FPGA pin 376 ps before the clock |
---|
| 770 | # Therefore the offset in constraint must have more setup time than nominal |
---|
| 771 | TIMEGRP "B_rgmii_rx_d1" OFFSET = IN 1.2 ns VALID 2.4 ns BEFORE "ETH_B_RGMII_RXC_0_pin" RISING; |
---|
| 772 | TIMEGRP "B_rgmii_rx_d1" OFFSET = IN 1.2 ns VALID 2.4 ns BEFORE "ETH_B_RGMII_RXC_0_pin" FALLING; |
---|
| 773 | |
---|
| 774 | # This signal trace is shorter than the clock trace, and arrives at the FPGA pin 372 ps before the clock |
---|
| 775 | # Therefore the offset in constraint must have more setup time than nominal |
---|
| 776 | TIMEGRP "B_rgmii_rx_d2" OFFSET = IN 1.2 ns VALID 2.4 ns BEFORE "ETH_B_RGMII_RXC_0_pin" RISING; |
---|
| 777 | TIMEGRP "B_rgmii_rx_d2" OFFSET = IN 1.2 ns VALID 2.4 ns BEFORE "ETH_B_RGMII_RXC_0_pin" FALLING; |
---|
| 778 | |
---|
| 779 | # This signal trace is shorter than the clock trace, and arrives at the FPGA pin 115 ps before the clock |
---|
| 780 | # Therefore the offset in constraint must have more setup time than nominal |
---|
| 781 | TIMEGRP "B_rgmii_rx_d3" OFFSET = IN 1.2 ns VALID 2.4 ns BEFORE "ETH_B_RGMII_RXC_0_pin" RISING; |
---|
| 782 | TIMEGRP "B_rgmii_rx_d3" OFFSET = IN 1.2 ns VALID 2.4 ns BEFORE "ETH_B_RGMII_RXC_0_pin" FALLING; |
---|
| 783 | |
---|
| 784 | # This signal trace is shorter than the clock trace, and arrives at the FPGA pin 292 ps before the clock |
---|
| 785 | # Therefore the offset in constraint must have more setup time than nominal |
---|
| 786 | TIMEGRP "B_rgmii_rx_ctrl" OFFSET = IN 1.2 ns VALID 2.4 ns BEFORE "ETH_B_RGMII_RXC_0_pin" RISING; |
---|
| 787 | TIMEGRP "B_rgmii_rx_ctrl" OFFSET = IN 1.2 ns VALID 2.4 ns BEFORE "ETH_B_RGMII_RXC_0_pin" FALLING; |
---|
| 788 | |
---|
| 789 | |
---|
| 790 | NET "*ETH_B*/LlinkTemac0_CLK" TNM_NET = "B_LLCLK0"; #name of signal connected to TEMAC LlinkTemac0_CLK input |
---|
| 791 | NET "*ETH_B*/SPLB_Clk" TNM_NET = "B_PLBCLK"; #name of signal connected to TEMAC SPLB_Clk input |
---|
| 792 | |
---|
| 793 | TIMESPEC "TS_B_LL_CLK0_2_RX_CLIENT_CLK0" = FROM B_LLCLK0 TO B_phy_clk_rx 8000 ps DATAPATHONLY; #constant value based on Ethernet clock |
---|
| 794 | TIMESPEC "TS_B_LL_CLK0_2_TX_CLIENT_CLK0" = FROM B_LLCLK0 TO B_phy_clk_tx 8000 ps DATAPATHONLY; #constant value based on Ethernet clock |
---|
| 795 | TIMESPEC "TS_B_RX_CLIENT_CLK0_2_LL_CLK0" = FROM B_phy_clk_rx TO B_LLCLK0 8000 ps DATAPATHONLY; #varies based on period of LocalLink clock |
---|
[1852] | 796 | TIMESPEC "TS_B_TX_CLIENT_CLK0_2_LL_CLK0" = FROM B_phy_clk_tx TO B_LLCLK0 8000 ps DATAPATHONLY; #varies based on period of LocalLink clock |
---|
| 797 | |
---|
| 798 | ###### DDR3_2GB_SODIMM |
---|
| 799 | #2012-Apr-2: |
---|
| 800 | # -Started with old UCF snippet from early FPGA pinout testing |
---|
| 801 | # -Updated LOC constraints to match MIG 13.4 design which met timing for 2GB SO-DIMM (-1 @ 400MHz, -2 @ 533MHz) |
---|
| 802 | |
---|
| 803 | ###### DDR3_SDRAM |
---|
| 804 | |
---|
| 805 | # Constrain BUFR clocks used to synchronize data from IOB to fabric logic |
---|
| 806 | # Note that ISE cannot infer this from other PERIOD constraints because |
---|
| 807 | # of the use of OSERDES blocks in the BUFR clock generation path |
---|
| 808 | NET "*/mpmc_core_0/gen_v6_ddr3_phy.mpmc_phy_if_0/clk_rsync[?]" TNM_NET = TNM_clk_rsync; |
---|
| 809 | TIMESPEC "TS_clk_rsync" = PERIOD "TNM_clk_rsync" 5000 ps; # This is over-constraint for 200MHz, user can relax it to match mpmc_clk0 |
---|
| 810 | |
---|
| 811 | # Paths between DQ/DQS ISERDES.Q outputs and CLB flops clocked by falling |
---|
| 812 | # edge of BUFR will by design only be used if DYNCLKDIVSEL is asserted for |
---|
| 813 | # that particular flop. Mark this path as being a full-cycle, rather than |
---|
| 814 | # a half cycle path for timing purposes. NOTE: This constraint forces full- |
---|
| 815 | # cycle timing to be applied globally for all rising->falling edge paths |
---|
| 816 | # in all resynchronizaton clock domains. If the user had modified the logic |
---|
| 817 | # in the resync clock domain such that other rising->falling edge paths |
---|
| 818 | # exist, then constraint below should be modified to utilize pattern |
---|
| 819 | # matching to specific affect only the DQ/DQS ISERDES.Q outputs |
---|
| 820 | TIMEGRP "TG_clk_rsync_rise" = RISING "TNM_clk_rsync"; |
---|
| 821 | TIMEGRP "TG_clk_rsync_fall" = FALLING "TNM_clk_rsync"; |
---|
| 822 | TIMESPEC "TS_clk_rsync_rise_to_fall" = FROM "TG_clk_rsync_rise" TO "TG_clk_rsync_fall" 5000 ps; # This is over-constraint for 200MHz, user can relax it to match mpmc_clk0 |
---|
| 823 | |
---|
| 824 | # Signal to select between controller and physical layer signals. Four divided by two clock |
---|
| 825 | # cycles (4 memory clock cycles) are provided by design for the signal to settle down. |
---|
| 826 | # Used only by the phy modules. |
---|
| 827 | INST "*/mpmc_core_0/gen_v6_ddr3_phy.mpmc_phy_if_0/u_phy_init/u_ff_phy_init_data_sel" TNM = "TNM_PHY_INIT_SEL"; |
---|
| 828 | TIMESPEC "TS_MC_PHY_INIT_SEL" = FROM "TNM_PHY_INIT_SEL" TO FFS = 10000 ps; # This is over-constraint, user can relax it to match 4 memory clock cycles |
---|
| 829 | |
---|
| 830 | #Internal Vref |
---|
| 831 | CONFIG INTERNAL_VREF_BANK22=0.75; |
---|
| 832 | CONFIG INTERNAL_VREF_BANK23=0.75; |
---|
| 833 | CONFIG INTERNAL_VREF_BANK33=0.75; |
---|
| 834 | |
---|
| 835 | #DCI Cascading |
---|
| 836 | CONFIG DCI_CASCADE = "23 22"; |
---|
| 837 | |
---|
| 838 | #BUFR IOBs (must be unconnected in FPGA and PCB) |
---|
| 839 | CONFIG PROHIBIT = AH17,AP20; |
---|
| 840 | |
---|
| 841 | #BUFIO IOBs (must be unconnected in FPGA and PCB) |
---|
| 842 | CONFIG PROHIBIT = AC13,AD12,AF19,AF20,AH23,AK27,AN27,AP11; |
---|
| 843 | |
---|
| 844 | ###################################################################################### |
---|
| 845 | ##Place RSYNC OSERDES and IODELAY: ## |
---|
| 846 | ###################################################################################### |
---|
| 847 | |
---|
| 848 | #MPMC as of EDK 13.4 only supports 32-bit memories |
---|
| 849 | ##Site: AH17 -- Bank 32 |
---|
| 850 | #INST "*/u_phy_read/u_phy_rdclk_gen/gen_loop_col1.u_oserdes_rsync" LOC = "OLOGIC_X2Y23"; |
---|
| 851 | #INST "*/u_phy_read/u_phy_rdclk_gen/gen_loop_col1.u_odelay_rsync" LOC = "IODELAY_X2Y23"; |
---|
| 852 | #INST "*/u_phy_read/u_phy_rdclk_gen/gen_loop_col1.u_bufr_rsync" LOC = "BUFR_X2Y1"; |
---|
| 853 | |
---|
| 854 | ##Site: AP20 -- Bank 22 |
---|
| 855 | INST "*/u_phy_read/u_phy_rdclk_gen/gen_loop_col0.u_oserdes_rsync" LOC = "OLOGIC_X1Y21"; |
---|
| 856 | INST "*/u_phy_read/u_phy_rdclk_gen/gen_loop_col0.u_odelay_rsync" LOC = "IODELAY_X1Y21"; |
---|
| 857 | INST "*/u_phy_read/u_phy_rdclk_gen/gen_loop_col0.u_bufr_rsync" LOC = "BUFR_X1Y1"; |
---|
| 858 | |
---|
| 859 | |
---|
| 860 | ###################################################################################### |
---|
| 861 | ##Place CPT OSERDES and IODELAY: ## |
---|
| 862 | ###################################################################################### |
---|
| 863 | |
---|
| 864 | ##Site: AH23 -- Bank 23 |
---|
| 865 | INST "*/u_phy_read/u_phy_rdclk_gen/gen_ck_cpt[0].u_oserdes_cpt" LOC = "OLOGIC_X1Y57"; |
---|
| 866 | INST "*/u_phy_read/u_phy_rdclk_gen/gen_ck_cpt[0].u_odelay_cpt" LOC = "IODELAY_X1Y57"; |
---|
| 867 | |
---|
| 868 | ##Site: AK27 -- Bank 23 |
---|
| 869 | INST "*/u_phy_read/u_phy_rdclk_gen/gen_ck_cpt[1].u_oserdes_cpt" LOC = "OLOGIC_X1Y59"; |
---|
| 870 | INST "*/u_phy_read/u_phy_rdclk_gen/gen_ck_cpt[1].u_odelay_cpt" LOC = "IODELAY_X1Y59"; |
---|
| 871 | |
---|
| 872 | ##Site: AN27 -- Bank 23 |
---|
| 873 | INST "*/u_phy_read/u_phy_rdclk_gen/gen_ck_cpt[2].u_oserdes_cpt" LOC = "OLOGIC_X1Y61"; |
---|
| 874 | INST "*/u_phy_read/u_phy_rdclk_gen/gen_ck_cpt[2].u_odelay_cpt" LOC = "IODELAY_X1Y61"; |
---|
| 875 | |
---|
| 876 | ##Site: AF19 -- Bank 22 |
---|
| 877 | INST "*/u_phy_read/u_phy_rdclk_gen/gen_ck_cpt[3].u_oserdes_cpt" LOC = "OLOGIC_X1Y23"; |
---|
| 878 | INST "*/u_phy_read/u_phy_rdclk_gen/gen_ck_cpt[3].u_odelay_cpt" LOC = "IODELAY_X1Y23"; |
---|
| 879 | |
---|
| 880 | #MPMC as of EDK 13.4 only supports 32-bit memories |
---|
| 881 | ##Site: AF20 -- Bank 22 |
---|
| 882 | #INST "*/u_phy_read/u_phy_rdclk_gen/gen_ck_cpt[4].u_oserdes_cpt" LOC = "OLOGIC_X1Y17"; |
---|
| 883 | #INST "*/u_phy_read/u_phy_rdclk_gen/gen_ck_cpt[4].u_odelay_cpt" LOC = "IODELAY_X1Y17"; |
---|
| 884 | |
---|
| 885 | ##Site: AP11 -- Bank 33 |
---|
| 886 | #INST "*/u_phy_read/u_phy_rdclk_gen/gen_ck_cpt[5].u_oserdes_cpt" LOC = "OLOGIC_X2Y57"; |
---|
| 887 | #INST "*/u_phy_read/u_phy_rdclk_gen/gen_ck_cpt[5].u_odelay_cpt" LOC = "IODELAY_X2Y57"; |
---|
| 888 | |
---|
| 889 | ##Site: AC13 -- Bank 33 |
---|
| 890 | #INST "*/u_phy_read/u_phy_rdclk_gen/gen_ck_cpt[6].u_oserdes_cpt" LOC = "OLOGIC_X2Y61"; |
---|
| 891 | #INST "*/u_phy_read/u_phy_rdclk_gen/gen_ck_cpt[6].u_odelay_cpt" LOC = "IODELAY_X2Y61"; |
---|
| 892 | |
---|
| 893 | ##Site: AD12 -- Bank 33 |
---|
| 894 | #INST "*/u_phy_read/u_phy_rdclk_gen/gen_ck_cpt[7].u_oserdes_cpt" LOC = "OLOGIC_X2Y59"; |
---|
| 895 | #INST "*/u_phy_read/u_phy_rdclk_gen/gen_ck_cpt[7].u_odelay_cpt" LOC = "IODELAY_X2Y59"; |
---|
| 896 | |
---|
| 897 | |
---|