# Transceivers Xilinx

# Introducción

Este documento tiene como objetivo explicar los conceptos básicos sobre el uso de transceivers de Xilinx.

# Puertos básicos

| Nombre                     | Dirección | Tamaño            | Función                                                                                                                                        |
|----------------------------|-----------|-------------------|------------------------------------------------------------------------------------------------------------------------------------------------|
| gtwiz_reset_clk_freerun_in | In        | 1                 | Entrada de reloj del<br>sistema, nunca superior<br>a 250MHz                                                                                    |
| gtwiz_userclk_tx_active_in | In        | 1                 | Entrada de activación de Tx. Esta entrada tiene que estar sincronizada. Activa a nivel alto.                                                   |
| gtwiz_userclk_rx_active_in | In        |                   | Entrada de activación de Rx. Esta entrada tiene que estar sincronizada. Activa a nivel alto.                                                   |
| gtwiz_reset_all_in         | In        | 1                 | Reset global del<br>Transceiver                                                                                                                |
| gtwiz_userdata_tx_in       | In        | 32/40 x N.º canal | Salida de datos por el<br>Transceiver                                                                                                          |
| gtwiz_userdata_rx_out      | Out       | 32/40 x N.º canal | Entrada de datos por el transceiver                                                                                                            |
| gtrefclk00_in              | In        | 1                 | Reloj de referencia, este<br>reloj no tiene mucho<br>valor. Viene de la salida<br>de un IBUFGDS_GTE3<br>con entrada de los<br>relojes del MGT. |
| gthrxn_in                  | In        | 1                 | Entradas que vienen del                                                                                                                        |
| gthrxp_in                  | In        | 1                 | exterior. No se define el<br>pin en el XDC de este<br>puerto. (es posible que<br>está sea la entrada<br>exterior del transceiver)              |
| gthtxn_out                 | Out       | 1                 | Salidas que vienen del                                                                                                                         |
| gthtxp_out                 | Out       | 1                 | exterior. No se define el<br>pin en el XDC de este<br>puerto. (es posible que<br>está sea la salida<br>exterior del transceiver)               |

| rxoutclk_out                         | Out | 1  | Reloj de salida de Rx,<br>va a un BUFG_GT                                                                          |
|--------------------------------------|-----|----|--------------------------------------------------------------------------------------------------------------------|
| txoutclk_out                         | Out | 1  | Reloj de salida de Tx,<br>va a un BUFG_GT                                                                          |
| rxusrclk_in                          | In  | 1  | Reloj de Rx. Este reloj                                                                                            |
| rxusrclk2_in                         | In  | 1  | proviene de un BUFG_GT del puerto de salida rxoutclk_out. El reloj útil para el trabajo en FPGA es el rxusrclk2_in |
| txusrclk_in                          | In  | 1  | Reloj de Tx. Este reloj                                                                                            |
| txusrclk2_in                         | In  | 1  | proviene de un BUFG_GT del puerto de salida txoutclk_out. El reloj útil para el trabajo en FPGA es el txusrclk2_in |
| <señales de="" entrada=""></señales> | In  |    | Señales activas a '1', se pueden meter a un VIO, con el reloj de txusrclk2_in o rxusrclk2_in                       |
| <señales de="" salida=""></señales>  | Out | ** | Señales activas a '1', se pueden meter a un ILA o a un VIO, con el reloj de txusrclk2_in o rxusrclk2_in            |

# Relojes

## Reloj para Freerun

Con un reloj diferencial se utiliza un IBUFGDS que convierte la señal en una señal de una línea, después, se pasa por un PLL para rebajarla a 100MHz, y por último, se utiliza un BUFG para conseguir la señal CLK\_FREERUN.



# • Reloj para referencia

Para conseguir el reloj de referencia gtrefclk00\_in se tiene que coger las señales de reloj diferenciales del transceiver a 125MHz y se pasan por un IBUFGDS\_GTE3.



## • Relojes de trabajo

Los relojes de trabajo y fundamentales del transceiver provienen de los puertos de salida del propio transceiver, estos puertos son el *rxoutclk\_out* y el *txoutclk\_out*. Estos relojes se pasan cada uno por un **BUFG\_GT**, dónde se pueden dividir sus frecuencias en caso de ser necesario. Estos relojes son también entradas del propio transceiver por los puertos r*xusrclk\_in*, *rxusrclk2\_in*, *txusrclk\_in* y *txusrclk2\_in*. Estos relojes tienen que estar sincronizados entre '1' y '2' (*aunque no tengan la misma frecuencia*). El reloj útil para la FPGA es el '2'.



Ejemplos de fabricante (documentación):





