# DDRydyless.com Xilinx

# Introducción

## **Puertos básicos**

| Nombre                  | Dirección | Tamaño       | Función                                                                                   |
|-------------------------|-----------|--------------|-------------------------------------------------------------------------------------------|
| c0_init_calib_complete  | Out       | 1            | Salida que determina<br>cuando la calibración<br>está completa. Se puede<br>dejar abierta |
| dbg_clk                 | Out       | 1            | Reloj de depuración. Se puede dejar al aire                                               |
| c0_sys_clk_i            | In        | 1            | Reloj de entrada del<br>controlador de la DDR.<br>Viene del exterior.                     |
| sys_rst                 | In        | 1            | Reset de entrada, activo a nivel alto                                                     |
| dbg_bus                 | Out       | 8 x 64 = 512 | Salida de depuración.<br>Se puede dejar al aire                                           |
| c0_ddr4_adr             | Out       | 17           | Puertos de salida para<br>la DDR                                                          |
| c0_ddr4_ba              | Out       | 2            |                                                                                           |
| c0_ddr4_cke             | Out       | 1            |                                                                                           |
| c0_ddr4_cs_n            | Out       | 1            |                                                                                           |
| c0_ddr4_dm_dbi_n        | Inout     | 8            |                                                                                           |
| c0_ddr4_dq              | Inout     | 8 x 8 = 64   |                                                                                           |
| c0_ddr4_dqs_c           | Inout     | 8            |                                                                                           |
| c0_ddr4_dqs_t           | Inout     | 8            |                                                                                           |
| c0_ddr4_odt             | Out       | 1            |                                                                                           |
| c0_ddr4_bg              | Out       | 1            |                                                                                           |
| c0_ddr4_reset_n         | Out       | 1            |                                                                                           |
| c0_ddr4_act_n           | Out       | 1            |                                                                                           |
| c0_ddr4_ck_c            | Out       | 1            |                                                                                           |
| c0_ddr4_ck_t            | Out       | 1            |                                                                                           |
| c0_ddr4_ui_clk          | Out       | 1            | Reloj de salida para<br>utilizarlo en la FPGA                                             |
| c0_ddr4_ui_clk_sync_rst | Out       | 1            | Reset de salida para<br>utilizarlo en la FPGA                                             |
| c0_ddr4_app_en          | In        | 1            | Señal de enable del<br>controlador de la DDR                                              |

| c0_ddr4_app_hi_pri        | In  | 1   | Señal que indica la<br>prioridad en la DDR, se<br>puede obviar<br>poniéndola a nivel bajo.               |
|---------------------------|-----|-----|----------------------------------------------------------------------------------------------------------|
| c0_ddr4_app_wdf_end       | In  | 1   | Señal que indica la<br>finalización del envío<br>de un dato                                              |
| c0_ddr4_app_wdf_wren      | In  | 1   | Señal que habilita la escritura de datos                                                                 |
| c0_ddr4_app_wdf_rdy       | Out | 1   | Señal que indica que la escritura está disponible para usarse                                            |
| c0_ddr4_app_wdf_data      | In  | 512 | Señal de datos de escritura                                                                              |
| c0_ddr4_app_rd_data_end   | Out | 1   | Señal que indica que la lectura se ha terminado                                                          |
| c0_ddr4_app_rd_data_valid | Out | 1   | Señal que indica que el dato leído es válido                                                             |
| c0_ddr4_app_rdy           | Out | 1   | Señal que indica que la lectura está disponible para usarse.                                             |
| c0_ddr4_app_rd_data       | Out | 512 | Señal con los datos<br>leídos de la memoria                                                              |
| c0_ddr4_app_addr          | In  | 29  | Señal dónde se escribe<br>la dirección dónde se<br>quiere escribir                                       |
| c0_ddr4_app_cmd           | In  | 3   | Señal que indica el<br>comando para el<br>controlador de la DDR.<br>"000" → escritura<br>"001" → lectura |
| c0_ddr4_app_wdf_mask      | In  | 64  | Máscara de datos de<br>salida, se puede dejar a<br>nivel bajo todos los bits                             |

### **Escritura**

Para la escritura hay que seguir el siguiente formato de activación.



<sup>\*</sup>En la lectura real de la DDR tarda un tiempo entre que se manda la orden y se escribe en la memoria. Este tiempo se llama CAS.

### Lectura

Para la lectura hay que seguir el siguiente diagrama temporal.



<sup>\*</sup>En la lectura real de la DDR tarda un tiempo entre que se manda la orden y se lee de la memoria. Este tiempo se llama CAS.