diff options
Diffstat (limited to 'fpga/usrp3/top/x400')
-rw-r--r-- | fpga/usrp3/top/x400/Makefile | 31 | ||||
-rw-r--r-- | fpga/usrp3/top/x400/Makefile.x4xx.inc | 15 | ||||
-rw-r--r-- | fpga/usrp3/top/x400/x4xx.v | 114 | ||||
-rw-r--r-- | fpga/usrp3/top/x400/x4xx_core.v | 323 | ||||
-rw-r--r-- | fpga/usrp3/top/x400/x4xx_dram.v | 895 |
5 files changed, 1272 insertions, 106 deletions
diff --git a/fpga/usrp3/top/x400/Makefile b/fpga/usrp3/top/x400/Makefile index c96e9b2d0..ad519be73 100644 --- a/fpga/usrp3/top/x400/Makefile +++ b/fpga/usrp3/top/x400/Makefile @@ -42,20 +42,23 @@ QSFP1_100GBE = QSFP1_0=$(MGT_100GbE) QSFP1_1=$(MGT_Disabled) QSFP1_2=$(MGT_Disa # Target specific variables -X410_IP: DEFS = $(QSFP0_10GBE) RFBW_100M=1 -X410_X1_100: DEFS = $(QSFP0_10GBE) RFBW_100M=1 -X410_XG_100: DEFS = $(QSFP0_10GBE) $(QSFP1_10GBE) RFBW_100M=1 -X410_X4_100: DEFS = $(QSFP0_4X10GBE) RFBW_100M=1 -X410_X4C_100: DEFS = $(QSFP0_4X10GBE) $(QSFP1_100GBE) RFBW_100M=1 USE_100GBE=1 -X410_CG_100: DEFS = $(QSFP0_100GBE) RFBW_100M=1 USE_100GBE=1 -X410_CG_200: DEFS = $(QSFP0_100GBE) RFBW_200M=1 USE_100GBE=1 -X410_XG_200: DEFS = $(QSFP0_10GBE) $(QSFP1_10GBE) RFBW_200M=1 -X410_X4_200: DEFS = $(QSFP0_4X10GBE) RFBW_200M=1 -X410_X4C_200: DEFS = $(QSFP0_4X10GBE) $(QSFP1_100GBE) RFBW_200M=1 USE_100GBE=1 -X410_C1_400: DEFS = $(QSFP0_100GBE) RFBW_400M=1 USE_100GBE=1 -X410_CG_400: DEFS = $(QSFP0_100GBE) $(QSFP1_100GBE) RFBW_400M=1 USE_100GBE=1 - -DEFS += $(OPTIONS) +X410_IP: DEFS += $(QSFP0_10GBE) RFBW_100M=1 +X410_X1_100: DEFS += $(QSFP0_10GBE) RFBW_100M=1 +X410_XG_100: DEFS += $(QSFP0_10GBE) $(QSFP1_10GBE) RFBW_100M=1 +X410_X4_100: DEFS += $(QSFP0_4X10GBE) RFBW_100M=1 +X410_X4C_100: DEFS += $(QSFP0_4X10GBE) $(QSFP1_100GBE) RFBW_100M=1 +X410_CG_100: DEFS += $(QSFP0_100GBE) RFBW_100M=1 +X410_CG_200: DEFS += $(QSFP0_100GBE) RFBW_200M=1 +X410_XG_200: DEFS += $(QSFP0_10GBE) $(QSFP1_10GBE) RFBW_200M=1 +X410_X4_200: DEFS += $(QSFP0_4X10GBE) RFBW_200M=1 +X410_X4C_200: DEFS += $(QSFP0_4X10GBE) $(QSFP1_100GBE) RFBW_200M=1 +X410_C1_400: DEFS += $(QSFP0_100GBE) RFBW_400M=1 +X410_CG_400: DEFS += $(QSFP0_100GBE) $(QSFP1_100GBE) RFBW_400M=1 + +# DRAM IP inclusion. Set to 1 to include DRAM IP in design, 0 to exclude it. +DRAM ?= 1 + +DEFS += $(OPTIONS) ENABLE_DRAM=$(DRAM) # Defaults specific to the various targets: X410_100_DEFAULTS:=DEFAULT_RFNOC_IMAGE_CORE_FILE=x410_100_rfnoc_image_core.v DEFAULT_EDGE_FILE=$(abspath x410_100_static_router.hex) diff --git a/fpga/usrp3/top/x400/Makefile.x4xx.inc b/fpga/usrp3/top/x400/Makefile.x4xx.inc index fa6208088..b74eeeb02 100644 --- a/fpga/usrp3/top/x400/Makefile.x4xx.inc +++ b/fpga/usrp3/top/x400/Makefile.x4xx.inc @@ -47,6 +47,8 @@ include $(LIB_DIR)/rfnoc/blocks/rfnoc_block_null_src_sink/Makefile.srcs include $(LIB_DIR)/rfnoc/blocks/rfnoc_block_radio/Makefile.srcs include $(LIB_DIR)/rfnoc/blocks/rfnoc_block_ddc/Makefile.srcs include $(LIB_DIR)/rfnoc/blocks/rfnoc_block_duc/Makefile.srcs +include $(LIB_DIR)/rfnoc/blocks/rfnoc_block_axi_ram_fifo/Makefile.srcs +include $(LIB_DIR)/rfnoc/blocks/rfnoc_block_replay/Makefile.srcs # If out-of-tree modules want to be compiled into this image, then they need to # pass in the RFNOC_OOT_MAKEFILE_SRCS as a list of Makefile.srcs files. @@ -75,6 +77,7 @@ x4xx_versioning_regs.v \ x4xx_dio.v \ x4xx_gpio_atr.v \ x4xx_gpio_spi.v \ +x4xx_dram.v \ rf/100m/rf_core_100m.v \ rf/200m/rf_core_200m.v \ rf/200m/rf_down_4to2.v \ @@ -99,7 +102,9 @@ MB_XDC = \ constraints/pins/common.xdc \ constraints/pins/rfdc_2x2.xdc \ constraints/timing/shared_constants.sdc \ -constraints/timing/common.xdc +constraints/timing/common.xdc \ +constraints/pins/dram.xdc \ +constraints/timing/dram.xdc # Definitions # MGT Types from x4xx_mgt_type.vh @@ -140,12 +145,6 @@ ifneq (,$(findstring QSFP1_3,$(EXTRA_DEFS))) MB_XDC += constraints/pins/qsfp1_3.xdc endif -ifndef NO_DRAM_FIFOS -DRAM_SRCS = -else -DRAM_SRCS = -endif - ifdef X410 DESIGN_SRCS = $(abspath $(MB_XDC)) endif @@ -165,6 +164,8 @@ $(RADIO_SRCS) $(CAP_GEN_GENERIC_SRCS) $(IP_XCI_SRCS) $(BD_SRCS) \ $(RFNOC_SRCS) $(RFNOC_OOT_SRCS) $(LIB_IP_XCI_SRCS) $(LIB_HLS_IP_SRCS) $(LIBCOREGEN_SRCS) \ $(RFNOC_BLOCK_DUC_SRCS) $(RFNOC_BLOCK_DDC_SRCS) \ $(RFNOC_BLOCK_RADIO_SRCS) $(RFNOC_BLOCK_NULL_SRC_SINK_SRCS) \ +$(RFNOC_BLOCK_AXI_RAM_FIFO_SRCS) \ +$(RFNOC_BLOCK_REPLAY_SRCS) \ $(DB_COMMON_SRCS) $(WHITE_RABBIT_SRCS) $(RFNOC_FRAMEWORK_SRCS) \ $(WB_SPI_SRCS) $(RFNOC_XPORT_SV_SRCS) \ ) diff --git a/fpga/usrp3/top/x400/x4xx.v b/fpga/usrp3/top/x400/x4xx.v index 8338149f5..a5215f020 100644 --- a/fpga/usrp3/top/x400/x4xx.v +++ b/fpga/usrp3/top/x400/x4xx.v @@ -186,48 +186,53 @@ module x4xx ( inout wire TRIG_IO, output wire PL_CPLD_JTAGEN, output wire PL_CPLD_CS0_n, // Dual-purpose CPLD JTAG TMS - output wire PL_CPLD_CS1_n + output wire PL_CPLD_CS1_n, //----------------------------------- - // Unused pins + // DRAM //----------------------------------- - // DRAM Controller 0 - // input wire DRAM0_REFCLK_P, - // input wire DRAM0_REFCLK_N, - // output wire DRAM0_ACT_n, - // output wire [16:0] DRAM0_ADDR, - // output wire [ 1:0] DRAM0_BA, - // output wire [ 0:0] DRAM0_BG, - // output wire [ 0:0] DRAM0_CKE, - // output wire [ 0:0] DRAM0_ODT, - // output wire [ 0:0] DRAM0_CS_n, - // output wire [ 0:0] DRAM0_CLK_P, - // output wire [ 0:0] DRAM0_CLK_N, - // output wire DRAM0_RESET_n, - // inout wire [ 7:0] DRAM0_DM_n, - // inout wire [63:0] DRAM0_DQ, - // inout wire [ 7:0] DRAM0_DQS_p, - // inout wire [ 7:0] DRAM0_DQS_n, - - // DRAM Controller 1 - // input wire DRAM1_REFCLK_P, - // input wire DRAM1_REFCLK_N, - // output wire DRAM1_ACT_n, - // output wire [16:0] DRAM1_ADDR, - // output wire [ 1:0] DRAM1_BA, - // output wire [ 0:0] DRAM1_BG, - // output wire [ 0:0] DRAM1_CKE, - // output wire [ 0:0] DRAM1_ODT, - // output wire [ 0:0] DRAM1_CS_n, - // output wire [ 0:0] DRAM1_CLK_P, - // output wire [ 0:0] DRAM1_CLK_N, - // output wire DRAM1_RESET_n, - // inout wire [ 7:0] DRAM1_DM_n, - // inout wire [63:0] DRAM1_DQ, - // inout wire [ 7:0] DRAM1_DQS_p, - // inout wire [ 7:0] DRAM1_DQS_n, + // DRAM Bank 0 + input wire DRAM0_REFCLK_P, + input wire DRAM0_REFCLK_N, + output wire DRAM0_ACT_n, + output wire [16:0] DRAM0_ADDR, + output wire [ 1:0] DRAM0_BA, + output wire [ 0:0] DRAM0_BG, + output wire [ 0:0] DRAM0_CKE, + output wire [ 0:0] DRAM0_ODT, + output wire [ 0:0] DRAM0_CS_n, + output wire [ 0:0] DRAM0_CLK_P, + output wire [ 0:0] DRAM0_CLK_N, + output wire DRAM0_RESET_n, + inout wire [ 7:0] DRAM0_DM_n, + inout wire [63:0] DRAM0_DQ, + inout wire [ 7:0] DRAM0_DQS_p, + inout wire [ 7:0] DRAM0_DQS_n, + + // DRAM Bank 1 + input wire DRAM1_REFCLK_P, + input wire DRAM1_REFCLK_N, + output wire DRAM1_ACT_n, + output wire [16:0] DRAM1_ADDR, + output wire [ 1:0] DRAM1_BA, + output wire [ 0:0] DRAM1_BG, + output wire [ 0:0] DRAM1_CKE, + output wire [ 0:0] DRAM1_ODT, + output wire [ 0:0] DRAM1_CS_n, + output wire [ 0:0] DRAM1_CLK_P, + output wire [ 0:0] DRAM1_CLK_N, + output wire DRAM1_RESET_n, + inout wire [ 7:0] DRAM1_DM_n, + inout wire [63:0] DRAM1_DQ, + inout wire [ 7:0] DRAM1_DQS_p, + inout wire [ 7:0] DRAM1_DQS_n + + + //----------------------------------- + // Unused pins + //----------------------------------- // input wire [1:0] IPASS_SIDEBAND, // input wire PCIE_RESET, @@ -2053,7 +2058,8 @@ module x4xx ( .CHDR_W (CHDR_W), .MTU (CHDR_MTU), .RFNOC_PROTOVER (RFNOC_PROTOVER), - .RADIO_SPC (RADIO_SPC) + .RADIO_SPC (RADIO_SPC), + .RF_BANDWIDTH (RF_BANDWIDTH) ) x4xx_core_i ( .radio_clk (radio_clk), .radio_rst (radio_rst), @@ -2062,6 +2068,38 @@ module x4xx ( .rfnoc_chdr_rst (clk200_rst), .rfnoc_ctrl_clk (clk40), .rfnoc_ctrl_rst (clk40_rst), + .dram0_sys_clk_p (DRAM0_REFCLK_P), + .dram0_sys_clk_n (DRAM0_REFCLK_N), + .dram0_ck_t (DRAM0_CLK_P), + .dram0_ck_c (DRAM0_CLK_N), + .dram0_cs_n (DRAM0_CS_n), + .dram0_act_n (DRAM0_ACT_n), + .dram0_adr (DRAM0_ADDR), + .dram0_ba (DRAM0_BA), + .dram0_bg (DRAM0_BG), + .dram0_cke (DRAM0_CKE), + .dram0_odt (DRAM0_ODT), + .dram0_reset_n (DRAM0_RESET_n), + .dram0_dm_dbi_n (DRAM0_DM_n), + .dram0_dq (DRAM0_DQ), + .dram0_dqs_t (DRAM0_DQS_p), + .dram0_dqs_c (DRAM0_DQS_n), + .dram1_sys_clk_p (DRAM1_REFCLK_P), + .dram1_sys_clk_n (DRAM1_REFCLK_N), + .dram1_ck_t (DRAM1_CLK_P), + .dram1_ck_c (DRAM1_CLK_N), + .dram1_cs_n (DRAM1_CS_n), + .dram1_act_n (DRAM1_ACT_n), + .dram1_adr (DRAM1_ADDR), + .dram1_ba (DRAM1_BA), + .dram1_bg (DRAM1_BG), + .dram1_cke (DRAM1_CKE), + .dram1_odt (DRAM1_ODT), + .dram1_reset_n (DRAM1_RESET_n), + .dram1_dm_dbi_n (DRAM1_DM_n), + .dram1_dq (DRAM1_DQ), + .dram1_dqs_t (DRAM1_DQS_p), + .dram1_dqs_c (DRAM1_DQS_n), .s_axi_aclk (clk40), .s_axi_aresetn (clk40_rstn), .s_axi_awaddr (axi_core_awaddr[REG_AWIDTH-1:0]), diff --git a/fpga/usrp3/top/x400/x4xx_core.v b/fpga/usrp3/top/x400/x4xx_core.v index 264ace27b..c9ab18e96 100644 --- a/fpga/usrp3/top/x400/x4xx_core.v +++ b/fpga/usrp3/top/x400/x4xx_core.v @@ -1,5 +1,5 @@ // -// Copyright 2021 Ettus Research, A National Instruments Brand +// Copyright 2022 Ettus Research, a National Instruments Brand // // SPDX-License-Identifier: LGPL-3.0 // @@ -21,6 +21,7 @@ // MTU : Log2 of maximum transmission unit in CHDR_W sized words // RFNOC_PROTOVER : RFNoC protocol version (major[7:0], minor[7:0]) // RADIO_SPC : Number of samples per radio clock cycle +// RF_BANDWIDTH : RF bandwidth of each radio channel // @@ -33,17 +34,54 @@ module x4xx_core #( parameter CHDR_W = 64, parameter MTU = $clog2(8192 / (CHDR_W/8)), parameter RFNOC_PROTOVER = {8'd1, 8'd0}, - parameter RADIO_SPC = 1 + parameter RADIO_SPC = 1, + parameter RF_BANDWIDTH = 200 ) ( // Clocks and resets - input radio_clk, - input radio_rst, - input radio_clk_2x, + input wire radio_clk, + input wire radio_rst, + input wire radio_clk_2x, - input rfnoc_chdr_clk, - input rfnoc_chdr_rst, - input rfnoc_ctrl_clk, - input rfnoc_ctrl_rst, + input wire rfnoc_chdr_clk, + input wire rfnoc_chdr_rst, + input wire rfnoc_ctrl_clk, + input wire rfnoc_ctrl_rst, + + // DRAM Bank 0 + input wire dram0_sys_clk_p, + input wire dram0_sys_clk_n, + output wire dram0_ck_t, + output wire dram0_ck_c, + output wire dram0_cs_n, + output wire dram0_act_n, + output wire [ 16:0] dram0_adr, + output wire [ 1:0] dram0_ba, + output wire dram0_bg, + output wire dram0_cke, + output wire dram0_odt, + output wire dram0_reset_n, + inout wire [ 7:0] dram0_dm_dbi_n, + inout wire [ 63:0] dram0_dq, + inout wire [ 7:0] dram0_dqs_t, + inout wire [ 7:0] dram0_dqs_c, + + // DRAM Bank 1 + input wire dram1_sys_clk_p, + input wire dram1_sys_clk_n, + output wire dram1_ck_t, + output wire dram1_ck_c, + output wire dram1_cs_n, + output wire dram1_act_n, + output wire [ 16:0] dram1_adr, + output wire [ 1:0] dram1_ba, + output wire dram1_bg, + output wire dram1_cke, + output wire dram1_odt, + output wire dram1_reset_n, + inout wire [ 7:0] dram1_dm_dbi_n, + inout wire [ 63:0] dram1_dq, + inout wire [ 7:0] dram1_dqs_t, + inout wire [ 7:0] dram1_dqs_c, // AXI-Lite interface (for motherboard registers) input s_axi_aclk, @@ -185,44 +223,44 @@ module x4xx_core #( `include "../../lib/rfnoc/core/ctrlport.vh" - axil_ctrlport_master - # ( - .TIMEOUT (10), //integer:=10 - .AXI_AWIDTH (REG_AWIDTH), //integer:=17 - .CTRLPORT_AWIDTH (CTRLPORT_ADDR_W)) //integer:=17 - axil_ctrlport_masterx ( - .s_axi_aclk (s_axi_aclk), //in wire - .s_axi_aresetn (s_axi_aresetn), //in wire - .s_axi_awaddr (s_axi_awaddr), //in wire[(AXI_AWIDTH-1):0] - .s_axi_awvalid (s_axi_awvalid), //in wire - .s_axi_awready (s_axi_awready), //out wire - .s_axi_wdata (s_axi_wdata), //in wire[31:0] - .s_axi_wstrb (s_axi_wstrb), //in wire[3:0] - .s_axi_wvalid (s_axi_wvalid), //in wire - .s_axi_wready (s_axi_wready), //out wire - .s_axi_bresp (s_axi_bresp), //out wire[1:0] - .s_axi_bvalid (s_axi_bvalid), //out wire - .s_axi_bready (s_axi_bready), //in wire - .s_axi_araddr (s_axi_araddr), //in wire[(AXI_AWIDTH-1):0] - .s_axi_arvalid (s_axi_arvalid), //in wire - .s_axi_arready (s_axi_arready), //out wire - .s_axi_rdata (s_axi_rdata), //out wire[31:0] - .s_axi_rresp (s_axi_rresp), //out wire[1:0] - .s_axi_rvalid (s_axi_rvalid), //out wire - .s_axi_rready (s_axi_rready), //in wire - .m_ctrlport_req_wr (ctrlport_req_wr), //out wire - .m_ctrlport_req_rd (ctrlport_req_rd), //out wire - .m_ctrlport_req_addr (ctrlport_req_addr), //out wire[19:0] - .m_ctrlport_req_portid (ctrlport_req_portid), //out wire[9:0] - .m_ctrlport_req_rem_epid (ctrlport_req_rem_epid), //out wire[15:0] - .m_ctrlport_req_rem_portid (ctrlport_req_rem_portid), //out wire[9:0] - .m_ctrlport_req_data (ctrlport_req_data), //out wire[31:0] - .m_ctrlport_req_byte_en (ctrlport_req_byte_en), //out wire[3:0] - .m_ctrlport_req_has_time (ctrlport_req_has_time), //out wire - .m_ctrlport_req_time (ctrlport_req_time), //out wire[63:0] - .m_ctrlport_resp_ack (ctrlport_resp_ack), //in wire - .m_ctrlport_resp_status (ctrlport_resp_status), //in wire[1:0] - .m_ctrlport_resp_data (ctrlport_resp_data)); //in wire[31:0] + axil_ctrlport_master #( + .TIMEOUT (10 ), + .AXI_AWIDTH (REG_AWIDTH ), + .CTRLPORT_AWIDTH(CTRLPORT_ADDR_W) + ) axil_ctrlport_master_i ( + .s_axi_aclk (s_axi_aclk), + .s_axi_aresetn (s_axi_aresetn), + .s_axi_awaddr (s_axi_awaddr), + .s_axi_awvalid (s_axi_awvalid), + .s_axi_awready (s_axi_awready), + .s_axi_wdata (s_axi_wdata), + .s_axi_wstrb (s_axi_wstrb), + .s_axi_wvalid (s_axi_wvalid), + .s_axi_wready (s_axi_wready), + .s_axi_bresp (s_axi_bresp), + .s_axi_bvalid (s_axi_bvalid), + .s_axi_bready (s_axi_bready), + .s_axi_araddr (s_axi_araddr), + .s_axi_arvalid (s_axi_arvalid), + .s_axi_arready (s_axi_arready), + .s_axi_rdata (s_axi_rdata), + .s_axi_rresp (s_axi_rresp), + .s_axi_rvalid (s_axi_rvalid), + .s_axi_rready (s_axi_rready), + .m_ctrlport_req_wr (ctrlport_req_wr), + .m_ctrlport_req_rd (ctrlport_req_rd), + .m_ctrlport_req_addr (ctrlport_req_addr), + .m_ctrlport_req_portid (ctrlport_req_portid), + .m_ctrlport_req_rem_epid (ctrlport_req_rem_epid), + .m_ctrlport_req_rem_portid (ctrlport_req_rem_portid), + .m_ctrlport_req_data (ctrlport_req_data), + .m_ctrlport_req_byte_en (ctrlport_req_byte_en), + .m_ctrlport_req_has_time (ctrlport_req_has_time), + .m_ctrlport_req_time (ctrlport_req_time), + .m_ctrlport_resp_ack (ctrlport_resp_ack), + .m_ctrlport_resp_status (ctrlport_resp_status), + .m_ctrlport_resp_data (ctrlport_resp_data) + ); //--------------------------------------------------------------------------- @@ -353,6 +391,151 @@ module x4xx_core #( //--------------------------------------------------------------------------- + // DRAM + //--------------------------------------------------------------------------- + + // Only the 100 and 200 MHz images currently support DRAM due to FPGA + // resource limitations. For 200 MHz and below, a 64-bit interface provides + // sufficient bandwidth. + localparam ENABLE_DRAM = (`ENABLE_DRAM) && (RF_BANDWIDTH <= 200); + localparam DRAM_NUM_PORTS = 4; + localparam DRAM_AXI_DWIDTH = (RF_BANDWIDTH <= 200) ? 64 : 128; + + wire dram0_ui_clk; + wire dram0_ui_clk_sync_rst; + + wire dram_clk = dram0_ui_clk; + wire dram_rst = dram0_ui_clk_sync_rst; + wire sys_rst = rfnoc_chdr_rst; + + wire [ 32*DRAM_NUM_PORTS-1:0] dram_axi_araddr; + wire [ 2*DRAM_NUM_PORTS-1:0] dram_axi_arburst; + wire [ 4*DRAM_NUM_PORTS-1:0] dram_axi_arcache; + wire [ 1*DRAM_NUM_PORTS-1:0] dram_axi_arid; + wire [ 8*DRAM_NUM_PORTS-1:0] dram_axi_arlen; + wire [ 1*DRAM_NUM_PORTS-1:0] dram_axi_arlock; + wire [ 3*DRAM_NUM_PORTS-1:0] dram_axi_arprot; + wire [ 4*DRAM_NUM_PORTS-1:0] dram_axi_arqos; + wire [ 1*DRAM_NUM_PORTS-1:0] dram_axi_arready; + wire [ 4*DRAM_NUM_PORTS-1:0] dram_axi_arregion; + wire [ 3*DRAM_NUM_PORTS-1:0] dram_axi_arsize; + wire [ 1*DRAM_NUM_PORTS-1:0] dram_axi_arvalid; + wire [ 32*DRAM_NUM_PORTS-1:0] dram_axi_awaddr; + wire [ 2*DRAM_NUM_PORTS-1:0] dram_axi_awburst; + wire [ 4*DRAM_NUM_PORTS-1:0] dram_axi_awcache; + wire [ 1*DRAM_NUM_PORTS-1:0] dram_axi_awid; + wire [ 8*DRAM_NUM_PORTS-1:0] dram_axi_awlen; + wire [ 1*DRAM_NUM_PORTS-1:0] dram_axi_awlock; + wire [ 3*DRAM_NUM_PORTS-1:0] dram_axi_awprot; + wire [ 4*DRAM_NUM_PORTS-1:0] dram_axi_awqos; + wire [ 1*DRAM_NUM_PORTS-1:0] dram_axi_awready; + wire [ 4*DRAM_NUM_PORTS-1:0] dram_axi_awregion; + wire [ 3*DRAM_NUM_PORTS-1:0] dram_axi_awsize; + wire [ 1*DRAM_NUM_PORTS-1:0] dram_axi_awvalid; + wire [ 1*DRAM_NUM_PORTS-1:0] dram_axi_bid; + wire [ 1*DRAM_NUM_PORTS-1:0] dram_axi_bready; + wire [ 2*DRAM_NUM_PORTS-1:0] dram_axi_bresp; + wire [ 1*DRAM_NUM_PORTS-1:0] dram_axi_bvalid; + wire [ DRAM_AXI_DWIDTH*DRAM_NUM_PORTS-1:0] dram_axi_rdata; + wire [ 1*DRAM_NUM_PORTS-1:0] dram_axi_rid; + wire [ 1*DRAM_NUM_PORTS-1:0] dram_axi_rlast; + wire [ 1*DRAM_NUM_PORTS-1:0] dram_axi_rready; + wire [ 2*DRAM_NUM_PORTS-1:0] dram_axi_rresp; + wire [ 1*DRAM_NUM_PORTS-1:0] dram_axi_rvalid; + wire [ DRAM_AXI_DWIDTH*DRAM_NUM_PORTS-1:0] dram_axi_wdata; + wire [ 1*DRAM_NUM_PORTS-1:0] dram_axi_wlast; + wire [ 1*DRAM_NUM_PORTS-1:0] dram_axi_wready; + wire [DRAM_AXI_DWIDTH/8*DRAM_NUM_PORTS-1:0] dram_axi_wstrb; + wire [ 1*DRAM_NUM_PORTS-1:0] dram_axi_wvalid; + + x4xx_dram #( + .ENABLE_DRAM (ENABLE_DRAM), + .AXI_DWIDTH (DRAM_AXI_DWIDTH), + .NUM_PORTS (DRAM_NUM_PORTS) + ) x4xx_dram_i ( + .sys_rst (sys_rst), + .dram0_sys_clk_p (dram0_sys_clk_p), + .dram0_sys_clk_n (dram0_sys_clk_n), + .dram1_sys_clk_p (dram1_sys_clk_p), + .dram1_sys_clk_n (dram1_sys_clk_n), + .dram0_ui_clk (dram0_ui_clk), + .dram0_ui_clk_sync_rst (dram0_ui_clk_sync_rst), + .dram1_ui_clk (), + .dram1_ui_clk_sync_rst (), + .dram0_ck_t (dram0_ck_t), + .dram0_ck_c (dram0_ck_c), + .dram0_cs_n (dram0_cs_n), + .dram0_act_n (dram0_act_n), + .dram0_adr (dram0_adr), + .dram0_ba (dram0_ba), + .dram0_bg (dram0_bg), + .dram0_cke (dram0_cke), + .dram0_odt (dram0_odt), + .dram0_reset_n (dram0_reset_n), + .dram0_dm_dbi_n (dram0_dm_dbi_n), + .dram0_dq (dram0_dq), + .dram0_dqs_t (dram0_dqs_t), + .dram0_dqs_c (dram0_dqs_c), + .dram1_ck_t (dram1_ck_t), + .dram1_ck_c (dram1_ck_c), + .dram1_cs_n (dram1_cs_n), + .dram1_act_n (dram1_act_n), + .dram1_adr (dram1_adr), + .dram1_ba (dram1_ba), + .dram1_bg (dram1_bg), + .dram1_cke (dram1_cke), + .dram1_odt (dram1_odt), + .dram1_reset_n (dram1_reset_n), + .dram1_dm_dbi_n (dram1_dm_dbi_n), + .dram1_dq (dram1_dq), + .dram1_dqs_t (dram1_dqs_t), + .dram1_dqs_c (dram1_dqs_c), + .dram_clk (dram_clk), + .dram_rst (dram_rst), + .dram_init_calib_complete (), + .dram_axi_araddr (dram_axi_araddr), + .dram_axi_arburst (dram_axi_arburst), + .dram_axi_arcache (dram_axi_arcache), + .dram_axi_arid (dram_axi_arid), + .dram_axi_arlen (dram_axi_arlen), + .dram_axi_arlock (dram_axi_arlock), + .dram_axi_arprot (dram_axi_arprot), + .dram_axi_arqos (dram_axi_arqos), + .dram_axi_arready (dram_axi_arready), + .dram_axi_arregion (dram_axi_arregion), + .dram_axi_arsize (dram_axi_arsize), + .dram_axi_arvalid (dram_axi_arvalid), + .dram_axi_awaddr (dram_axi_awaddr), + .dram_axi_awburst (dram_axi_awburst), + .dram_axi_awcache (dram_axi_awcache), + .dram_axi_awid (dram_axi_awid), + .dram_axi_awlen (dram_axi_awlen), + .dram_axi_awlock (dram_axi_awlock), + .dram_axi_awprot (dram_axi_awprot), + .dram_axi_awqos (dram_axi_awqos), + .dram_axi_awready (dram_axi_awready), + .dram_axi_awregion (dram_axi_awregion), + .dram_axi_awsize (dram_axi_awsize), + .dram_axi_awvalid (dram_axi_awvalid), + .dram_axi_bid (dram_axi_bid), + .dram_axi_bready (dram_axi_bready), + .dram_axi_bresp (dram_axi_bresp), + .dram_axi_bvalid (dram_axi_bvalid), + .dram_axi_rdata (dram_axi_rdata), + .dram_axi_rid (dram_axi_rid), + .dram_axi_rlast (dram_axi_rlast), + .dram_axi_rready (dram_axi_rready), + .dram_axi_rresp (dram_axi_rresp), + .dram_axi_rvalid (dram_axi_rvalid), + .dram_axi_wdata (dram_axi_wdata), + .dram_axi_wlast (dram_axi_wlast), + .dram_axi_wready (dram_axi_wready), + .dram_axi_wstrb (dram_axi_wstrb), + .dram_axi_wvalid (dram_axi_wvalid) + ); + + + //--------------------------------------------------------------------------- // RFNoC Image Core //--------------------------------------------------------------------------- @@ -370,6 +553,7 @@ module x4xx_core #( .core_arst (rfnoc_ctrl_rst), .radio_clk (radio_clk), .radio_2x_clk (radio_clk_2x), + .dram_clk (dram_clk), .device_id (device_id), .m_ctrlport_radio0_req_wr (ctrlport_radio_req_wr [0* 1+: 1]), .m_ctrlport_radio0_req_rd (ctrlport_radio_req_rd [0* 1+: 1]), @@ -404,6 +588,51 @@ module x4xx_core #( .radio_tx_data_radio0 ({ tx_data[1*CHAN_W+:CHAN_W], tx_data[0*CHAN_W+:CHAN_W]}), .radio_tx_running_radio0 ({tx_running[1], tx_running[0] }), .radio_time (radio_time), + .axi_rst (dram_rst), + .m_axi_awid (dram_axi_awid), + .m_axi_awaddr (dram_axi_awaddr), + .m_axi_awlen (dram_axi_awlen), + .m_axi_awsize (dram_axi_awsize), + .m_axi_awburst (dram_axi_awburst), + .m_axi_awlock (dram_axi_awlock), + .m_axi_awcache (dram_axi_awcache), + .m_axi_awprot (dram_axi_awprot), + .m_axi_awqos (dram_axi_awqos), + .m_axi_awregion (dram_axi_awregion), + .m_axi_awuser (), + .m_axi_awvalid (dram_axi_awvalid), + .m_axi_awready (dram_axi_awready), + .m_axi_wdata (dram_axi_wdata), + .m_axi_wstrb (dram_axi_wstrb), + .m_axi_wlast (dram_axi_wlast), + .m_axi_wuser (), + .m_axi_wvalid (dram_axi_wvalid), + .m_axi_wready (dram_axi_wready), + .m_axi_bid (dram_axi_bid), + .m_axi_bresp (dram_axi_bresp), + .m_axi_buser (0), + .m_axi_bvalid (dram_axi_bvalid), + .m_axi_bready (dram_axi_bready), + .m_axi_arid (dram_axi_arid), + .m_axi_araddr (dram_axi_araddr), + .m_axi_arlen (dram_axi_arlen), + .m_axi_arsize (dram_axi_arsize), + .m_axi_arburst (dram_axi_arburst), + .m_axi_arlock (dram_axi_arlock), + .m_axi_arcache (dram_axi_arcache), + .m_axi_arprot (dram_axi_arprot), + .m_axi_arqos (dram_axi_arqos), + .m_axi_arregion (dram_axi_arregion), + .m_axi_aruser (), + .m_axi_arvalid (dram_axi_arvalid), + .m_axi_arready (dram_axi_arready), + .m_axi_rid (dram_axi_rid), + .m_axi_rdata (dram_axi_rdata), + .m_axi_rresp (dram_axi_rresp), + .m_axi_rlast (dram_axi_rlast), + .m_axi_ruser (0), + .m_axi_rvalid (dram_axi_rvalid), + .m_axi_rready (dram_axi_rready), .s_eth0_tdata (e2v_tdata [0*CHDR_W +: CHDR_W]), .s_eth0_tlast (e2v_tlast [0* 1 +: 1]), .s_eth0_tvalid (e2v_tvalid [0* 1 +: 1]), diff --git a/fpga/usrp3/top/x400/x4xx_dram.v b/fpga/usrp3/top/x400/x4xx_dram.v new file mode 100644 index 000000000..5a1b9c1b0 --- /dev/null +++ b/fpga/usrp3/top/x400/x4xx_dram.v @@ -0,0 +1,895 @@ +// +// Copyright 2022 Ettus Research, a National Instruments Brand +// +// SPDX-License-Identifier: LGPL-3.0-or-later +// +// Module: x4xx_dram +// +// Description: +// +// Contains the DRAM logic for X4xx product series. This module provides up +// to 4 separate memory interface ports (dram_axi_*). These ports are spread +// across 1 or 2 DRAM banks, with 2 or 4 ports per bank depending on the bus +// width requested. Only the DRAM banks that are used will be instantiated. +// DRAM sharing between ports is achieved using AXI Interconnect IP. +// +// Parameters: +// +// ENABLE_DRAM : Set to 1 to include the DRAM IP. Set to 0 to exclude it and +// save resources. +// AXI_DWIDTH : Data width of AXI interface to the DRAM. Can be 64 or 128. +// NUM_PORTS : Number of AXI ports to support. Can be 0, 2, or 4. +// + + +module x4xx_dram #( + parameter ENABLE_DRAM = 1, + parameter AXI_DWIDTH = 128, + parameter NUM_PORTS = 4 +) ( + + //--------------------------------------------------------------------------- + // DRAM IP Clocks and Reset + //--------------------------------------------------------------------------- + + // Asynchronous reset for DRAM IP (active-high) + input wire sys_rst, + + // Base clocks for the DRAM IP + input wire dram0_sys_clk_p, + input wire dram0_sys_clk_n, + input wire dram1_sys_clk_p, + input wire dram1_sys_clk_n, + + // DRAM interface output clocks (synchronous to the DRAM PHY) + output wire dram0_ui_clk, + output wire dram0_ui_clk_sync_rst, + output wire dram1_ui_clk, + output wire dram1_ui_clk_sync_rst, + + //------------------------------------------------------------------------- + // DRAM Bank 0 Chip Interface + //------------------------------------------------------------------------- + + output wire dram0_ck_t, + output wire dram0_ck_c, + output wire dram0_cs_n, + output wire dram0_act_n, + output wire [ 16:0] dram0_adr, + output wire [ 1:0] dram0_ba, + output wire dram0_bg, + output wire dram0_cke, + output wire dram0_odt, + output wire dram0_reset_n, + inout wire [ 7:0] dram0_dm_dbi_n, + inout wire [ 63:0] dram0_dq, + inout wire [ 7:0] dram0_dqs_t, + inout wire [ 7:0] dram0_dqs_c, + + //------------------------------------------------------------------------- + // DRAM Bank 1 Chip Interface + //------------------------------------------------------------------------- + + output wire dram1_ck_t, + output wire dram1_ck_c, + output wire dram1_cs_n, + output wire dram1_act_n, + output wire [ 16:0] dram1_adr, + output wire [ 1:0] dram1_ba, + output wire dram1_bg, + output wire dram1_cke, + output wire dram1_odt, + output wire dram1_reset_n, + inout wire [ 7:0] dram1_dm_dbi_n, + inout wire [ 63:0] dram1_dq, + inout wire [ 7:0] dram1_dqs_t, + inout wire [ 7:0] dram1_dqs_c, + + //------------------------------------------------------------------------- + // DRAM User Interfaces (Synchronous to dram_clk) + //------------------------------------------------------------------------- + + input wire dram_clk, + input wire dram_rst, + + output reg dram_init_calib_complete, + + input wire [ 32*NUM_PORTS-1:0] dram_axi_araddr, + input wire [ 2*NUM_PORTS-1:0] dram_axi_arburst, + input wire [ 4*NUM_PORTS-1:0] dram_axi_arcache, + input wire [ 1*NUM_PORTS-1:0] dram_axi_arid, + input wire [ 8*NUM_PORTS-1:0] dram_axi_arlen, + input wire [ 1*NUM_PORTS-1:0] dram_axi_arlock, + input wire [ 3*NUM_PORTS-1:0] dram_axi_arprot, + input wire [ 4*NUM_PORTS-1:0] dram_axi_arqos, + output wire [ 1*NUM_PORTS-1:0] dram_axi_arready, + input wire [ 4*NUM_PORTS-1:0] dram_axi_arregion, + input wire [ 3*NUM_PORTS-1:0] dram_axi_arsize, + input wire [ 1*NUM_PORTS-1:0] dram_axi_arvalid, + input wire [ 32*NUM_PORTS-1:0] dram_axi_awaddr, + input wire [ 2*NUM_PORTS-1:0] dram_axi_awburst, + input wire [ 4*NUM_PORTS-1:0] dram_axi_awcache, + input wire [ 1*NUM_PORTS-1:0] dram_axi_awid, + input wire [ 8*NUM_PORTS-1:0] dram_axi_awlen, + input wire [ 1*NUM_PORTS-1:0] dram_axi_awlock, + input wire [ 3*NUM_PORTS-1:0] dram_axi_awprot, + input wire [ 4*NUM_PORTS-1:0] dram_axi_awqos, + output wire [ 1*NUM_PORTS-1:0] dram_axi_awready, + input wire [ 4*NUM_PORTS-1:0] dram_axi_awregion, + input wire [ 3*NUM_PORTS-1:0] dram_axi_awsize, + input wire [ 1*NUM_PORTS-1:0] dram_axi_awvalid, + output wire [ 1*NUM_PORTS-1:0] dram_axi_bid, + input wire [ 1*NUM_PORTS-1:0] dram_axi_bready, + output wire [ 2*NUM_PORTS-1:0] dram_axi_bresp, + output wire [ 1*NUM_PORTS-1:0] dram_axi_bvalid, + output wire [ AXI_DWIDTH*NUM_PORTS-1:0] dram_axi_rdata, + output wire [ 1*NUM_PORTS-1:0] dram_axi_rid, + output wire [ 1*NUM_PORTS-1:0] dram_axi_rlast, + input wire [ 1*NUM_PORTS-1:0] dram_axi_rready, + output wire [ 2*NUM_PORTS-1:0] dram_axi_rresp, + output wire [ 1*NUM_PORTS-1:0] dram_axi_rvalid, + input wire [ AXI_DWIDTH*NUM_PORTS-1:0] dram_axi_wdata, + input wire [ 1*NUM_PORTS-1:0] dram_axi_wlast, + output wire [ 1*NUM_PORTS-1:0] dram_axi_wready, + input wire [AXI_DWIDTH/8*NUM_PORTS-1:0] dram_axi_wstrb, + input wire [ 1*NUM_PORTS-1:0] dram_axi_wvalid +); + //--------------------------------------------------------------------------- + // Assertions + //--------------------------------------------------------------------------- + + if (!( + (NUM_PORTS == 0 ) || + (NUM_PORTS == 2 && AXI_DWIDTH == 128) || + (NUM_PORTS == 4 && AXI_DWIDTH == 64) || + (NUM_PORTS == 4 && AXI_DWIDTH == 128) + )) begin : check_parameters + ERROR_Unsupported_combination_of_parameters_on_x4xx_dram(); + end + + //--------------------------------------------------------------------------- + // Calibration Complete Signal + //--------------------------------------------------------------------------- + + wire dram0_init_calib_complete_d; + wire dram1_init_calib_complete_d; + + // Combine the signals from both banks into a single "complete" signal. + always @(posedge dram_clk) begin + if (dram_rst) begin + dram_init_calib_complete <= 1'b0; + end else begin + dram_init_calib_complete <= dram0_init_calib_complete_d & + dram1_init_calib_complete_d; + end + end + + generate + + //------------------------------------------------------------------------- + // DRAM Bank 0 + //------------------------------------------------------------------------- + + if (ENABLE_DRAM && NUM_PORTS > 0) begin : gen_dram_bank0 + wire dram0_init_calib_complete; + + // DRAM IP AXI Interface + wire [ 3:0] dram0_axi_awid; + wire [ 31:0] dram0_axi_awaddr; + wire [ 7:0] dram0_axi_awlen; + wire [ 2:0] dram0_axi_awsize; + wire [ 1:0] dram0_axi_awburst; + wire [ 0:0] dram0_axi_awlock; + wire [ 3:0] dram0_axi_awcache; + wire [ 2:0] dram0_axi_awprot; + wire [ 3:0] dram0_axi_awqos; + wire dram0_axi_awvalid; + wire dram0_axi_awready; + wire [511:0] dram0_axi_wdata; + wire [ 63:0] dram0_axi_wstrb; + wire dram0_axi_wlast; + wire dram0_axi_wvalid; + wire dram0_axi_wready; + wire dram0_axi_bready; + wire [ 3:0] dram0_axi_bid; + wire [ 1:0] dram0_axi_bresp; + wire dram0_axi_bvalid; + wire [ 3:0] dram0_axi_arid; + wire [ 31:0] dram0_axi_araddr; + wire [ 7:0] dram0_axi_arlen; + wire [ 2:0] dram0_axi_arsize; + wire [ 1:0] dram0_axi_arburst; + wire [ 0:0] dram0_axi_arlock; + wire [ 3:0] dram0_axi_arcache; + wire [ 2:0] dram0_axi_arprot; + wire [ 3:0] dram0_axi_arqos; + wire dram0_axi_arvalid; + wire dram0_axi_arready; + wire dram0_axi_rready; + wire [ 3:0] dram0_axi_rid; + wire [511:0] dram0_axi_rdata; + wire [ 1:0] dram0_axi_rresp; + wire dram0_axi_rlast; + wire dram0_axi_rvalid; + + if (AXI_DWIDTH == 64) begin : gen_axi_64 + axi_inter_4x64_512_bd axi_inter_4x64_512_bd_i ( + .M0_AXI_ACLK (dram0_ui_clk ), + .M0_AXI_ARESETN (~dram0_ui_clk_sync_rst ), + .M0_AXI_araddr (dram0_axi_araddr ), + .M0_AXI_arburst (dram0_axi_arburst ), + .M0_AXI_arcache (dram0_axi_arcache ), + .M0_AXI_arid (dram0_axi_arid ), + .M0_AXI_arlen (dram0_axi_arlen ), + .M0_AXI_arlock (dram0_axi_arlock ), + .M0_AXI_arprot (dram0_axi_arprot ), + .M0_AXI_arqos (dram0_axi_arqos ), + .M0_AXI_arready (dram0_axi_arready ), + .M0_AXI_arregion( ), + .M0_AXI_arsize (dram0_axi_arsize ), + .M0_AXI_arvalid (dram0_axi_arvalid ), + .M0_AXI_awaddr (dram0_axi_awaddr ), + .M0_AXI_awburst (dram0_axi_awburst ), + .M0_AXI_awcache (dram0_axi_awcache ), + .M0_AXI_awid (dram0_axi_awid ), + .M0_AXI_awlen (dram0_axi_awlen ), + .M0_AXI_awlock (dram0_axi_awlock ), + .M0_AXI_awprot (dram0_axi_awprot ), + .M0_AXI_awqos (dram0_axi_awqos ), + .M0_AXI_awready (dram0_axi_awready ), + .M0_AXI_awregion( ), + .M0_AXI_awsize (dram0_axi_awsize ), + .M0_AXI_awvalid (dram0_axi_awvalid ), + .M0_AXI_bid (dram0_axi_bid ), + .M0_AXI_bready (dram0_axi_bready ), + .M0_AXI_bresp (dram0_axi_bresp ), + .M0_AXI_bvalid (dram0_axi_bvalid ), + .M0_AXI_rdata (dram0_axi_rdata ), + .M0_AXI_rid (dram0_axi_rid ), + .M0_AXI_rlast (dram0_axi_rlast ), + .M0_AXI_rready (dram0_axi_rready ), + .M0_AXI_rresp (dram0_axi_rresp ), + .M0_AXI_rvalid (dram0_axi_rvalid ), + .M0_AXI_wdata (dram0_axi_wdata ), + .M0_AXI_wlast (dram0_axi_wlast ), + .M0_AXI_wready (dram0_axi_wready ), + .M0_AXI_wstrb (dram0_axi_wstrb ), + .M0_AXI_wvalid (dram0_axi_wvalid ), + .S0_AXI_ACLK (dram_clk ), + .S0_AXI_ARESETN (~dram_rst ), + .S0_AXI_araddr (dram_axi_araddr [ 2*0 +: 32]), + .S0_AXI_arburst (dram_axi_arburst [ 2*0 +: 2]), + .S0_AXI_arcache (dram_axi_arcache [ 4*0 +: 4]), + .S0_AXI_arid (dram_axi_arid [ 1*0 +: 1]), + .S0_AXI_arlen (dram_axi_arlen [ 8*0 +: 8]), + .S0_AXI_arlock (dram_axi_arlock [ 1*0 +: 1]), + .S0_AXI_arprot (dram_axi_arprot [ 3*0 +: 3]), + .S0_AXI_arqos (dram_axi_arqos [ 4*0 +: 4]), + .S0_AXI_arready (dram_axi_arready [ 1*0 +: 1]), + .S0_AXI_arregion(dram_axi_arregion[ 4*0 +: 4]), + .S0_AXI_arsize (dram_axi_arsize [ 3*0 +: 3]), + .S0_AXI_arvalid (dram_axi_arvalid [ 1*0 +: 1]), + .S0_AXI_awaddr (dram_axi_awaddr [ 2*0 +: 32]), + .S0_AXI_awburst (dram_axi_awburst [ 2*0 +: 2]), + .S0_AXI_awcache (dram_axi_awcache [ 4*0 +: 4]), + .S0_AXI_awid (dram_axi_awid [ 1*0 +: 1]), + .S0_AXI_awlen (dram_axi_awlen [ 8*0 +: 8]), + .S0_AXI_awlock (dram_axi_awlock [ 1*0 +: 1]), + .S0_AXI_awprot (dram_axi_awprot [ 3*0 +: 3]), + .S0_AXI_awqos (dram_axi_awqos [ 4*0 +: 4]), + .S0_AXI_awready (dram_axi_awready [ 1*0 +: 1]), + .S0_AXI_awregion(dram_axi_awregion[ 4*0 +: 4]), + .S0_AXI_awsize (dram_axi_awsize [ 3*0 +: 3]), + .S0_AXI_awvalid (dram_axi_awvalid [ 1*0 +: 1]), + .S0_AXI_bid (dram_axi_bid [ 1*0 +: 1]), + .S0_AXI_bready (dram_axi_bready [ 1*0 +: 1]), + .S0_AXI_bresp (dram_axi_bresp [ 2*0 +: 2]), + .S0_AXI_bvalid (dram_axi_bvalid [ 1*0 +: 1]), + .S0_AXI_rdata (dram_axi_rdata [ AXI_DWIDTH*0 +: AXI_DWIDTH]), + .S0_AXI_rid (dram_axi_rid [ 1*0 +: 1]), + .S0_AXI_rlast (dram_axi_rlast [ 1*0 +: 1]), + .S0_AXI_rready (dram_axi_rready [ 1*0 +: 1]), + .S0_AXI_rresp (dram_axi_rresp [ 2*0 +: 2]), + .S0_AXI_rvalid (dram_axi_rvalid [ 1*0 +: 1]), + .S0_AXI_wdata (dram_axi_wdata [ AXI_DWIDTH*0 +: AXI_DWIDTH]), + .S0_AXI_wlast (dram_axi_wlast [ 1*0 +: 1]), + .S0_AXI_wready (dram_axi_wready [ 1*0 +: 1]), + .S0_AXI_wstrb (dram_axi_wstrb [AXI_DWIDTH/8*0 +: AXI_DWIDTH/8]), + .S0_AXI_wvalid (dram_axi_wvalid [ 1*0 +: 1]), + .S1_AXI_araddr (dram_axi_araddr [ 32*1 +: 32]), + .S1_AXI_arburst (dram_axi_arburst [ 2*1 +: 2]), + .S1_AXI_arcache (dram_axi_arcache [ 4*1 +: 4]), + .S1_AXI_arid (dram_axi_arid [ 1*1 +: 1]), + .S1_AXI_arlen (dram_axi_arlen [ 8*1 +: 8]), + .S1_AXI_arlock (dram_axi_arlock [ 1*1 +: 1]), + .S1_AXI_arprot (dram_axi_arprot [ 3*1 +: 3]), + .S1_AXI_arqos (dram_axi_arqos [ 4*1 +: 4]), + .S1_AXI_arready (dram_axi_arready [ 1*1 +: 1]), + .S1_AXI_arregion(dram_axi_arregion[ 4*1 +: 4]), + .S1_AXI_arsize (dram_axi_arsize [ 3*1 +: 3]), + .S1_AXI_arvalid (dram_axi_arvalid [ 1*1 +: 1]), + .S1_AXI_awaddr (dram_axi_awaddr [ 32*1 +: 32]), + .S1_AXI_awburst (dram_axi_awburst [ 2*1 +: 2]), + .S1_AXI_awcache (dram_axi_awcache [ 4*1 +: 4]), + .S1_AXI_awid (dram_axi_awid [ 1*1 +: 1]), + .S1_AXI_awlen (dram_axi_awlen [ 8*1 +: 8]), + .S1_AXI_awlock (dram_axi_awlock [ 1*1 +: 1]), + .S1_AXI_awprot (dram_axi_awprot [ 3*1 +: 3]), + .S1_AXI_awqos (dram_axi_awqos [ 4*1 +: 4]), + .S1_AXI_awready (dram_axi_awready [ 1*1 +: 1]), + .S1_AXI_awregion(dram_axi_awregion[ 4*1 +: 4]), + .S1_AXI_awsize (dram_axi_awsize [ 3*1 +: 3]), + .S1_AXI_awvalid (dram_axi_awvalid [ 1*1 +: 1]), + .S1_AXI_bid (dram_axi_bid [ 1*1 +: 1]), + .S1_AXI_bready (dram_axi_bready [ 1*1 +: 1]), + .S1_AXI_bresp (dram_axi_bresp [ 2*1 +: 2]), + .S1_AXI_bvalid (dram_axi_bvalid [ 1*1 +: 1]), + .S1_AXI_rdata (dram_axi_rdata [ AXI_DWIDTH*1 +: AXI_DWIDTH]), + .S1_AXI_rid (dram_axi_rid [ 1*1 +: 1]), + .S1_AXI_rlast (dram_axi_rlast [ 1*1 +: 1]), + .S1_AXI_rready (dram_axi_rready [ 1*1 +: 1]), + .S1_AXI_rresp (dram_axi_rresp [ 2*1 +: 2]), + .S1_AXI_rvalid (dram_axi_rvalid [ 1*1 +: 1]), + .S1_AXI_wdata (dram_axi_wdata [ AXI_DWIDTH*1 +: AXI_DWIDTH]), + .S1_AXI_wlast (dram_axi_wlast [ 1*1 +: 1]), + .S1_AXI_wready (dram_axi_wready [ 1*1 +: 1]), + .S1_AXI_wstrb (dram_axi_wstrb [AXI_DWIDTH/8*1 +: AXI_DWIDTH/8]), + .S1_AXI_wvalid (dram_axi_wvalid [ 1*1 +: 1]), + .S2_AXI_araddr (dram_axi_araddr [ 32*2 +: 32]), + .S2_AXI_arburst (dram_axi_arburst [ 2*2 +: 2]), + .S2_AXI_arcache (dram_axi_arcache [ 4*2 +: 4]), + .S2_AXI_arid (dram_axi_arid [ 1*2 +: 1]), + .S2_AXI_arlen (dram_axi_arlen [ 8*2 +: 8]), + .S2_AXI_arlock (dram_axi_arlock [ 1*2 +: 1]), + .S2_AXI_arprot (dram_axi_arprot [ 3*2 +: 3]), + .S2_AXI_arqos (dram_axi_arqos [ 4*2 +: 4]), + .S2_AXI_arready (dram_axi_arready [ 1*2 +: 1]), + .S2_AXI_arregion(dram_axi_arregion[ 4*2 +: 4]), + .S2_AXI_arsize (dram_axi_arsize [ 3*2 +: 3]), + .S2_AXI_arvalid (dram_axi_arvalid [ 1*2 +: 1]), + .S2_AXI_awaddr (dram_axi_awaddr [ 32*2 +: 32]), + .S2_AXI_awburst (dram_axi_awburst [ 2*2 +: 2]), + .S2_AXI_awcache (dram_axi_awcache [ 4*2 +: 4]), + .S2_AXI_awid (dram_axi_awid [ 1*2 +: 1]), + .S2_AXI_awlen (dram_axi_awlen [ 8*2 +: 8]), + .S2_AXI_awlock (dram_axi_awlock [ 1*2 +: 1]), + .S2_AXI_awprot (dram_axi_awprot [ 3*2 +: 3]), + .S2_AXI_awqos (dram_axi_awqos [ 4*2 +: 4]), + .S2_AXI_awready (dram_axi_awready [ 1*2 +: 1]), + .S2_AXI_awregion(dram_axi_awregion[ 4*2 +: 4]), + .S2_AXI_awsize (dram_axi_awsize [ 3*2 +: 3]), + .S2_AXI_awvalid (dram_axi_awvalid [ 1*2 +: 1]), + .S2_AXI_bid (dram_axi_bid [ 1*2 +: 1]), + .S2_AXI_bready (dram_axi_bready [ 1*2 +: 1]), + .S2_AXI_bresp (dram_axi_bresp [ 2*2 +: 2]), + .S2_AXI_bvalid (dram_axi_bvalid [ 1*2 +: 1]), + .S2_AXI_rdata (dram_axi_rdata [ AXI_DWIDTH*2 +: AXI_DWIDTH]), + .S2_AXI_rid (dram_axi_rid [ 1*2 +: 1]), + .S2_AXI_rlast (dram_axi_rlast [ 1*2 +: 1]), + .S2_AXI_rready (dram_axi_rready [ 1*2 +: 1]), + .S2_AXI_rresp (dram_axi_rresp [ 2*2 +: 2]), + .S2_AXI_rvalid (dram_axi_rvalid [ 1*2 +: 1]), + .S2_AXI_wdata (dram_axi_wdata [ AXI_DWIDTH*2 +: AXI_DWIDTH]), + .S2_AXI_wlast (dram_axi_wlast [ 1*2 +: 1]), + .S2_AXI_wready (dram_axi_wready [ 1*2 +: 1]), + .S2_AXI_wstrb (dram_axi_wstrb [AXI_DWIDTH/8*2 +: AXI_DWIDTH/8]), + .S2_AXI_wvalid (dram_axi_wvalid [ 1*2 +: 1]), + .S3_AXI_araddr (dram_axi_araddr [ 32*3 +: 32]), + .S3_AXI_arburst (dram_axi_arburst [ 2*3 +: 2]), + .S3_AXI_arcache (dram_axi_arcache [ 4*3 +: 4]), + .S3_AXI_arid (dram_axi_arid [ 1*3 +: 1]), + .S3_AXI_arlen (dram_axi_arlen [ 8*3 +: 8]), + .S3_AXI_arlock (dram_axi_arlock [ 1*3 +: 1]), + .S3_AXI_arprot (dram_axi_arprot [ 3*3 +: 3]), + .S3_AXI_arqos (dram_axi_arqos [ 4*3 +: 4]), + .S3_AXI_arready (dram_axi_arready [ 1*3 +: 1]), + .S3_AXI_arregion(dram_axi_arregion[ 4*3 +: 4]), + .S3_AXI_arsize (dram_axi_arsize [ 3*3 +: 3]), + .S3_AXI_arvalid (dram_axi_arvalid [ 1*3 +: 1]), + .S3_AXI_awaddr (dram_axi_awaddr [ 32*3 +: 32]), + .S3_AXI_awburst (dram_axi_awburst [ 2*3 +: 2]), + .S3_AXI_awcache (dram_axi_awcache [ 4*3 +: 4]), + .S3_AXI_awid (dram_axi_awid [ 1*3 +: 1]), + .S3_AXI_awlen (dram_axi_awlen [ 8*3 +: 8]), + .S3_AXI_awlock (dram_axi_awlock [ 1*3 +: 1]), + .S3_AXI_awprot (dram_axi_awprot [ 3*3 +: 3]), + .S3_AXI_awqos (dram_axi_awqos [ 4*3 +: 4]), + .S3_AXI_awready (dram_axi_awready [ 1*3 +: 1]), + .S3_AXI_awregion(dram_axi_awregion[ 4*3 +: 4]), + .S3_AXI_awsize (dram_axi_awsize [ 3*3 +: 3]), + .S3_AXI_awvalid (dram_axi_awvalid [ 1*3 +: 1]), + .S3_AXI_bid (dram_axi_bid [ 1*3 +: 1]), + .S3_AXI_bready (dram_axi_bready [ 1*3 +: 1]), + .S3_AXI_bresp (dram_axi_bresp [ 2*3 +: 2]), + .S3_AXI_bvalid (dram_axi_bvalid [ 1*3 +: 1]), + .S3_AXI_rdata (dram_axi_rdata [ AXI_DWIDTH*3 +: AXI_DWIDTH]), + .S3_AXI_rid (dram_axi_rid [ 1*3 +: 1]), + .S3_AXI_rlast (dram_axi_rlast [ 1*3 +: 1]), + .S3_AXI_rready (dram_axi_rready [ 1*3 +: 1]), + .S3_AXI_rresp (dram_axi_rresp [ 2*3 +: 2]), + .S3_AXI_rvalid (dram_axi_rvalid [ 1*3 +: 1]), + .S3_AXI_wdata (dram_axi_wdata [ AXI_DWIDTH*3 +: AXI_DWIDTH]), + .S3_AXI_wlast (dram_axi_wlast [ 1*3 +: 1]), + .S3_AXI_wready (dram_axi_wready [ 1*3 +: 1]), + .S3_AXI_wstrb (dram_axi_wstrb [AXI_DWIDTH/8*3 +: AXI_DWIDTH/8]), + .S3_AXI_wvalid (dram_axi_wvalid [ 1*3 +: 1]) + ); + end else begin : gen_axi_128 + axi_inter_2x128_512_bd axi_inter_2x128_512_bd_i ( + .M0_AXI_ACLK (dram0_ui_clk ), + .M0_AXI_ARESETN (~dram0_ui_clk_sync_rst ), + .M0_AXI_araddr (dram0_axi_araddr ), + .M0_AXI_arburst (dram0_axi_arburst ), + .M0_AXI_arcache (dram0_axi_arcache ), + .M0_AXI_arid (dram0_axi_arid ), + .M0_AXI_arlen (dram0_axi_arlen ), + .M0_AXI_arlock (dram0_axi_arlock ), + .M0_AXI_arprot (dram0_axi_arprot ), + .M0_AXI_arqos (dram0_axi_arqos ), + .M0_AXI_arready (dram0_axi_arready ), + .M0_AXI_arregion( ), + .M0_AXI_arsize (dram0_axi_arsize ), + .M0_AXI_arvalid (dram0_axi_arvalid ), + .M0_AXI_awaddr (dram0_axi_awaddr ), + .M0_AXI_awburst (dram0_axi_awburst ), + .M0_AXI_awcache (dram0_axi_awcache ), + .M0_AXI_awid (dram0_axi_awid ), + .M0_AXI_awlen (dram0_axi_awlen ), + .M0_AXI_awlock (dram0_axi_awlock ), + .M0_AXI_awprot (dram0_axi_awprot ), + .M0_AXI_awqos (dram0_axi_awqos ), + .M0_AXI_awready (dram0_axi_awready ), + .M0_AXI_awregion( ), + .M0_AXI_awsize (dram0_axi_awsize ), + .M0_AXI_awvalid (dram0_axi_awvalid ), + .M0_AXI_bid (dram0_axi_bid ), + .M0_AXI_bready (dram0_axi_bready ), + .M0_AXI_bresp (dram0_axi_bresp ), + .M0_AXI_bvalid (dram0_axi_bvalid ), + .M0_AXI_rdata (dram0_axi_rdata ), + .M0_AXI_rid (dram0_axi_rid ), + .M0_AXI_rlast (dram0_axi_rlast ), + .M0_AXI_rready (dram0_axi_rready ), + .M0_AXI_rresp (dram0_axi_rresp ), + .M0_AXI_rvalid (dram0_axi_rvalid ), + .M0_AXI_wdata (dram0_axi_wdata ), + .M0_AXI_wlast (dram0_axi_wlast ), + .M0_AXI_wready (dram0_axi_wready ), + .M0_AXI_wstrb (dram0_axi_wstrb ), + .M0_AXI_wvalid (dram0_axi_wvalid ), + .S0_AXI_ACLK (dram_clk ), + .S0_AXI_ARESETN (~dram_rst ), + .S0_AXI_araddr (dram_axi_araddr [ 32*0 +: 32]), + .S0_AXI_arburst (dram_axi_arburst [ 2*0 +: 2]), + .S0_AXI_arcache (dram_axi_arcache [ 4*0 +: 4]), + .S0_AXI_arid (dram_axi_arid [ 1*0 +: 1]), + .S0_AXI_arlen (dram_axi_arlen [ 8*0 +: 8]), + .S0_AXI_arlock (dram_axi_arlock [ 1*0 +: 1]), + .S0_AXI_arprot (dram_axi_arprot [ 3*0 +: 3]), + .S0_AXI_arqos (dram_axi_arqos [ 4*0 +: 4]), + .S0_AXI_arready (dram_axi_arready [ 1*0 +: 1]), + .S0_AXI_arregion(dram_axi_arregion[ 4*0 +: 4]), + .S0_AXI_arsize (dram_axi_arsize [ 3*0 +: 3]), + .S0_AXI_arvalid (dram_axi_arvalid [ 1*0 +: 1]), + .S0_AXI_awaddr (dram_axi_awaddr [ 32*0 +: 32]), + .S0_AXI_awburst (dram_axi_awburst [ 2*0 +: 2]), + .S0_AXI_awcache (dram_axi_awcache [ 4*0 +: 4]), + .S0_AXI_awid (dram_axi_awid [ 1*0 +: 1]), + .S0_AXI_awlen (dram_axi_awlen [ 8*0 +: 8]), + .S0_AXI_awlock (dram_axi_awlock [ 1*0 +: 1]), + .S0_AXI_awprot (dram_axi_awprot [ 3*0 +: 3]), + .S0_AXI_awqos (dram_axi_awqos [ 4*0 +: 4]), + .S0_AXI_awready (dram_axi_awready [ 1*0 +: 1]), + .S0_AXI_awregion(dram_axi_awregion[ 4*0 +: 4]), + .S0_AXI_awsize (dram_axi_awsize [ 3*0 +: 3]), + .S0_AXI_awvalid (dram_axi_awvalid [ 1*0 +: 1]), + .S0_AXI_bid (dram_axi_bid [ 1*0 +: 1]), + .S0_AXI_bready (dram_axi_bready [ 1*0 +: 1]), + .S0_AXI_bresp (dram_axi_bresp [ 2*0 +: 2]), + .S0_AXI_bvalid (dram_axi_bvalid [ 1*0 +: 1]), + .S0_AXI_rdata (dram_axi_rdata [ AXI_DWIDTH*0 +: AXI_DWIDTH]), + .S0_AXI_rid (dram_axi_rid [ 1*0 +: 1]), + .S0_AXI_rlast (dram_axi_rlast [ 1*0 +: 1]), + .S0_AXI_rready (dram_axi_rready [ 1*0 +: 1]), + .S0_AXI_rresp (dram_axi_rresp [ 2*0 +: 2]), + .S0_AXI_rvalid (dram_axi_rvalid [ 1*0 +: 1]), + .S0_AXI_wdata (dram_axi_wdata [ AXI_DWIDTH*0 +: AXI_DWIDTH]), + .S0_AXI_wlast (dram_axi_wlast [ 1*0 +: 1]), + .S0_AXI_wready (dram_axi_wready [ 1*0 +: 1]), + .S0_AXI_wstrb (dram_axi_wstrb [AXI_DWIDTH/8*0 +: AXI_DWIDTH/8]), + .S0_AXI_wvalid (dram_axi_wvalid [ 1*0 +: 1]), + .S1_AXI_araddr (dram_axi_araddr [ 32*1 +: 32]), + .S1_AXI_arburst (dram_axi_arburst [ 2*1 +: 2]), + .S1_AXI_arcache (dram_axi_arcache [ 4*1 +: 4]), + .S1_AXI_arid (dram_axi_arid [ 1*1 +: 1]), + .S1_AXI_arlen (dram_axi_arlen [ 8*1 +: 8]), + .S1_AXI_arlock (dram_axi_arlock [ 1*1 +: 1]), + .S1_AXI_arprot (dram_axi_arprot [ 3*1 +: 3]), + .S1_AXI_arqos (dram_axi_arqos [ 4*1 +: 4]), + .S1_AXI_arready (dram_axi_arready [ 1*1 +: 1]), + .S1_AXI_arregion(dram_axi_arregion[ 4*1 +: 4]), + .S1_AXI_arsize (dram_axi_arsize [ 3*1 +: 3]), + .S1_AXI_arvalid (dram_axi_arvalid [ 1*1 +: 1]), + .S1_AXI_awaddr (dram_axi_awaddr [ 32*1 +: 32]), + .S1_AXI_awburst (dram_axi_awburst [ 2*1 +: 2]), + .S1_AXI_awcache (dram_axi_awcache [ 4*1 +: 4]), + .S1_AXI_awid (dram_axi_awid [ 1*1 +: 1]), + .S1_AXI_awlen (dram_axi_awlen [ 8*1 +: 8]), + .S1_AXI_awlock (dram_axi_awlock [ 1*1 +: 1]), + .S1_AXI_awprot (dram_axi_awprot [ 3*1 +: 3]), + .S1_AXI_awqos (dram_axi_awqos [ 4*1 +: 4]), + .S1_AXI_awready (dram_axi_awready [ 1*1 +: 1]), + .S1_AXI_awregion(dram_axi_awregion[ 4*1 +: 4]), + .S1_AXI_awsize (dram_axi_awsize [ 3*1 +: 3]), + .S1_AXI_awvalid (dram_axi_awvalid [ 1*1 +: 1]), + .S1_AXI_bid (dram_axi_bid [ 1*1 +: 1]), + .S1_AXI_bready (dram_axi_bready [ 1*1 +: 1]), + .S1_AXI_bresp (dram_axi_bresp [ 2*1 +: 2]), + .S1_AXI_bvalid (dram_axi_bvalid [ 1*1 +: 1]), + .S1_AXI_rdata (dram_axi_rdata [ AXI_DWIDTH*1 +: AXI_DWIDTH]), + .S1_AXI_rid (dram_axi_rid [ 1*1 +: 1]), + .S1_AXI_rlast (dram_axi_rlast [ 1*1 +: 1]), + .S1_AXI_rready (dram_axi_rready [ 1*1 +: 1]), + .S1_AXI_rresp (dram_axi_rresp [ 2*1 +: 2]), + .S1_AXI_rvalid (dram_axi_rvalid [ 1*1 +: 1]), + .S1_AXI_wdata (dram_axi_wdata [ AXI_DWIDTH*1 +: AXI_DWIDTH]), + .S1_AXI_wlast (dram_axi_wlast [ 1*1 +: 1]), + .S1_AXI_wready (dram_axi_wready [ 1*1 +: 1]), + .S1_AXI_wstrb (dram_axi_wstrb [AXI_DWIDTH/8*1 +: AXI_DWIDTH/8]), + .S1_AXI_wvalid (dram_axi_wvalid [ 1*1 +: 1]) + ); + end + + ddr4_64bits ddr4_64bits_i ( + .sys_rst (sys_rst ), + .c0_sys_clk_p (dram0_sys_clk_p ), + .c0_sys_clk_n (dram0_sys_clk_n ), + .c0_ddr4_act_n (dram0_act_n ), + .c0_ddr4_adr (dram0_adr ), + .c0_ddr4_ba (dram0_ba ), + .c0_ddr4_bg (dram0_bg ), + .c0_ddr4_cke (dram0_cke ), + .c0_ddr4_odt (dram0_odt ), + .c0_ddr4_cs_n (dram0_cs_n ), + .c0_ddr4_ck_t (dram0_ck_t ), + .c0_ddr4_ck_c (dram0_ck_c ), + .c0_ddr4_reset_n (dram0_reset_n ), + .c0_ddr4_dm_dbi_n (dram0_dm_dbi_n ), + .c0_ddr4_dq (dram0_dq ), + .c0_ddr4_dqs_c (dram0_dqs_c ), + .c0_ddr4_dqs_t (dram0_dqs_t ), + .c0_init_calib_complete (dram0_init_calib_complete), + .c0_ddr4_ui_clk (dram0_ui_clk ), + .c0_ddr4_ui_clk_sync_rst(dram0_ui_clk_sync_rst ), + .dbg_clk ( ), + .c0_ddr4_aresetn (~dram0_ui_clk_sync_rst ), + .c0_ddr4_s_axi_awid (dram0_axi_awid ), + .c0_ddr4_s_axi_awaddr (dram0_axi_awaddr ), + .c0_ddr4_s_axi_awlen (dram0_axi_awlen ), + .c0_ddr4_s_axi_awsize (dram0_axi_awsize ), + .c0_ddr4_s_axi_awburst (dram0_axi_awburst ), + .c0_ddr4_s_axi_awlock (dram0_axi_awlock ), + .c0_ddr4_s_axi_awcache (dram0_axi_awcache ), + .c0_ddr4_s_axi_awprot (dram0_axi_awprot ), + .c0_ddr4_s_axi_awqos (dram0_axi_awqos ), + .c0_ddr4_s_axi_awvalid (dram0_axi_awvalid ), + .c0_ddr4_s_axi_awready (dram0_axi_awready ), + .c0_ddr4_s_axi_wdata (dram0_axi_wdata ), + .c0_ddr4_s_axi_wstrb (dram0_axi_wstrb ), + .c0_ddr4_s_axi_wlast (dram0_axi_wlast ), + .c0_ddr4_s_axi_wvalid (dram0_axi_wvalid ), + .c0_ddr4_s_axi_wready (dram0_axi_wready ), + .c0_ddr4_s_axi_bready (dram0_axi_bready ), + .c0_ddr4_s_axi_bid (dram0_axi_bid ), + .c0_ddr4_s_axi_bresp (dram0_axi_bresp ), + .c0_ddr4_s_axi_bvalid (dram0_axi_bvalid ), + .c0_ddr4_s_axi_arid (dram0_axi_arid ), + .c0_ddr4_s_axi_araddr (dram0_axi_araddr ), + .c0_ddr4_s_axi_arlen (dram0_axi_arlen ), + .c0_ddr4_s_axi_arsize (dram0_axi_arsize ), + .c0_ddr4_s_axi_arburst (dram0_axi_arburst ), + .c0_ddr4_s_axi_arlock (dram0_axi_arlock ), + .c0_ddr4_s_axi_arcache (dram0_axi_arcache ), + .c0_ddr4_s_axi_arprot (dram0_axi_arprot ), + .c0_ddr4_s_axi_arqos (dram0_axi_arqos ), + .c0_ddr4_s_axi_arvalid (dram0_axi_arvalid ), + .c0_ddr4_s_axi_arready (dram0_axi_arready ), + .c0_ddr4_s_axi_rready (dram0_axi_rready ), + .c0_ddr4_s_axi_rid (dram0_axi_rid ), + .c0_ddr4_s_axi_rdata (dram0_axi_rdata ), + .c0_ddr4_s_axi_rresp (dram0_axi_rresp ), + .c0_ddr4_s_axi_rlast (dram0_axi_rlast ), + .c0_ddr4_s_axi_rvalid (dram0_axi_rvalid ), + .dbg_bus ( ) + ); + + synchronizer synchronizer_dram0 ( + .clk(dram_clk ), + .rst(dram_rst ), + .in (dram0_init_calib_complete ), + .out(dram0_init_calib_complete_d) + ); + + end else begin : gen_dram_bank0_disable + OBUFDS OBUFDS_i ( + .O (dram0_ck_t), + .OB(dram0_ck_c), + .I (1'b0 ) + ); + + assign dram0_ui_clk = 1'b0; + assign dram0_cs_n = 1'b1; + assign dram0_act_n = 1'b1; + assign dram0_adr = 16'b0; + assign dram0_ba = 2'b0; + assign dram0_bg = 1'b0; + assign dram0_cke = 1'b0; + assign dram0_odt = 1'b0; + assign dram0_reset_n = 1'b1; + + assign dram0_init_calib_complete_d = 1'b1; + end + + //------------------------------------------------------------------------- + // DRAM Bank 1 + //------------------------------------------------------------------------- + + if (ENABLE_DRAM && NUM_PORTS > 2 && AXI_DWIDTH == 128) begin : gen_dram_bank1 + wire dram1_init_calib_complete; + + // DRAM IP AXI Interface + wire [ 3:0] dram1_axi_awid; + wire [ 31:0] dram1_axi_awaddr; + wire [ 7:0] dram1_axi_awlen; + wire [ 2:0] dram1_axi_awsize; + wire [ 1:0] dram1_axi_awburst; + wire [ 0:0] dram1_axi_awlock; + wire [ 3:0] dram1_axi_awcache; + wire [ 2:0] dram1_axi_awprot; + wire [ 3:0] dram1_axi_awqos; + wire dram1_axi_awvalid; + wire dram1_axi_awready; + wire [511:0] dram1_axi_wdata; + wire [ 63:0] dram1_axi_wstrb; + wire dram1_axi_wlast; + wire dram1_axi_wvalid; + wire dram1_axi_wready; + wire dram1_axi_bready; + wire [ 3:0] dram1_axi_bid; + wire [ 1:0] dram1_axi_bresp; + wire dram1_axi_bvalid; + wire [ 3:0] dram1_axi_arid; + wire [ 31:0] dram1_axi_araddr; + wire [ 7:0] dram1_axi_arlen; + wire [ 2:0] dram1_axi_arsize; + wire [ 1:0] dram1_axi_arburst; + wire [ 0:0] dram1_axi_arlock; + wire [ 3:0] dram1_axi_arcache; + wire [ 2:0] dram1_axi_arprot; + wire [ 3:0] dram1_axi_arqos; + wire dram1_axi_arvalid; + wire dram1_axi_arready; + wire dram1_axi_rready; + wire [ 3:0] dram1_axi_rid; + wire [511:0] dram1_axi_rdata; + wire [ 1:0] dram1_axi_rresp; + wire dram1_axi_rlast; + wire dram1_axi_rvalid; + + axi_inter_2x128_512_bd axi_inter_2x128_512_bd_i ( + .M0_AXI_ACLK (dram1_ui_clk ), + .M0_AXI_ARESETN (~dram1_ui_clk_sync_rst ), + .M0_AXI_araddr (dram1_axi_araddr ), + .M0_AXI_arburst (dram1_axi_arburst ), + .M0_AXI_arcache (dram1_axi_arcache ), + .M0_AXI_arid (dram1_axi_arid ), + .M0_AXI_arlen (dram1_axi_arlen ), + .M0_AXI_arlock (dram1_axi_arlock ), + .M0_AXI_arprot (dram1_axi_arprot ), + .M0_AXI_arqos (dram1_axi_arqos ), + .M0_AXI_arready (dram1_axi_arready ), + .M0_AXI_arregion( ), + .M0_AXI_arsize (dram1_axi_arsize ), + .M0_AXI_arvalid (dram1_axi_arvalid ), + .M0_AXI_awaddr (dram1_axi_awaddr ), + .M0_AXI_awburst (dram1_axi_awburst ), + .M0_AXI_awcache (dram1_axi_awcache ), + .M0_AXI_awid (dram1_axi_awid ), + .M0_AXI_awlen (dram1_axi_awlen ), + .M0_AXI_awlock (dram1_axi_awlock ), + .M0_AXI_awprot (dram1_axi_awprot ), + .M0_AXI_awqos (dram1_axi_awqos ), + .M0_AXI_awready (dram1_axi_awready ), + .M0_AXI_awregion( ), + .M0_AXI_awsize (dram1_axi_awsize ), + .M0_AXI_awvalid (dram1_axi_awvalid ), + .M0_AXI_bid (dram1_axi_bid ), + .M0_AXI_bready (dram1_axi_bready ), + .M0_AXI_bresp (dram1_axi_bresp ), + .M0_AXI_bvalid (dram1_axi_bvalid ), + .M0_AXI_rdata (dram1_axi_rdata ), + .M0_AXI_rid (dram1_axi_rid ), + .M0_AXI_rlast (dram1_axi_rlast ), + .M0_AXI_rready (dram1_axi_rready ), + .M0_AXI_rresp (dram1_axi_rresp ), + .M0_AXI_rvalid (dram1_axi_rvalid ), + .M0_AXI_wdata (dram1_axi_wdata ), + .M0_AXI_wlast (dram1_axi_wlast ), + .M0_AXI_wready (dram1_axi_wready ), + .M0_AXI_wstrb (dram1_axi_wstrb ), + .M0_AXI_wvalid (dram1_axi_wvalid ), + .S0_AXI_ACLK (dram_clk ), + .S0_AXI_ARESETN (~dram_rst ), + .S0_AXI_araddr (dram_axi_araddr [ 32*2 +: 32] ), + .S0_AXI_arburst (dram_axi_arburst [ 2*2 +: 2]), + .S0_AXI_arcache (dram_axi_arcache [ 4*2 +: 4]), + .S0_AXI_arid (dram_axi_arid [ 1*2 +: 1]), + .S0_AXI_arlen (dram_axi_arlen [ 8*2 +: 8]), + .S0_AXI_arlock (dram_axi_arlock [ 1*2 +: 1]), + .S0_AXI_arprot (dram_axi_arprot [ 3*2 +: 3]), + .S0_AXI_arqos (dram_axi_arqos [ 4*2 +: 4]), + .S0_AXI_arready (dram_axi_arready [ 1*2 +: 1]), + .S0_AXI_arregion(dram_axi_arregion[ 4*2 +: 4]), + .S0_AXI_arsize (dram_axi_arsize [ 3*2 +: 3]), + .S0_AXI_arvalid (dram_axi_arvalid [ 1*2 +: 1]), + .S0_AXI_awaddr (dram_axi_awaddr [ 32*2 +: 32]), + .S0_AXI_awburst (dram_axi_awburst [ 2*2 +: 2]), + .S0_AXI_awcache (dram_axi_awcache [ 4*2 +: 4]), + .S0_AXI_awid (dram_axi_awid [ 1*2 +: 1]), + .S0_AXI_awlen (dram_axi_awlen [ 8*2 +: 8]), + .S0_AXI_awlock (dram_axi_awlock [ 1*2 +: 1]), + .S0_AXI_awprot (dram_axi_awprot [ 3*2 +: 3]), + .S0_AXI_awqos (dram_axi_awqos [ 4*2 +: 4]), + .S0_AXI_awready (dram_axi_awready [ 1*2 +: 1]), + .S0_AXI_awregion(dram_axi_awregion[ 4*2 +: 4]), + .S0_AXI_awsize (dram_axi_awsize [ 3*2 +: 3]), + .S0_AXI_awvalid (dram_axi_awvalid [ 1*2 +: 1]), + .S0_AXI_bid (dram_axi_bid [ 1*2 +: 1]), + .S0_AXI_bready (dram_axi_bready [ 1*2 +: 1]), + .S0_AXI_bresp (dram_axi_bresp [ 2*2 +: 2]), + .S0_AXI_bvalid (dram_axi_bvalid [ 1*2 +: 1]), + .S0_AXI_rdata (dram_axi_rdata [ AXI_DWIDTH*2 +: AXI_DWIDTH]), + .S0_AXI_rid (dram_axi_rid [ 1*2 +: 1]), + .S0_AXI_rlast (dram_axi_rlast [ 1*2 +: 1]), + .S0_AXI_rready (dram_axi_rready [ 1*2 +: 1]), + .S0_AXI_rresp (dram_axi_rresp [ 2*2 +: 2]), + .S0_AXI_rvalid (dram_axi_rvalid [ 1*2 +: 1]), + .S0_AXI_wdata (dram_axi_wdata [ AXI_DWIDTH*2 +: AXI_DWIDTH]), + .S0_AXI_wlast (dram_axi_wlast [ 1*2 +: 1]), + .S0_AXI_wready (dram_axi_wready [ 1*2 +: 1]), + .S0_AXI_wstrb (dram_axi_wstrb [AXI_DWIDTH/8*2 +: AXI_DWIDTH/8]), + .S0_AXI_wvalid (dram_axi_wvalid [ 1*2 +: 1]), + .S1_AXI_araddr (dram_axi_araddr [ 32*3 +: 32]), + .S1_AXI_arburst (dram_axi_arburst [ 2*3 +: 2]), + .S1_AXI_arcache (dram_axi_arcache [ 4*3 +: 4]), + .S1_AXI_arid (dram_axi_arid [ 1*3 +: 1]), + .S1_AXI_arlen (dram_axi_arlen [ 8*3 +: 8]), + .S1_AXI_arlock (dram_axi_arlock [ 1*3 +: 1]), + .S1_AXI_arprot (dram_axi_arprot [ 3*3 +: 3]), + .S1_AXI_arqos (dram_axi_arqos [ 4*3 +: 4]), + .S1_AXI_arready (dram_axi_arready [ 1*3 +: 1]), + .S1_AXI_arregion(dram_axi_arregion[ 4*3 +: 4]), + .S1_AXI_arsize (dram_axi_arsize [ 3*3 +: 3]), + .S1_AXI_arvalid (dram_axi_arvalid [ 1*3 +: 1]), + .S1_AXI_awaddr (dram_axi_awaddr [ 32*3 +: 32]), + .S1_AXI_awburst (dram_axi_awburst [ 2*3 +: 2]), + .S1_AXI_awcache (dram_axi_awcache [ 4*3 +: 4]), + .S1_AXI_awid (dram_axi_awid [ 1*3 +: 1]), + .S1_AXI_awlen (dram_axi_awlen [ 8*3 +: 8]), + .S1_AXI_awlock (dram_axi_awlock [ 1*3 +: 1]), + .S1_AXI_awprot (dram_axi_awprot [ 3*3 +: 3]), + .S1_AXI_awqos (dram_axi_awqos [ 4*3 +: 4]), + .S1_AXI_awready (dram_axi_awready [ 1*3 +: 1]), + .S1_AXI_awregion(dram_axi_awregion[ 4*3 +: 4]), + .S1_AXI_awsize (dram_axi_awsize [ 3*3 +: 3]), + .S1_AXI_awvalid (dram_axi_awvalid [ 1*3 +: 1]), + .S1_AXI_bid (dram_axi_bid [ 1*3 +: 1]), + .S1_AXI_bready (dram_axi_bready [ 1*3 +: 1]), + .S1_AXI_bresp (dram_axi_bresp [ 2*3 +: 2]), + .S1_AXI_bvalid (dram_axi_bvalid [ 1*3 +: 1]), + .S1_AXI_rdata (dram_axi_rdata [ AXI_DWIDTH*3 +: AXI_DWIDTH]), + .S1_AXI_rid (dram_axi_rid [ 1*3 +: 1]), + .S1_AXI_rlast (dram_axi_rlast [ 1*3 +: 1]), + .S1_AXI_rready (dram_axi_rready [ 1*3 +: 1]), + .S1_AXI_rresp (dram_axi_rresp [ 2*3 +: 2]), + .S1_AXI_rvalid (dram_axi_rvalid [ 1*3 +: 1]), + .S1_AXI_wdata (dram_axi_wdata [ AXI_DWIDTH*3 +: AXI_DWIDTH]), + .S1_AXI_wlast (dram_axi_wlast [ 1*3 +: 1]), + .S1_AXI_wready (dram_axi_wready [ 1*3 +: 1]), + .S1_AXI_wstrb (dram_axi_wstrb [AXI_DWIDTH/8*3 +: AXI_DWIDTH/8]), + .S1_AXI_wvalid (dram_axi_wvalid [ 1*3 +: 1]) + ); + + ddr4_64bits ddr4_64bits_i ( + .sys_rst (sys_rst ), + .c0_sys_clk_p (dram1_sys_clk_p ), + .c0_sys_clk_n (dram1_sys_clk_n ), + .c0_ddr4_act_n (dram1_act_n ), + .c0_ddr4_adr (dram1_adr ), + .c0_ddr4_ba (dram1_ba ), + .c0_ddr4_bg (dram1_bg ), + .c0_ddr4_cke (dram1_cke ), + .c0_ddr4_odt (dram1_odt ), + .c0_ddr4_cs_n (dram1_cs_n ), + .c0_ddr4_ck_t (dram1_ck_t ), + .c0_ddr4_ck_c (dram1_ck_c ), + .c0_ddr4_reset_n (dram1_reset_n ), + .c0_ddr4_dm_dbi_n (dram1_dm_dbi_n ), + .c0_ddr4_dq (dram1_dq ), + .c0_ddr4_dqs_c (dram1_dqs_c ), + .c0_ddr4_dqs_t (dram1_dqs_t ), + .c0_init_calib_complete (dram1_init_calib_complete), + .c0_ddr4_ui_clk (dram1_ui_clk ), + .c0_ddr4_ui_clk_sync_rst(dram1_ui_clk_sync_rst ), + .dbg_clk ( ), + .c0_ddr4_aresetn (~dram1_ui_clk_sync_rst ), + .c0_ddr4_s_axi_awid (dram1_axi_awid ), + .c0_ddr4_s_axi_awaddr (dram1_axi_awaddr ), + .c0_ddr4_s_axi_awlen (dram1_axi_awlen ), + .c0_ddr4_s_axi_awsize (dram1_axi_awsize ), + .c0_ddr4_s_axi_awburst (dram1_axi_awburst ), + .c0_ddr4_s_axi_awlock (dram1_axi_awlock ), + .c0_ddr4_s_axi_awcache (dram1_axi_awcache ), + .c0_ddr4_s_axi_awprot (dram1_axi_awprot ), + .c0_ddr4_s_axi_awqos (dram1_axi_awqos ), + .c0_ddr4_s_axi_awvalid (dram1_axi_awvalid ), + .c0_ddr4_s_axi_awready (dram1_axi_awready ), + .c0_ddr4_s_axi_wdata (dram1_axi_wdata ), + .c0_ddr4_s_axi_wstrb (dram1_axi_wstrb ), + .c0_ddr4_s_axi_wlast (dram1_axi_wlast ), + .c0_ddr4_s_axi_wvalid (dram1_axi_wvalid ), + .c0_ddr4_s_axi_wready (dram1_axi_wready ), + .c0_ddr4_s_axi_bready (dram1_axi_bready ), + .c0_ddr4_s_axi_bid (dram1_axi_bid ), + .c0_ddr4_s_axi_bresp (dram1_axi_bresp ), + .c0_ddr4_s_axi_bvalid (dram1_axi_bvalid ), + .c0_ddr4_s_axi_arid (dram1_axi_arid ), + .c0_ddr4_s_axi_araddr (dram1_axi_araddr ), + .c0_ddr4_s_axi_arlen (dram1_axi_arlen ), + .c0_ddr4_s_axi_arsize (dram1_axi_arsize ), + .c0_ddr4_s_axi_arburst (dram1_axi_arburst ), + .c0_ddr4_s_axi_arlock (dram1_axi_arlock ), + .c0_ddr4_s_axi_arcache (dram1_axi_arcache ), + .c0_ddr4_s_axi_arprot (dram1_axi_arprot ), + .c0_ddr4_s_axi_arqos (dram1_axi_arqos ), + .c0_ddr4_s_axi_arvalid (dram1_axi_arvalid ), + .c0_ddr4_s_axi_arready (dram1_axi_arready ), + .c0_ddr4_s_axi_rready (dram1_axi_rready ), + .c0_ddr4_s_axi_rid (dram1_axi_rid ), + .c0_ddr4_s_axi_rdata (dram1_axi_rdata ), + .c0_ddr4_s_axi_rresp (dram1_axi_rresp ), + .c0_ddr4_s_axi_rlast (dram1_axi_rlast ), + .c0_ddr4_s_axi_rvalid (dram1_axi_rvalid ), + .dbg_bus ( ) + ); + + synchronizer synchronizer_dram1 ( + .clk(dram_clk ), + .rst(dram_rst ), + .in (dram1_init_calib_complete ), + .out(dram1_init_calib_complete_d) + ); + + end else begin : gen_dram_bank1_disable + OBUFDS OBUFDS_i ( + .O (dram1_ck_t), + .OB(dram1_ck_c), + .I (1'b0 ) + ); + + assign dram1_ui_clk = 1'b0; + assign dram1_cs_n = 1'b1; + assign dram1_act_n = 1'b1; + assign dram1_adr = 16'b0; + assign dram1_ba = 2'b0; + assign dram1_bg = 1'b0; + assign dram1_cke = 1'b0; + assign dram1_odt = 1'b0; + assign dram1_reset_n = 1'b1; + + assign dram1_init_calib_complete_d = 1'b1; + end + + endgenerate + +endmodule |