diff options
Diffstat (limited to 'fpga')
| -rw-r--r-- | fpga/usrp3/top/x400/Makefile | 25 | ||||
| -rw-r--r-- | fpga/usrp3/top/x400/x410_400_128_rfnoc_image_core.v | 1435 | ||||
| -rw-r--r-- | fpga/usrp3/top/x400/x410_400_128_rfnoc_image_core.vh | 21 | ||||
| -rw-r--r-- | fpga/usrp3/top/x400/x410_400_128_rfnoc_image_core.yml | 118 | ||||
| -rw-r--r-- | fpga/usrp3/top/x400/x410_400_128_static_router.hex | 17 | 
5 files changed, 1613 insertions, 3 deletions
| diff --git a/fpga/usrp3/top/x400/Makefile b/fpga/usrp3/top/x400/Makefile index ce5134932..b73b94872 100644 --- a/fpga/usrp3/top/x400/Makefile +++ b/fpga/usrp3/top/x400/Makefile @@ -53,6 +53,9 @@ X410_X1_200:  DEFS += $(QSFP0_10GBE)                   RFBW_200M=1 DRAM_CH=4*$(D  X410_XG_200:  DEFS += $(QSFP0_10GBE)   $(QSFP1_10GBE)  RFBW_200M=1 DRAM_CH=4*$(DRAM) DRAM_W=64  X410_X4_200:  DEFS += $(QSFP0_4X10GBE)                 RFBW_200M=1 DRAM_CH=4*$(DRAM) DRAM_W=64  X410_X4C_200: DEFS += $(QSFP0_4X10GBE) $(QSFP1_100GBE) RFBW_200M=1 DRAM_CH=0 +X410_X1_400:  DEFS += $(QSFP0_10GBE)                   RFBW_400M=1 DRAM_CH=4*$(DRAM) DRAM_W=128 +X410_XG_400:  DEFS += $(QSFP0_10GBE)   $(QSFP1_10GBE)  RFBW_400M=1 DRAM_CH=4*$(DRAM) DRAM_W=128 +X410_X4_400:  DEFS += $(QSFP0_4X10GBE)                 RFBW_400M=1 DRAM_CH=4*$(DRAM) DRAM_W=128  X410_C1_400:  DEFS += $(QSFP0_100GBE)                  RFBW_400M=1 DRAM_CH=0  X410_CG_400:  DEFS += $(QSFP0_100GBE)  $(QSFP1_100GBE) RFBW_400M=1 DRAM_CH=0 @@ -63,9 +66,10 @@ DRAM ?= 1  DEFS += $(OPTIONS)  # 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) -X410_200_DEFAULTS:=DEFAULT_RFNOC_IMAGE_CORE_FILE=x410_200_rfnoc_image_core.v DEFAULT_EDGE_FILE=$(abspath x410_200_static_router.hex) -X410_400_DEFAULTS:=DEFAULT_RFNOC_IMAGE_CORE_FILE=x410_400_rfnoc_image_core.v DEFAULT_EDGE_FILE=$(abspath x410_400_static_router.hex) +X410_100_DEFAULTS     := DEFAULT_RFNOC_IMAGE_CORE_FILE=x410_100_rfnoc_image_core.v     DEFAULT_EDGE_FILE=$(abspath x410_100_static_router.hex) +X410_200_DEFAULTS     := DEFAULT_RFNOC_IMAGE_CORE_FILE=x410_200_rfnoc_image_core.v     DEFAULT_EDGE_FILE=$(abspath x410_200_static_router.hex) +X410_400_DEFAULTS     := DEFAULT_RFNOC_IMAGE_CORE_FILE=x410_400_rfnoc_image_core.v     DEFAULT_EDGE_FILE=$(abspath x410_400_static_router.hex) +X410_400_128_DEFAULTS := DEFAULT_RFNOC_IMAGE_CORE_FILE=x410_400_128_rfnoc_image_core.v DEFAULT_EDGE_FILE=$(abspath x410_400_128_static_router.hex)  # Option to stop after RTL elaboration. Use this flag as a synthesis check. @@ -110,6 +114,9 @@ vivado_ip = make -f Makefile.x4xx.inc viv_ip NAME=$@ ARCH=$(XIL_ARCH_$1) PART_ID  ##X410_X1_200 | 200 MHz   | 10 GbE (Lane 0) | None            | 64b x 4 Ch  ##X410_XG_200 | 200 MHz   | 10 GbE (Lane 0) | 10 GbE (Lane 0) | 64b x 4 Ch  ##X410_X4_200 | 200 MHz   | 4 x 10 GbE      | None            | 64b x 4 Ch +##X410_X1_400 | 400 MHz   | 10 GbE (Lane 0) | None            | 128b x 4 Ch +##X410_XG_400 | 400 MHz   | 10 GbE (Lane 0) | 10 GbE (Lane 0) | 128b x 4 ch +##X410_X4_400 | 400 MHz   | 4 x 10 GbE      | None            | 128b x 4 Ch  ##X410_C1_400 | 400 MHz   | 100 GbE         | None            | None  ##X410_CG_400 | 400 MHz   | 100 GbE         | 100 GbE         | None  ##* Note: Not all targets are shipped with UHD @@ -138,6 +145,18 @@ X410_X4_200: build/usrp_x410_fpga_X4_200.dts  	$(call vivado_build,X410,$(DEFS) X410=1,$(X410_200_DEFAULTS))  	$(call post_build,X410,X4_200) +X410_X1_400: build/usrp_x410_fpga_X1_400.dts +	$(call vivado_build,X410,$(DEFS) X410=1,$(X410_400_128_DEFAULTS)) +	$(call post_build,X410,X1_400) + +X410_XG_400: build/usrp_x410_fpga_XG_400.dts +	$(call vivado_build,X410,$(DEFS) X410=1,$(X410_400_128_DEFAULTS)) +	$(call post_build,X410,XG_400) + +X410_X4_400: build/usrp_x410_fpga_X4_400.dts +	$(call vivado_build,X410,$(DEFS) X410=1,$(X410_400_128_DEFAULTS)) +	$(call post_build,X410,X4_400) +  X410_C1_400: build/usrp_x410_fpga_C1_400.dts  	$(call vivado_build,X410,$(DEFS) X410=1,$(X410_400_DEFAULTS))  	$(call post_build,X410,C1_400) diff --git a/fpga/usrp3/top/x400/x410_400_128_rfnoc_image_core.v b/fpga/usrp3/top/x400/x410_400_128_rfnoc_image_core.v new file mode 100644 index 000000000..d31cc728e --- /dev/null +++ b/fpga/usrp3/top/x400/x410_400_128_rfnoc_image_core.v @@ -0,0 +1,1435 @@ +// +// Copyright 2022 Ettus Research, A National Instruments Brand +// +// SPDX-License-Identifier: LGPL-3.0-or-later +// +// Module: rfnoc_image_core (for x410) +// +// Description: +// +//   The RFNoC Image Core contains the Verilog description of the RFNoC design +//   to be loaded onto the FPGA. +// +//   This file was automatically generated by the RFNoC image builder tool. +//   Re-running that tool will overwrite this file! +// +// File generated on: 2022-03-14T16:50:52.296419 +// Source: ./x410_400_128_rfnoc_image_core.yml +// Source SHA256: 78673c977afc0a046ef08c3070fd3600aac7ba8918ce79c698731d693678cd85 +// + +`default_nettype none + + +module rfnoc_image_core #( +  parameter        CHDR_W     = 128, +  parameter        MTU        = 10, +  parameter [15:0] PROTOVER   = {8'd1, 8'd0}, +  parameter        RADIO_NIPC = 1 +) ( +  // Clocks +  input  wire         chdr_aclk, +  input  wire         ctrl_aclk, +  input  wire         core_arst, +  input  wire         radio_clk, +  input  wire         radio_2x_clk, +  input  wire         dram_clk, +  // Basic +  input  wire [  15:0] device_id, + +  // IO ports ///////////////////////// + +  // ctrlport_radio0 +  output wire [   0:0] m_ctrlport_radio0_req_wr, +  output wire [   0:0] m_ctrlport_radio0_req_rd, +  output wire [  19:0] m_ctrlport_radio0_req_addr, +  output wire [  31:0] m_ctrlport_radio0_req_data, +  output wire [   3:0] m_ctrlport_radio0_req_byte_en, +  output wire [   0:0] m_ctrlport_radio0_req_has_time, +  output wire [  63:0] m_ctrlport_radio0_req_time, +  input  wire [   0:0] m_ctrlport_radio0_resp_ack, +  input  wire [   1:0] m_ctrlport_radio0_resp_status, +  input  wire [  31:0] m_ctrlport_radio0_resp_data, +  // ctrlport_radio1 +  output wire [   0:0] m_ctrlport_radio1_req_wr, +  output wire [   0:0] m_ctrlport_radio1_req_rd, +  output wire [  19:0] m_ctrlport_radio1_req_addr, +  output wire [  31:0] m_ctrlport_radio1_req_data, +  output wire [   3:0] m_ctrlport_radio1_req_byte_en, +  output wire [   0:0] m_ctrlport_radio1_req_has_time, +  output wire [  63:0] m_ctrlport_radio1_req_time, +  input  wire [   0:0] m_ctrlport_radio1_resp_ack, +  input  wire [   1:0] m_ctrlport_radio1_resp_status, +  input  wire [  31:0] m_ctrlport_radio1_resp_data, +  // time +  input  wire [  63:0] radio_time, +  // radio0 +  input  wire [ 255:0] radio_rx_data_radio0, +  input  wire [   7:0] radio_rx_stb_radio0, +  output wire [   7:0] radio_rx_running_radio0, +  output wire [ 255:0] radio_tx_data_radio0, +  input  wire [   7:0] radio_tx_stb_radio0, +  output wire [   7:0] radio_tx_running_radio0, +  // radio1 +  input  wire [ 255:0] radio_rx_data_radio1, +  input  wire [   7:0] radio_rx_stb_radio1, +  output wire [   7:0] radio_rx_running_radio1, +  output wire [ 255:0] radio_tx_data_radio1, +  input  wire [   7:0] radio_tx_stb_radio1, +  output wire [   7:0] radio_tx_running_radio1, +  // dram +  input  wire [   0:0] axi_rst, +  output wire [   3:0] m_axi_awid, +  output wire [ 191:0] m_axi_awaddr, +  output wire [  31:0] m_axi_awlen, +  output wire [  11:0] m_axi_awsize, +  output wire [   7:0] m_axi_awburst, +  output wire [   3:0] m_axi_awlock, +  output wire [  15:0] m_axi_awcache, +  output wire [  11:0] m_axi_awprot, +  output wire [  15:0] m_axi_awqos, +  output wire [  15:0] m_axi_awregion, +  output wire [   3:0] m_axi_awuser, +  output wire [   3:0] m_axi_awvalid, +  input  wire [   3:0] m_axi_awready, +  output wire [2047:0] m_axi_wdata, +  output wire [ 255:0] m_axi_wstrb, +  output wire [   3:0] m_axi_wlast, +  output wire [   3:0] m_axi_wuser, +  output wire [   3:0] m_axi_wvalid, +  input  wire [   3:0] m_axi_wready, +  input  wire [   3:0] m_axi_bid, +  input  wire [   7:0] m_axi_bresp, +  input  wire [   3:0] m_axi_buser, +  input  wire [   3:0] m_axi_bvalid, +  output wire [   3:0] m_axi_bready, +  output wire [   3:0] m_axi_arid, +  output wire [ 191:0] m_axi_araddr, +  output wire [  31:0] m_axi_arlen, +  output wire [  11:0] m_axi_arsize, +  output wire [   7:0] m_axi_arburst, +  output wire [   3:0] m_axi_arlock, +  output wire [  15:0] m_axi_arcache, +  output wire [  11:0] m_axi_arprot, +  output wire [  15:0] m_axi_arqos, +  output wire [  15:0] m_axi_arregion, +  output wire [   3:0] m_axi_aruser, +  output wire [   3:0] m_axi_arvalid, +  input  wire [   3:0] m_axi_arready, +  input  wire [   3:0] m_axi_rid, +  input  wire [2047:0] m_axi_rdata, +  input  wire [   7:0] m_axi_rresp, +  input  wire [   3:0] m_axi_rlast, +  input  wire [   3:0] m_axi_ruser, +  input  wire [   3:0] m_axi_rvalid, +  output wire [   3:0] m_axi_rready, + +  // Transport Adapters /////////////// + +  // Transport 0 (eth0) +  input  wire [CHDR_W-1:0] s_eth0_tdata, +  input  wire              s_eth0_tlast, +  input  wire              s_eth0_tvalid, +  output wire              s_eth0_tready, +  output wire [CHDR_W-1:0] m_eth0_tdata, +  output wire              m_eth0_tlast, +  output wire              m_eth0_tvalid, +  input  wire              m_eth0_tready, +  // Transport 1 (eth1) +  input  wire [CHDR_W-1:0] s_eth1_tdata, +  input  wire              s_eth1_tlast, +  input  wire              s_eth1_tvalid, +  output wire              s_eth1_tready, +  output wire [CHDR_W-1:0] m_eth1_tdata, +  output wire              m_eth1_tlast, +  output wire              m_eth1_tvalid, +  input  wire              m_eth1_tready, +  // Transport 2 (eth2) +  input  wire [CHDR_W-1:0] s_eth2_tdata, +  input  wire              s_eth2_tlast, +  input  wire              s_eth2_tvalid, +  output wire              s_eth2_tready, +  output wire [CHDR_W-1:0] m_eth2_tdata, +  output wire              m_eth2_tlast, +  output wire              m_eth2_tvalid, +  input  wire              m_eth2_tready, +  // Transport 3 (eth3) +  input  wire [CHDR_W-1:0] s_eth3_tdata, +  input  wire              s_eth3_tlast, +  input  wire              s_eth3_tvalid, +  output wire              s_eth3_tready, +  output wire [CHDR_W-1:0] m_eth3_tdata, +  output wire              m_eth3_tlast, +  output wire              m_eth3_tvalid, +  input  wire              m_eth3_tready, +  // Transport 4 (eth4) +  input  wire [CHDR_W-1:0] s_eth4_tdata, +  input  wire              s_eth4_tlast, +  input  wire              s_eth4_tvalid, +  output wire              s_eth4_tready, +  output wire [CHDR_W-1:0] m_eth4_tdata, +  output wire              m_eth4_tlast, +  output wire              m_eth4_tvalid, +  input  wire              m_eth4_tready, +  // Transport 5 (dma) +  input  wire [CHDR_W-1:0] s_dma_tdata, +  input  wire              s_dma_tlast, +  input  wire              s_dma_tvalid, +  output wire              s_dma_tready, +  output wire [CHDR_W-1:0] m_dma_tdata, +  output wire              m_dma_tlast, +  output wire              m_dma_tvalid, +  input  wire              m_dma_tready +); + +  localparam EDGE_TBL_FILE = `"`RFNOC_EDGE_TBL_FILE`"; + +  wire rfnoc_chdr_clk, rfnoc_chdr_rst; +  wire rfnoc_ctrl_clk, rfnoc_ctrl_rst; + + +  //--------------------------------------------------------------------------- +  // CHDR Crossbar +  //--------------------------------------------------------------------------- + +  wire [CHDR_W-1:0] xb_to_ep0_tdata ; +  wire              xb_to_ep0_tlast ; +  wire              xb_to_ep0_tvalid; +  wire              xb_to_ep0_tready; +  wire [CHDR_W-1:0] ep0_to_xb_tdata ; +  wire              ep0_to_xb_tlast ; +  wire              ep0_to_xb_tvalid; +  wire              ep0_to_xb_tready; +  wire [CHDR_W-1:0] xb_to_ep1_tdata ; +  wire              xb_to_ep1_tlast ; +  wire              xb_to_ep1_tvalid; +  wire              xb_to_ep1_tready; +  wire [CHDR_W-1:0] ep1_to_xb_tdata ; +  wire              ep1_to_xb_tlast ; +  wire              ep1_to_xb_tvalid; +  wire              ep1_to_xb_tready; +  wire [CHDR_W-1:0] xb_to_ep2_tdata ; +  wire              xb_to_ep2_tlast ; +  wire              xb_to_ep2_tvalid; +  wire              xb_to_ep2_tready; +  wire [CHDR_W-1:0] ep2_to_xb_tdata ; +  wire              ep2_to_xb_tlast ; +  wire              ep2_to_xb_tvalid; +  wire              ep2_to_xb_tready; +  wire [CHDR_W-1:0] xb_to_ep3_tdata ; +  wire              xb_to_ep3_tlast ; +  wire              xb_to_ep3_tvalid; +  wire              xb_to_ep3_tready; +  wire [CHDR_W-1:0] ep3_to_xb_tdata ; +  wire              ep3_to_xb_tlast ; +  wire              ep3_to_xb_tvalid; +  wire              ep3_to_xb_tready; +  wire [CHDR_W-1:0] xb_to_ep4_tdata ; +  wire              xb_to_ep4_tlast ; +  wire              xb_to_ep4_tvalid; +  wire              xb_to_ep4_tready; +  wire [CHDR_W-1:0] ep4_to_xb_tdata ; +  wire              ep4_to_xb_tlast ; +  wire              ep4_to_xb_tvalid; +  wire              ep4_to_xb_tready; +  wire [CHDR_W-1:0] xb_to_ep5_tdata ; +  wire              xb_to_ep5_tlast ; +  wire              xb_to_ep5_tvalid; +  wire              xb_to_ep5_tready; +  wire [CHDR_W-1:0] ep5_to_xb_tdata ; +  wire              ep5_to_xb_tlast ; +  wire              ep5_to_xb_tvalid; +  wire              ep5_to_xb_tready; +  wire [CHDR_W-1:0] xb_to_ep6_tdata ; +  wire              xb_to_ep6_tlast ; +  wire              xb_to_ep6_tvalid; +  wire              xb_to_ep6_tready; +  wire [CHDR_W-1:0] ep6_to_xb_tdata ; +  wire              ep6_to_xb_tlast ; +  wire              ep6_to_xb_tvalid; +  wire              ep6_to_xb_tready; +  wire [CHDR_W-1:0] xb_to_ep7_tdata ; +  wire              xb_to_ep7_tlast ; +  wire              xb_to_ep7_tvalid; +  wire              xb_to_ep7_tready; +  wire [CHDR_W-1:0] ep7_to_xb_tdata ; +  wire              ep7_to_xb_tlast ; +  wire              ep7_to_xb_tvalid; +  wire              ep7_to_xb_tready; + +  chdr_crossbar_nxn #( +    .CHDR_W         (CHDR_W), +    .NPORTS         (14), +    .DEFAULT_PORT   (0), +    .MTU            (MTU), +    .ROUTE_TBL_SIZE (6), +    .MUX_ALLOC      ("ROUND-ROBIN"), +    .OPTIMIZE       ("AREA"), +    .NPORTS_MGMT    (6), +    .EXT_RTCFG_PORT (0), +    .PROTOVER       (PROTOVER) +  ) chdr_xb_i ( +    .clk            (rfnoc_chdr_clk), +    .reset          (rfnoc_chdr_rst), +    .device_id      (device_id), +    .s_axis_tdata   ({ep7_to_xb_tdata , ep6_to_xb_tdata , ep5_to_xb_tdata , ep4_to_xb_tdata , ep3_to_xb_tdata , ep2_to_xb_tdata , ep1_to_xb_tdata , ep0_to_xb_tdata , s_dma_tdata , s_eth4_tdata , s_eth3_tdata , s_eth2_tdata , s_eth1_tdata , s_eth0_tdata }), +    .s_axis_tlast   ({ep7_to_xb_tlast , ep6_to_xb_tlast , ep5_to_xb_tlast , ep4_to_xb_tlast , ep3_to_xb_tlast , ep2_to_xb_tlast , ep1_to_xb_tlast , ep0_to_xb_tlast , s_dma_tlast , s_eth4_tlast , s_eth3_tlast , s_eth2_tlast , s_eth1_tlast , s_eth0_tlast }), +    .s_axis_tvalid  ({ep7_to_xb_tvalid, ep6_to_xb_tvalid, ep5_to_xb_tvalid, ep4_to_xb_tvalid, ep3_to_xb_tvalid, ep2_to_xb_tvalid, ep1_to_xb_tvalid, ep0_to_xb_tvalid, s_dma_tvalid, s_eth4_tvalid, s_eth3_tvalid, s_eth2_tvalid, s_eth1_tvalid, s_eth0_tvalid}), +    .s_axis_tready  ({ep7_to_xb_tready, ep6_to_xb_tready, ep5_to_xb_tready, ep4_to_xb_tready, ep3_to_xb_tready, ep2_to_xb_tready, ep1_to_xb_tready, ep0_to_xb_tready, s_dma_tready, s_eth4_tready, s_eth3_tready, s_eth2_tready, s_eth1_tready, s_eth0_tready}), +    .m_axis_tdata   ({xb_to_ep7_tdata , xb_to_ep6_tdata , xb_to_ep5_tdata , xb_to_ep4_tdata , xb_to_ep3_tdata , xb_to_ep2_tdata , xb_to_ep1_tdata , xb_to_ep0_tdata , m_dma_tdata , m_eth4_tdata , m_eth3_tdata , m_eth2_tdata , m_eth1_tdata , m_eth0_tdata }), +    .m_axis_tlast   ({xb_to_ep7_tlast , xb_to_ep6_tlast , xb_to_ep5_tlast , xb_to_ep4_tlast , xb_to_ep3_tlast , xb_to_ep2_tlast , xb_to_ep1_tlast , xb_to_ep0_tlast , m_dma_tlast , m_eth4_tlast , m_eth3_tlast , m_eth2_tlast , m_eth1_tlast , m_eth0_tlast }), +    .m_axis_tvalid  ({xb_to_ep7_tvalid, xb_to_ep6_tvalid, xb_to_ep5_tvalid, xb_to_ep4_tvalid, xb_to_ep3_tvalid, xb_to_ep2_tvalid, xb_to_ep1_tvalid, xb_to_ep0_tvalid, m_dma_tvalid, m_eth4_tvalid, m_eth3_tvalid, m_eth2_tvalid, m_eth1_tvalid, m_eth0_tvalid}), +    .m_axis_tready  ({xb_to_ep7_tready, xb_to_ep6_tready, xb_to_ep5_tready, xb_to_ep4_tready, xb_to_ep3_tready, xb_to_ep2_tready, xb_to_ep1_tready, xb_to_ep0_tready, m_dma_tready, m_eth4_tready, m_eth3_tready, m_eth2_tready, m_eth1_tready, m_eth0_tready}), +    .ext_rtcfg_stb  (1'h0), +    .ext_rtcfg_addr (16'h0), +    .ext_rtcfg_data (32'h0), +    .ext_rtcfg_ack  () +  ); + + +  //--------------------------------------------------------------------------- +  // Stream Endpoints +  //--------------------------------------------------------------------------- + +  // If requested buffer size is 0, use the minimum SRL-based FIFO size. +  // Otherwise, make sure it's at least two MTU-sized packets. +  localparam REQ_BUFF_SIZE_EP0 = (32768)/(CHDR_W/8); +  localparam INGRESS_BUFF_SIZE_EP0 = +    REQ_BUFF_SIZE_EP0 == 0         ? 5     : +    REQ_BUFF_SIZE_EP0 < 2*(2**MTU) ? MTU+1 : +    $clog2(REQ_BUFF_SIZE_EP0); + +  wire [CHDR_W-1:0] m_ep0_out0_tdata; +  wire              m_ep0_out0_tlast; +  wire              m_ep0_out0_tvalid; +  wire              m_ep0_out0_tready; +  wire [CHDR_W-1:0] s_ep0_in0_tdata; +  wire              s_ep0_in0_tlast; +  wire              s_ep0_in0_tvalid; +  wire              s_ep0_in0_tready; +  wire [      31:0] m_ep0_ctrl_tdata,  s_ep0_ctrl_tdata; +  wire              m_ep0_ctrl_tlast,  s_ep0_ctrl_tlast; +  wire              m_ep0_ctrl_tvalid, s_ep0_ctrl_tvalid; +  wire              m_ep0_ctrl_tready, s_ep0_ctrl_tready; + +  chdr_stream_endpoint #( +    .PROTOVER           (PROTOVER), +    .CHDR_W             (CHDR_W), +    .AXIS_CTRL_EN       (1), +    .AXIS_DATA_EN       (1), +    .NUM_DATA_I         (1), +    .NUM_DATA_O         (1), +    .INST_NUM           (0), +    .CTRL_XBAR_PORT     (1), +    .INGRESS_BUFF_SIZE  (INGRESS_BUFF_SIZE_EP0), +    .MTU                (MTU), +    .REPORT_STRM_ERRS   (1) +  ) ep0_i ( +    .rfnoc_chdr_clk     (rfnoc_chdr_clk), +    .rfnoc_chdr_rst     (rfnoc_chdr_rst), +    .rfnoc_ctrl_clk     (rfnoc_ctrl_clk), +    .rfnoc_ctrl_rst     (rfnoc_ctrl_rst), +    .device_id          (device_id), +    .s_axis_chdr_tdata  (xb_to_ep0_tdata), +    .s_axis_chdr_tlast  (xb_to_ep0_tlast), +    .s_axis_chdr_tvalid (xb_to_ep0_tvalid), +    .s_axis_chdr_tready (xb_to_ep0_tready), +    .m_axis_chdr_tdata  (ep0_to_xb_tdata), +    .m_axis_chdr_tlast  (ep0_to_xb_tlast), +    .m_axis_chdr_tvalid (ep0_to_xb_tvalid), +    .m_axis_chdr_tready (ep0_to_xb_tready), +    .s_axis_data_tdata  ({s_ep0_in0_tdata}), +    .s_axis_data_tlast  ({s_ep0_in0_tlast}), +    .s_axis_data_tvalid ({s_ep0_in0_tvalid}), +    .s_axis_data_tready ({s_ep0_in0_tready}), +    .m_axis_data_tdata  ({m_ep0_out0_tdata}), +    .m_axis_data_tlast  ({m_ep0_out0_tlast}), +    .m_axis_data_tvalid ({m_ep0_out0_tvalid}), +    .m_axis_data_tready ({m_ep0_out0_tready}), +    .s_axis_ctrl_tdata  (s_ep0_ctrl_tdata), +    .s_axis_ctrl_tlast  (s_ep0_ctrl_tlast), +    .s_axis_ctrl_tvalid (s_ep0_ctrl_tvalid), +    .s_axis_ctrl_tready (s_ep0_ctrl_tready), +    .m_axis_ctrl_tdata  (m_ep0_ctrl_tdata), +    .m_axis_ctrl_tlast  (m_ep0_ctrl_tlast), +    .m_axis_ctrl_tvalid (m_ep0_ctrl_tvalid), +    .m_axis_ctrl_tready (m_ep0_ctrl_tready), +    .strm_seq_err_stb   (), +    .strm_data_err_stb  (), +    .strm_route_err_stb (), +    .signal_data_err    (1'b0) +  ); + +  // If requested buffer size is 0, use the minimum SRL-based FIFO size. +  // Otherwise, make sure it's at least two MTU-sized packets. +  localparam REQ_BUFF_SIZE_EP1 = (32768)/(CHDR_W/8); +  localparam INGRESS_BUFF_SIZE_EP1 = +    REQ_BUFF_SIZE_EP1 == 0         ? 5     : +    REQ_BUFF_SIZE_EP1 < 2*(2**MTU) ? MTU+1 : +    $clog2(REQ_BUFF_SIZE_EP1); + +  wire [CHDR_W-1:0] m_ep1_out0_tdata; +  wire              m_ep1_out0_tlast; +  wire              m_ep1_out0_tvalid; +  wire              m_ep1_out0_tready; +  wire [CHDR_W-1:0] s_ep1_in0_tdata; +  wire              s_ep1_in0_tlast; +  wire              s_ep1_in0_tvalid; +  wire              s_ep1_in0_tready; +  wire [      31:0] m_ep1_ctrl_tdata,  s_ep1_ctrl_tdata; +  wire              m_ep1_ctrl_tlast,  s_ep1_ctrl_tlast; +  wire              m_ep1_ctrl_tvalid, s_ep1_ctrl_tvalid; +  wire              m_ep1_ctrl_tready, s_ep1_ctrl_tready; + +  chdr_stream_endpoint #( +    .PROTOVER           (PROTOVER), +    .CHDR_W             (CHDR_W), +    .AXIS_CTRL_EN       (0), +    .AXIS_DATA_EN       (1), +    .NUM_DATA_I         (1), +    .NUM_DATA_O         (1), +    .INST_NUM           (1), +    .CTRL_XBAR_PORT     (2), +    .INGRESS_BUFF_SIZE  (INGRESS_BUFF_SIZE_EP1), +    .MTU                (MTU), +    .REPORT_STRM_ERRS   (1) +  ) ep1_i ( +    .rfnoc_chdr_clk     (rfnoc_chdr_clk), +    .rfnoc_chdr_rst     (rfnoc_chdr_rst), +    .rfnoc_ctrl_clk     (rfnoc_ctrl_clk), +    .rfnoc_ctrl_rst     (rfnoc_ctrl_rst), +    .device_id          (device_id), +    .s_axis_chdr_tdata  (xb_to_ep1_tdata), +    .s_axis_chdr_tlast  (xb_to_ep1_tlast), +    .s_axis_chdr_tvalid (xb_to_ep1_tvalid), +    .s_axis_chdr_tready (xb_to_ep1_tready), +    .m_axis_chdr_tdata  (ep1_to_xb_tdata), +    .m_axis_chdr_tlast  (ep1_to_xb_tlast), +    .m_axis_chdr_tvalid (ep1_to_xb_tvalid), +    .m_axis_chdr_tready (ep1_to_xb_tready), +    .s_axis_data_tdata  ({s_ep1_in0_tdata}), +    .s_axis_data_tlast  ({s_ep1_in0_tlast}), +    .s_axis_data_tvalid ({s_ep1_in0_tvalid}), +    .s_axis_data_tready ({s_ep1_in0_tready}), +    .m_axis_data_tdata  ({m_ep1_out0_tdata}), +    .m_axis_data_tlast  ({m_ep1_out0_tlast}), +    .m_axis_data_tvalid ({m_ep1_out0_tvalid}), +    .m_axis_data_tready ({m_ep1_out0_tready}), +    .s_axis_ctrl_tdata  (s_ep1_ctrl_tdata), +    .s_axis_ctrl_tlast  (s_ep1_ctrl_tlast), +    .s_axis_ctrl_tvalid (s_ep1_ctrl_tvalid), +    .s_axis_ctrl_tready (s_ep1_ctrl_tready), +    .m_axis_ctrl_tdata  (m_ep1_ctrl_tdata), +    .m_axis_ctrl_tlast  (m_ep1_ctrl_tlast), +    .m_axis_ctrl_tvalid (m_ep1_ctrl_tvalid), +    .m_axis_ctrl_tready (m_ep1_ctrl_tready), +    .strm_seq_err_stb   (), +    .strm_data_err_stb  (), +    .strm_route_err_stb (), +    .signal_data_err    (1'b0) +  ); + +  // If requested buffer size is 0, use the minimum SRL-based FIFO size. +  // Otherwise, make sure it's at least two MTU-sized packets. +  localparam REQ_BUFF_SIZE_EP2 = (32768)/(CHDR_W/8); +  localparam INGRESS_BUFF_SIZE_EP2 = +    REQ_BUFF_SIZE_EP2 == 0         ? 5     : +    REQ_BUFF_SIZE_EP2 < 2*(2**MTU) ? MTU+1 : +    $clog2(REQ_BUFF_SIZE_EP2); + +  wire [CHDR_W-1:0] m_ep2_out0_tdata; +  wire              m_ep2_out0_tlast; +  wire              m_ep2_out0_tvalid; +  wire              m_ep2_out0_tready; +  wire [CHDR_W-1:0] s_ep2_in0_tdata; +  wire              s_ep2_in0_tlast; +  wire              s_ep2_in0_tvalid; +  wire              s_ep2_in0_tready; +  wire [      31:0] m_ep2_ctrl_tdata,  s_ep2_ctrl_tdata; +  wire              m_ep2_ctrl_tlast,  s_ep2_ctrl_tlast; +  wire              m_ep2_ctrl_tvalid, s_ep2_ctrl_tvalid; +  wire              m_ep2_ctrl_tready, s_ep2_ctrl_tready; + +  chdr_stream_endpoint #( +    .PROTOVER           (PROTOVER), +    .CHDR_W             (CHDR_W), +    .AXIS_CTRL_EN       (0), +    .AXIS_DATA_EN       (1), +    .NUM_DATA_I         (1), +    .NUM_DATA_O         (1), +    .INST_NUM           (2), +    .CTRL_XBAR_PORT     (3), +    .INGRESS_BUFF_SIZE  (INGRESS_BUFF_SIZE_EP2), +    .MTU                (MTU), +    .REPORT_STRM_ERRS   (1) +  ) ep2_i ( +    .rfnoc_chdr_clk     (rfnoc_chdr_clk), +    .rfnoc_chdr_rst     (rfnoc_chdr_rst), +    .rfnoc_ctrl_clk     (rfnoc_ctrl_clk), +    .rfnoc_ctrl_rst     (rfnoc_ctrl_rst), +    .device_id          (device_id), +    .s_axis_chdr_tdata  (xb_to_ep2_tdata), +    .s_axis_chdr_tlast  (xb_to_ep2_tlast), +    .s_axis_chdr_tvalid (xb_to_ep2_tvalid), +    .s_axis_chdr_tready (xb_to_ep2_tready), +    .m_axis_chdr_tdata  (ep2_to_xb_tdata), +    .m_axis_chdr_tlast  (ep2_to_xb_tlast), +    .m_axis_chdr_tvalid (ep2_to_xb_tvalid), +    .m_axis_chdr_tready (ep2_to_xb_tready), +    .s_axis_data_tdata  ({s_ep2_in0_tdata}), +    .s_axis_data_tlast  ({s_ep2_in0_tlast}), +    .s_axis_data_tvalid ({s_ep2_in0_tvalid}), +    .s_axis_data_tready ({s_ep2_in0_tready}), +    .m_axis_data_tdata  ({m_ep2_out0_tdata}), +    .m_axis_data_tlast  ({m_ep2_out0_tlast}), +    .m_axis_data_tvalid ({m_ep2_out0_tvalid}), +    .m_axis_data_tready ({m_ep2_out0_tready}), +    .s_axis_ctrl_tdata  (s_ep2_ctrl_tdata), +    .s_axis_ctrl_tlast  (s_ep2_ctrl_tlast), +    .s_axis_ctrl_tvalid (s_ep2_ctrl_tvalid), +    .s_axis_ctrl_tready (s_ep2_ctrl_tready), +    .m_axis_ctrl_tdata  (m_ep2_ctrl_tdata), +    .m_axis_ctrl_tlast  (m_ep2_ctrl_tlast), +    .m_axis_ctrl_tvalid (m_ep2_ctrl_tvalid), +    .m_axis_ctrl_tready (m_ep2_ctrl_tready), +    .strm_seq_err_stb   (), +    .strm_data_err_stb  (), +    .strm_route_err_stb (), +    .signal_data_err    (1'b0) +  ); + +  // If requested buffer size is 0, use the minimum SRL-based FIFO size. +  // Otherwise, make sure it's at least two MTU-sized packets. +  localparam REQ_BUFF_SIZE_EP3 = (32768)/(CHDR_W/8); +  localparam INGRESS_BUFF_SIZE_EP3 = +    REQ_BUFF_SIZE_EP3 == 0         ? 5     : +    REQ_BUFF_SIZE_EP3 < 2*(2**MTU) ? MTU+1 : +    $clog2(REQ_BUFF_SIZE_EP3); + +  wire [CHDR_W-1:0] m_ep3_out0_tdata; +  wire              m_ep3_out0_tlast; +  wire              m_ep3_out0_tvalid; +  wire              m_ep3_out0_tready; +  wire [CHDR_W-1:0] s_ep3_in0_tdata; +  wire              s_ep3_in0_tlast; +  wire              s_ep3_in0_tvalid; +  wire              s_ep3_in0_tready; +  wire [      31:0] m_ep3_ctrl_tdata,  s_ep3_ctrl_tdata; +  wire              m_ep3_ctrl_tlast,  s_ep3_ctrl_tlast; +  wire              m_ep3_ctrl_tvalid, s_ep3_ctrl_tvalid; +  wire              m_ep3_ctrl_tready, s_ep3_ctrl_tready; + +  chdr_stream_endpoint #( +    .PROTOVER           (PROTOVER), +    .CHDR_W             (CHDR_W), +    .AXIS_CTRL_EN       (0), +    .AXIS_DATA_EN       (1), +    .NUM_DATA_I         (1), +    .NUM_DATA_O         (1), +    .INST_NUM           (3), +    .CTRL_XBAR_PORT     (4), +    .INGRESS_BUFF_SIZE  (INGRESS_BUFF_SIZE_EP3), +    .MTU                (MTU), +    .REPORT_STRM_ERRS   (1) +  ) ep3_i ( +    .rfnoc_chdr_clk     (rfnoc_chdr_clk), +    .rfnoc_chdr_rst     (rfnoc_chdr_rst), +    .rfnoc_ctrl_clk     (rfnoc_ctrl_clk), +    .rfnoc_ctrl_rst     (rfnoc_ctrl_rst), +    .device_id          (device_id), +    .s_axis_chdr_tdata  (xb_to_ep3_tdata), +    .s_axis_chdr_tlast  (xb_to_ep3_tlast), +    .s_axis_chdr_tvalid (xb_to_ep3_tvalid), +    .s_axis_chdr_tready (xb_to_ep3_tready), +    .m_axis_chdr_tdata  (ep3_to_xb_tdata), +    .m_axis_chdr_tlast  (ep3_to_xb_tlast), +    .m_axis_chdr_tvalid (ep3_to_xb_tvalid), +    .m_axis_chdr_tready (ep3_to_xb_tready), +    .s_axis_data_tdata  ({s_ep3_in0_tdata}), +    .s_axis_data_tlast  ({s_ep3_in0_tlast}), +    .s_axis_data_tvalid ({s_ep3_in0_tvalid}), +    .s_axis_data_tready ({s_ep3_in0_tready}), +    .m_axis_data_tdata  ({m_ep3_out0_tdata}), +    .m_axis_data_tlast  ({m_ep3_out0_tlast}), +    .m_axis_data_tvalid ({m_ep3_out0_tvalid}), +    .m_axis_data_tready ({m_ep3_out0_tready}), +    .s_axis_ctrl_tdata  (s_ep3_ctrl_tdata), +    .s_axis_ctrl_tlast  (s_ep3_ctrl_tlast), +    .s_axis_ctrl_tvalid (s_ep3_ctrl_tvalid), +    .s_axis_ctrl_tready (s_ep3_ctrl_tready), +    .m_axis_ctrl_tdata  (m_ep3_ctrl_tdata), +    .m_axis_ctrl_tlast  (m_ep3_ctrl_tlast), +    .m_axis_ctrl_tvalid (m_ep3_ctrl_tvalid), +    .m_axis_ctrl_tready (m_ep3_ctrl_tready), +    .strm_seq_err_stb   (), +    .strm_data_err_stb  (), +    .strm_route_err_stb (), +    .signal_data_err    (1'b0) +  ); + +  // If requested buffer size is 0, use the minimum SRL-based FIFO size. +  // Otherwise, make sure it's at least two MTU-sized packets. +  localparam REQ_BUFF_SIZE_EP4 = (32768)/(CHDR_W/8); +  localparam INGRESS_BUFF_SIZE_EP4 = +    REQ_BUFF_SIZE_EP4 == 0         ? 5     : +    REQ_BUFF_SIZE_EP4 < 2*(2**MTU) ? MTU+1 : +    $clog2(REQ_BUFF_SIZE_EP4); + +  wire [CHDR_W-1:0] m_ep4_out0_tdata; +  wire              m_ep4_out0_tlast; +  wire              m_ep4_out0_tvalid; +  wire              m_ep4_out0_tready; +  wire [CHDR_W-1:0] s_ep4_in0_tdata; +  wire              s_ep4_in0_tlast; +  wire              s_ep4_in0_tvalid; +  wire              s_ep4_in0_tready; +  wire [      31:0] m_ep4_ctrl_tdata,  s_ep4_ctrl_tdata; +  wire              m_ep4_ctrl_tlast,  s_ep4_ctrl_tlast; +  wire              m_ep4_ctrl_tvalid, s_ep4_ctrl_tvalid; +  wire              m_ep4_ctrl_tready, s_ep4_ctrl_tready; + +  chdr_stream_endpoint #( +    .PROTOVER           (PROTOVER), +    .CHDR_W             (CHDR_W), +    .AXIS_CTRL_EN       (0), +    .AXIS_DATA_EN       (1), +    .NUM_DATA_I         (1), +    .NUM_DATA_O         (1), +    .INST_NUM           (4), +    .CTRL_XBAR_PORT     (5), +    .INGRESS_BUFF_SIZE  (INGRESS_BUFF_SIZE_EP4), +    .MTU                (MTU), +    .REPORT_STRM_ERRS   (1) +  ) ep4_i ( +    .rfnoc_chdr_clk     (rfnoc_chdr_clk), +    .rfnoc_chdr_rst     (rfnoc_chdr_rst), +    .rfnoc_ctrl_clk     (rfnoc_ctrl_clk), +    .rfnoc_ctrl_rst     (rfnoc_ctrl_rst), +    .device_id          (device_id), +    .s_axis_chdr_tdata  (xb_to_ep4_tdata), +    .s_axis_chdr_tlast  (xb_to_ep4_tlast), +    .s_axis_chdr_tvalid (xb_to_ep4_tvalid), +    .s_axis_chdr_tready (xb_to_ep4_tready), +    .m_axis_chdr_tdata  (ep4_to_xb_tdata), +    .m_axis_chdr_tlast  (ep4_to_xb_tlast), +    .m_axis_chdr_tvalid (ep4_to_xb_tvalid), +    .m_axis_chdr_tready (ep4_to_xb_tready), +    .s_axis_data_tdata  ({s_ep4_in0_tdata}), +    .s_axis_data_tlast  ({s_ep4_in0_tlast}), +    .s_axis_data_tvalid ({s_ep4_in0_tvalid}), +    .s_axis_data_tready ({s_ep4_in0_tready}), +    .m_axis_data_tdata  ({m_ep4_out0_tdata}), +    .m_axis_data_tlast  ({m_ep4_out0_tlast}), +    .m_axis_data_tvalid ({m_ep4_out0_tvalid}), +    .m_axis_data_tready ({m_ep4_out0_tready}), +    .s_axis_ctrl_tdata  (s_ep4_ctrl_tdata), +    .s_axis_ctrl_tlast  (s_ep4_ctrl_tlast), +    .s_axis_ctrl_tvalid (s_ep4_ctrl_tvalid), +    .s_axis_ctrl_tready (s_ep4_ctrl_tready), +    .m_axis_ctrl_tdata  (m_ep4_ctrl_tdata), +    .m_axis_ctrl_tlast  (m_ep4_ctrl_tlast), +    .m_axis_ctrl_tvalid (m_ep4_ctrl_tvalid), +    .m_axis_ctrl_tready (m_ep4_ctrl_tready), +    .strm_seq_err_stb   (), +    .strm_data_err_stb  (), +    .strm_route_err_stb (), +    .signal_data_err    (1'b0) +  ); + +  // If requested buffer size is 0, use the minimum SRL-based FIFO size. +  // Otherwise, make sure it's at least two MTU-sized packets. +  localparam REQ_BUFF_SIZE_EP5 = (32768)/(CHDR_W/8); +  localparam INGRESS_BUFF_SIZE_EP5 = +    REQ_BUFF_SIZE_EP5 == 0         ? 5     : +    REQ_BUFF_SIZE_EP5 < 2*(2**MTU) ? MTU+1 : +    $clog2(REQ_BUFF_SIZE_EP5); + +  wire [CHDR_W-1:0] m_ep5_out0_tdata; +  wire              m_ep5_out0_tlast; +  wire              m_ep5_out0_tvalid; +  wire              m_ep5_out0_tready; +  wire [CHDR_W-1:0] s_ep5_in0_tdata; +  wire              s_ep5_in0_tlast; +  wire              s_ep5_in0_tvalid; +  wire              s_ep5_in0_tready; +  wire [      31:0] m_ep5_ctrl_tdata,  s_ep5_ctrl_tdata; +  wire              m_ep5_ctrl_tlast,  s_ep5_ctrl_tlast; +  wire              m_ep5_ctrl_tvalid, s_ep5_ctrl_tvalid; +  wire              m_ep5_ctrl_tready, s_ep5_ctrl_tready; + +  chdr_stream_endpoint #( +    .PROTOVER           (PROTOVER), +    .CHDR_W             (CHDR_W), +    .AXIS_CTRL_EN       (0), +    .AXIS_DATA_EN       (1), +    .NUM_DATA_I         (1), +    .NUM_DATA_O         (1), +    .INST_NUM           (5), +    .CTRL_XBAR_PORT     (6), +    .INGRESS_BUFF_SIZE  (INGRESS_BUFF_SIZE_EP5), +    .MTU                (MTU), +    .REPORT_STRM_ERRS   (1) +  ) ep5_i ( +    .rfnoc_chdr_clk     (rfnoc_chdr_clk), +    .rfnoc_chdr_rst     (rfnoc_chdr_rst), +    .rfnoc_ctrl_clk     (rfnoc_ctrl_clk), +    .rfnoc_ctrl_rst     (rfnoc_ctrl_rst), +    .device_id          (device_id), +    .s_axis_chdr_tdata  (xb_to_ep5_tdata), +    .s_axis_chdr_tlast  (xb_to_ep5_tlast), +    .s_axis_chdr_tvalid (xb_to_ep5_tvalid), +    .s_axis_chdr_tready (xb_to_ep5_tready), +    .m_axis_chdr_tdata  (ep5_to_xb_tdata), +    .m_axis_chdr_tlast  (ep5_to_xb_tlast), +    .m_axis_chdr_tvalid (ep5_to_xb_tvalid), +    .m_axis_chdr_tready (ep5_to_xb_tready), +    .s_axis_data_tdata  ({s_ep5_in0_tdata}), +    .s_axis_data_tlast  ({s_ep5_in0_tlast}), +    .s_axis_data_tvalid ({s_ep5_in0_tvalid}), +    .s_axis_data_tready ({s_ep5_in0_tready}), +    .m_axis_data_tdata  ({m_ep5_out0_tdata}), +    .m_axis_data_tlast  ({m_ep5_out0_tlast}), +    .m_axis_data_tvalid ({m_ep5_out0_tvalid}), +    .m_axis_data_tready ({m_ep5_out0_tready}), +    .s_axis_ctrl_tdata  (s_ep5_ctrl_tdata), +    .s_axis_ctrl_tlast  (s_ep5_ctrl_tlast), +    .s_axis_ctrl_tvalid (s_ep5_ctrl_tvalid), +    .s_axis_ctrl_tready (s_ep5_ctrl_tready), +    .m_axis_ctrl_tdata  (m_ep5_ctrl_tdata), +    .m_axis_ctrl_tlast  (m_ep5_ctrl_tlast), +    .m_axis_ctrl_tvalid (m_ep5_ctrl_tvalid), +    .m_axis_ctrl_tready (m_ep5_ctrl_tready), +    .strm_seq_err_stb   (), +    .strm_data_err_stb  (), +    .strm_route_err_stb (), +    .signal_data_err    (1'b0) +  ); + +  // If requested buffer size is 0, use the minimum SRL-based FIFO size. +  // Otherwise, make sure it's at least two MTU-sized packets. +  localparam REQ_BUFF_SIZE_EP6 = (32768)/(CHDR_W/8); +  localparam INGRESS_BUFF_SIZE_EP6 = +    REQ_BUFF_SIZE_EP6 == 0         ? 5     : +    REQ_BUFF_SIZE_EP6 < 2*(2**MTU) ? MTU+1 : +    $clog2(REQ_BUFF_SIZE_EP6); + +  wire [CHDR_W-1:0] m_ep6_out0_tdata; +  wire              m_ep6_out0_tlast; +  wire              m_ep6_out0_tvalid; +  wire              m_ep6_out0_tready; +  wire [CHDR_W-1:0] s_ep6_in0_tdata; +  wire              s_ep6_in0_tlast; +  wire              s_ep6_in0_tvalid; +  wire              s_ep6_in0_tready; +  wire [      31:0] m_ep6_ctrl_tdata,  s_ep6_ctrl_tdata; +  wire              m_ep6_ctrl_tlast,  s_ep6_ctrl_tlast; +  wire              m_ep6_ctrl_tvalid, s_ep6_ctrl_tvalid; +  wire              m_ep6_ctrl_tready, s_ep6_ctrl_tready; + +  chdr_stream_endpoint #( +    .PROTOVER           (PROTOVER), +    .CHDR_W             (CHDR_W), +    .AXIS_CTRL_EN       (0), +    .AXIS_DATA_EN       (1), +    .NUM_DATA_I         (1), +    .NUM_DATA_O         (1), +    .INST_NUM           (6), +    .CTRL_XBAR_PORT     (7), +    .INGRESS_BUFF_SIZE  (INGRESS_BUFF_SIZE_EP6), +    .MTU                (MTU), +    .REPORT_STRM_ERRS   (1) +  ) ep6_i ( +    .rfnoc_chdr_clk     (rfnoc_chdr_clk), +    .rfnoc_chdr_rst     (rfnoc_chdr_rst), +    .rfnoc_ctrl_clk     (rfnoc_ctrl_clk), +    .rfnoc_ctrl_rst     (rfnoc_ctrl_rst), +    .device_id          (device_id), +    .s_axis_chdr_tdata  (xb_to_ep6_tdata), +    .s_axis_chdr_tlast  (xb_to_ep6_tlast), +    .s_axis_chdr_tvalid (xb_to_ep6_tvalid), +    .s_axis_chdr_tready (xb_to_ep6_tready), +    .m_axis_chdr_tdata  (ep6_to_xb_tdata), +    .m_axis_chdr_tlast  (ep6_to_xb_tlast), +    .m_axis_chdr_tvalid (ep6_to_xb_tvalid), +    .m_axis_chdr_tready (ep6_to_xb_tready), +    .s_axis_data_tdata  ({s_ep6_in0_tdata}), +    .s_axis_data_tlast  ({s_ep6_in0_tlast}), +    .s_axis_data_tvalid ({s_ep6_in0_tvalid}), +    .s_axis_data_tready ({s_ep6_in0_tready}), +    .m_axis_data_tdata  ({m_ep6_out0_tdata}), +    .m_axis_data_tlast  ({m_ep6_out0_tlast}), +    .m_axis_data_tvalid ({m_ep6_out0_tvalid}), +    .m_axis_data_tready ({m_ep6_out0_tready}), +    .s_axis_ctrl_tdata  (s_ep6_ctrl_tdata), +    .s_axis_ctrl_tlast  (s_ep6_ctrl_tlast), +    .s_axis_ctrl_tvalid (s_ep6_ctrl_tvalid), +    .s_axis_ctrl_tready (s_ep6_ctrl_tready), +    .m_axis_ctrl_tdata  (m_ep6_ctrl_tdata), +    .m_axis_ctrl_tlast  (m_ep6_ctrl_tlast), +    .m_axis_ctrl_tvalid (m_ep6_ctrl_tvalid), +    .m_axis_ctrl_tready (m_ep6_ctrl_tready), +    .strm_seq_err_stb   (), +    .strm_data_err_stb  (), +    .strm_route_err_stb (), +    .signal_data_err    (1'b0) +  ); + +  // If requested buffer size is 0, use the minimum SRL-based FIFO size. +  // Otherwise, make sure it's at least two MTU-sized packets. +  localparam REQ_BUFF_SIZE_EP7 = (32768)/(CHDR_W/8); +  localparam INGRESS_BUFF_SIZE_EP7 = +    REQ_BUFF_SIZE_EP7 == 0         ? 5     : +    REQ_BUFF_SIZE_EP7 < 2*(2**MTU) ? MTU+1 : +    $clog2(REQ_BUFF_SIZE_EP7); + +  wire [CHDR_W-1:0] m_ep7_out0_tdata; +  wire              m_ep7_out0_tlast; +  wire              m_ep7_out0_tvalid; +  wire              m_ep7_out0_tready; +  wire [CHDR_W-1:0] s_ep7_in0_tdata; +  wire              s_ep7_in0_tlast; +  wire              s_ep7_in0_tvalid; +  wire              s_ep7_in0_tready; +  wire [      31:0] m_ep7_ctrl_tdata,  s_ep7_ctrl_tdata; +  wire              m_ep7_ctrl_tlast,  s_ep7_ctrl_tlast; +  wire              m_ep7_ctrl_tvalid, s_ep7_ctrl_tvalid; +  wire              m_ep7_ctrl_tready, s_ep7_ctrl_tready; + +  chdr_stream_endpoint #( +    .PROTOVER           (PROTOVER), +    .CHDR_W             (CHDR_W), +    .AXIS_CTRL_EN       (0), +    .AXIS_DATA_EN       (1), +    .NUM_DATA_I         (1), +    .NUM_DATA_O         (1), +    .INST_NUM           (7), +    .CTRL_XBAR_PORT     (8), +    .INGRESS_BUFF_SIZE  (INGRESS_BUFF_SIZE_EP7), +    .MTU                (MTU), +    .REPORT_STRM_ERRS   (1) +  ) ep7_i ( +    .rfnoc_chdr_clk     (rfnoc_chdr_clk), +    .rfnoc_chdr_rst     (rfnoc_chdr_rst), +    .rfnoc_ctrl_clk     (rfnoc_ctrl_clk), +    .rfnoc_ctrl_rst     (rfnoc_ctrl_rst), +    .device_id          (device_id), +    .s_axis_chdr_tdata  (xb_to_ep7_tdata), +    .s_axis_chdr_tlast  (xb_to_ep7_tlast), +    .s_axis_chdr_tvalid (xb_to_ep7_tvalid), +    .s_axis_chdr_tready (xb_to_ep7_tready), +    .m_axis_chdr_tdata  (ep7_to_xb_tdata), +    .m_axis_chdr_tlast  (ep7_to_xb_tlast), +    .m_axis_chdr_tvalid (ep7_to_xb_tvalid), +    .m_axis_chdr_tready (ep7_to_xb_tready), +    .s_axis_data_tdata  ({s_ep7_in0_tdata}), +    .s_axis_data_tlast  ({s_ep7_in0_tlast}), +    .s_axis_data_tvalid ({s_ep7_in0_tvalid}), +    .s_axis_data_tready ({s_ep7_in0_tready}), +    .m_axis_data_tdata  ({m_ep7_out0_tdata}), +    .m_axis_data_tlast  ({m_ep7_out0_tlast}), +    .m_axis_data_tvalid ({m_ep7_out0_tvalid}), +    .m_axis_data_tready ({m_ep7_out0_tready}), +    .s_axis_ctrl_tdata  (s_ep7_ctrl_tdata), +    .s_axis_ctrl_tlast  (s_ep7_ctrl_tlast), +    .s_axis_ctrl_tvalid (s_ep7_ctrl_tvalid), +    .s_axis_ctrl_tready (s_ep7_ctrl_tready), +    .m_axis_ctrl_tdata  (m_ep7_ctrl_tdata), +    .m_axis_ctrl_tlast  (m_ep7_ctrl_tlast), +    .m_axis_ctrl_tvalid (m_ep7_ctrl_tvalid), +    .m_axis_ctrl_tready (m_ep7_ctrl_tready), +    .strm_seq_err_stb   (), +    .strm_data_err_stb  (), +    .strm_route_err_stb (), +    .signal_data_err    (1'b0) +  ); + + +  //--------------------------------------------------------------------------- +  // Control Crossbar +  //--------------------------------------------------------------------------- + +  wire [31:0] m_core_ctrl_tdata,  s_core_ctrl_tdata; +  wire        m_core_ctrl_tlast,  s_core_ctrl_tlast; +  wire        m_core_ctrl_tvalid, s_core_ctrl_tvalid; +  wire        m_core_ctrl_tready, s_core_ctrl_tready; +  wire [31:0] m_radio0_ctrl_tdata,  s_radio0_ctrl_tdata; +  wire        m_radio0_ctrl_tlast,  s_radio0_ctrl_tlast; +  wire        m_radio0_ctrl_tvalid, s_radio0_ctrl_tvalid; +  wire        m_radio0_ctrl_tready, s_radio0_ctrl_tready; +  wire [31:0] m_radio1_ctrl_tdata,  s_radio1_ctrl_tdata; +  wire        m_radio1_ctrl_tlast,  s_radio1_ctrl_tlast; +  wire        m_radio1_ctrl_tvalid, s_radio1_ctrl_tvalid; +  wire        m_radio1_ctrl_tready, s_radio1_ctrl_tready; +  wire [31:0] m_replay0_ctrl_tdata,  s_replay0_ctrl_tdata; +  wire        m_replay0_ctrl_tlast,  s_replay0_ctrl_tlast; +  wire        m_replay0_ctrl_tvalid, s_replay0_ctrl_tvalid; +  wire        m_replay0_ctrl_tready, s_replay0_ctrl_tready; + +  axis_ctrl_crossbar_nxn #( +    .WIDTH            (32), +    .NPORTS           (5), +    .TOPOLOGY         ("TORUS"), +    .INGRESS_BUFF_SIZE(5), +    .ROUTER_BUFF_SIZE (5), +    .ROUTING_ALLOC    ("WORMHOLE"), +    .SWITCH_ALLOC     ("PRIO") +  ) ctrl_xb_i ( +    .clk              (rfnoc_ctrl_clk), +    .reset            (rfnoc_ctrl_rst), +    .s_axis_tdata     ({m_replay0_ctrl_tdata , m_radio1_ctrl_tdata , m_radio0_ctrl_tdata , m_ep0_ctrl_tdata , m_core_ctrl_tdata }), +    .s_axis_tvalid    ({m_replay0_ctrl_tvalid, m_radio1_ctrl_tvalid, m_radio0_ctrl_tvalid, m_ep0_ctrl_tvalid, m_core_ctrl_tvalid}), +    .s_axis_tlast     ({m_replay0_ctrl_tlast , m_radio1_ctrl_tlast , m_radio0_ctrl_tlast , m_ep0_ctrl_tlast , m_core_ctrl_tlast }), +    .s_axis_tready    ({m_replay0_ctrl_tready, m_radio1_ctrl_tready, m_radio0_ctrl_tready, m_ep0_ctrl_tready, m_core_ctrl_tready}), +    .m_axis_tdata     ({s_replay0_ctrl_tdata , s_radio1_ctrl_tdata , s_radio0_ctrl_tdata , s_ep0_ctrl_tdata , s_core_ctrl_tdata }), +    .m_axis_tvalid    ({s_replay0_ctrl_tvalid, s_radio1_ctrl_tvalid, s_radio0_ctrl_tvalid, s_ep0_ctrl_tvalid, s_core_ctrl_tvalid}), +    .m_axis_tlast     ({s_replay0_ctrl_tlast , s_radio1_ctrl_tlast , s_radio0_ctrl_tlast , s_ep0_ctrl_tlast , s_core_ctrl_tlast }), +    .m_axis_tready    ({s_replay0_ctrl_tready, s_radio1_ctrl_tready, s_radio0_ctrl_tready, s_ep0_ctrl_tready, s_core_ctrl_tready}), +    .deadlock_detected() +  ); + + +  //--------------------------------------------------------------------------- +  // RFNoC Core Kernel +  //--------------------------------------------------------------------------- + +  wire [(512*3)-1:0] rfnoc_core_config, rfnoc_core_status; + +  rfnoc_core_kernel #( +    .PROTOVER            (PROTOVER), +    .DEVICE_TYPE         (16'hA400), +    .DEVICE_FAMILY       ("ULTRASCALE"), +    .SAFE_START_CLKS     (0), +    .NUM_BLOCKS          (3), +    .NUM_STREAM_ENDPOINTS(8), +    .NUM_ENDPOINTS_CTRL  (1), +    .NUM_TRANSPORTS      (6), +    .NUM_EDGES           (16), +    .CHDR_XBAR_PRESENT   (1), +    .EDGE_TBL_FILE       (EDGE_TBL_FILE) +  ) core_kernel_i ( +    .chdr_aclk          (chdr_aclk), +    .chdr_aclk_locked   (1'b1), +    .ctrl_aclk          (ctrl_aclk), +    .ctrl_aclk_locked   (1'b1), +    .core_arst          (core_arst), +    .core_chdr_clk      (rfnoc_chdr_clk), +    .core_chdr_rst      (rfnoc_chdr_rst), +    .core_ctrl_clk      (rfnoc_ctrl_clk), +    .core_ctrl_rst      (rfnoc_ctrl_rst), +    .s_axis_ctrl_tdata  (s_core_ctrl_tdata), +    .s_axis_ctrl_tlast  (s_core_ctrl_tlast), +    .s_axis_ctrl_tvalid (s_core_ctrl_tvalid), +    .s_axis_ctrl_tready (s_core_ctrl_tready), +    .m_axis_ctrl_tdata  (m_core_ctrl_tdata), +    .m_axis_ctrl_tlast  (m_core_ctrl_tlast), +    .m_axis_ctrl_tvalid (m_core_ctrl_tvalid), +    .m_axis_ctrl_tready (m_core_ctrl_tready), +    .device_id          (device_id), +    .rfnoc_core_config  (rfnoc_core_config), +    .rfnoc_core_status  (rfnoc_core_status) +  ); + + +  //--------------------------------------------------------------------------- +  // Blocks +  //--------------------------------------------------------------------------- + +  //----------------------------------- +  // radio0 +  //----------------------------------- + +  wire              radio0_radio_clk; +  wire [CHDR_W-1:0] s_radio0_in_1_tdata , s_radio0_in_0_tdata ; +  wire              s_radio0_in_1_tlast , s_radio0_in_0_tlast ; +  wire              s_radio0_in_1_tvalid, s_radio0_in_0_tvalid; +  wire              s_radio0_in_1_tready, s_radio0_in_0_tready; +  wire [CHDR_W-1:0] m_radio0_out_1_tdata , m_radio0_out_0_tdata ; +  wire              m_radio0_out_1_tlast , m_radio0_out_0_tlast ; +  wire              m_radio0_out_1_tvalid, m_radio0_out_0_tvalid; +  wire              m_radio0_out_1_tready, m_radio0_out_0_tready; + +  // ctrlport +  wire [   0:0] radio0_m_ctrlport_req_wr; +  wire [   0:0] radio0_m_ctrlport_req_rd; +  wire [  19:0] radio0_m_ctrlport_req_addr; +  wire [  31:0] radio0_m_ctrlport_req_data; +  wire [   3:0] radio0_m_ctrlport_req_byte_en; +  wire [   0:0] radio0_m_ctrlport_req_has_time; +  wire [  63:0] radio0_m_ctrlport_req_time; +  wire [   0:0] radio0_m_ctrlport_resp_ack; +  wire [   1:0] radio0_m_ctrlport_resp_status; +  wire [  31:0] radio0_m_ctrlport_resp_data; +  // time +  wire [  63:0] radio0_radio_time; +  // radio +  wire [ 255:0] radio0_radio_rx_data; +  wire [   7:0] radio0_radio_rx_stb; +  wire [   7:0] radio0_radio_rx_running; +  wire [ 255:0] radio0_radio_tx_data; +  wire [   7:0] radio0_radio_tx_stb; +  wire [   7:0] radio0_radio_tx_running; + +  rfnoc_block_radio #( +    .THIS_PORTID         (2), +    .CHDR_W              (CHDR_W), +    .NUM_PORTS           (2), +    .NIPC                (RADIO_NIPC), +    .ITEM_W              (32), +    .MTU                 (MTU) +  ) b_radio0_0 ( +    .rfnoc_chdr_clk      (rfnoc_chdr_clk), +    .rfnoc_ctrl_clk      (rfnoc_ctrl_clk), +    .radio_clk           (radio0_radio_clk), +    .rfnoc_core_config   (rfnoc_core_config[512*1-1:512*0]), +    .rfnoc_core_status   (rfnoc_core_status[512*1-1:512*0]), +    .m_ctrlport_req_wr   (radio0_m_ctrlport_req_wr), +    .m_ctrlport_req_rd   (radio0_m_ctrlport_req_rd), +    .m_ctrlport_req_addr (radio0_m_ctrlport_req_addr), +    .m_ctrlport_req_data (radio0_m_ctrlport_req_data), +    .m_ctrlport_req_byte_en(radio0_m_ctrlport_req_byte_en), +    .m_ctrlport_req_has_time(radio0_m_ctrlport_req_has_time), +    .m_ctrlport_req_time (radio0_m_ctrlport_req_time), +    .m_ctrlport_resp_ack (radio0_m_ctrlport_resp_ack), +    .m_ctrlport_resp_status(radio0_m_ctrlport_resp_status), +    .m_ctrlport_resp_data(radio0_m_ctrlport_resp_data), +    .radio_time          (radio0_radio_time), +    .radio_rx_data       (radio0_radio_rx_data), +    .radio_rx_stb        (radio0_radio_rx_stb), +    .radio_rx_running    (radio0_radio_rx_running), +    .radio_tx_data       (radio0_radio_tx_data), +    .radio_tx_stb        (radio0_radio_tx_stb), +    .radio_tx_running    (radio0_radio_tx_running), +    .s_rfnoc_chdr_tdata  ({s_radio0_in_1_tdata , s_radio0_in_0_tdata }), +    .s_rfnoc_chdr_tlast  ({s_radio0_in_1_tlast , s_radio0_in_0_tlast }), +    .s_rfnoc_chdr_tvalid ({s_radio0_in_1_tvalid, s_radio0_in_0_tvalid}), +    .s_rfnoc_chdr_tready ({s_radio0_in_1_tready, s_radio0_in_0_tready}), +    .m_rfnoc_chdr_tdata  ({m_radio0_out_1_tdata , m_radio0_out_0_tdata }), +    .m_rfnoc_chdr_tlast  ({m_radio0_out_1_tlast , m_radio0_out_0_tlast }), +    .m_rfnoc_chdr_tvalid ({m_radio0_out_1_tvalid, m_radio0_out_0_tvalid}), +    .m_rfnoc_chdr_tready ({m_radio0_out_1_tready, m_radio0_out_0_tready}), +    .s_rfnoc_ctrl_tdata  (s_radio0_ctrl_tdata), +    .s_rfnoc_ctrl_tlast  (s_radio0_ctrl_tlast), +    .s_rfnoc_ctrl_tvalid (s_radio0_ctrl_tvalid), +    .s_rfnoc_ctrl_tready (s_radio0_ctrl_tready), +    .m_rfnoc_ctrl_tdata  (m_radio0_ctrl_tdata), +    .m_rfnoc_ctrl_tlast  (m_radio0_ctrl_tlast), +    .m_rfnoc_ctrl_tvalid (m_radio0_ctrl_tvalid), +    .m_rfnoc_ctrl_tready (m_radio0_ctrl_tready) +  ); + +  //----------------------------------- +  // radio1 +  //----------------------------------- + +  wire              radio1_radio_clk; +  wire [CHDR_W-1:0] s_radio1_in_1_tdata , s_radio1_in_0_tdata ; +  wire              s_radio1_in_1_tlast , s_radio1_in_0_tlast ; +  wire              s_radio1_in_1_tvalid, s_radio1_in_0_tvalid; +  wire              s_radio1_in_1_tready, s_radio1_in_0_tready; +  wire [CHDR_W-1:0] m_radio1_out_1_tdata , m_radio1_out_0_tdata ; +  wire              m_radio1_out_1_tlast , m_radio1_out_0_tlast ; +  wire              m_radio1_out_1_tvalid, m_radio1_out_0_tvalid; +  wire              m_radio1_out_1_tready, m_radio1_out_0_tready; + +  // ctrlport +  wire [   0:0] radio1_m_ctrlport_req_wr; +  wire [   0:0] radio1_m_ctrlport_req_rd; +  wire [  19:0] radio1_m_ctrlport_req_addr; +  wire [  31:0] radio1_m_ctrlport_req_data; +  wire [   3:0] radio1_m_ctrlport_req_byte_en; +  wire [   0:0] radio1_m_ctrlport_req_has_time; +  wire [  63:0] radio1_m_ctrlport_req_time; +  wire [   0:0] radio1_m_ctrlport_resp_ack; +  wire [   1:0] radio1_m_ctrlport_resp_status; +  wire [  31:0] radio1_m_ctrlport_resp_data; +  // time +  wire [  63:0] radio1_radio_time; +  // radio +  wire [ 255:0] radio1_radio_rx_data; +  wire [   7:0] radio1_radio_rx_stb; +  wire [   7:0] radio1_radio_rx_running; +  wire [ 255:0] radio1_radio_tx_data; +  wire [   7:0] radio1_radio_tx_stb; +  wire [   7:0] radio1_radio_tx_running; + +  rfnoc_block_radio #( +    .THIS_PORTID         (3), +    .CHDR_W              (CHDR_W), +    .NUM_PORTS           (2), +    .NIPC                (RADIO_NIPC), +    .ITEM_W              (32), +    .MTU                 (MTU) +  ) b_radio1_1 ( +    .rfnoc_chdr_clk      (rfnoc_chdr_clk), +    .rfnoc_ctrl_clk      (rfnoc_ctrl_clk), +    .radio_clk           (radio1_radio_clk), +    .rfnoc_core_config   (rfnoc_core_config[512*2-1:512*1]), +    .rfnoc_core_status   (rfnoc_core_status[512*2-1:512*1]), +    .m_ctrlport_req_wr   (radio1_m_ctrlport_req_wr), +    .m_ctrlport_req_rd   (radio1_m_ctrlport_req_rd), +    .m_ctrlport_req_addr (radio1_m_ctrlport_req_addr), +    .m_ctrlport_req_data (radio1_m_ctrlport_req_data), +    .m_ctrlport_req_byte_en(radio1_m_ctrlport_req_byte_en), +    .m_ctrlport_req_has_time(radio1_m_ctrlport_req_has_time), +    .m_ctrlport_req_time (radio1_m_ctrlport_req_time), +    .m_ctrlport_resp_ack (radio1_m_ctrlport_resp_ack), +    .m_ctrlport_resp_status(radio1_m_ctrlport_resp_status), +    .m_ctrlport_resp_data(radio1_m_ctrlport_resp_data), +    .radio_time          (radio1_radio_time), +    .radio_rx_data       (radio1_radio_rx_data), +    .radio_rx_stb        (radio1_radio_rx_stb), +    .radio_rx_running    (radio1_radio_rx_running), +    .radio_tx_data       (radio1_radio_tx_data), +    .radio_tx_stb        (radio1_radio_tx_stb), +    .radio_tx_running    (radio1_radio_tx_running), +    .s_rfnoc_chdr_tdata  ({s_radio1_in_1_tdata , s_radio1_in_0_tdata }), +    .s_rfnoc_chdr_tlast  ({s_radio1_in_1_tlast , s_radio1_in_0_tlast }), +    .s_rfnoc_chdr_tvalid ({s_radio1_in_1_tvalid, s_radio1_in_0_tvalid}), +    .s_rfnoc_chdr_tready ({s_radio1_in_1_tready, s_radio1_in_0_tready}), +    .m_rfnoc_chdr_tdata  ({m_radio1_out_1_tdata , m_radio1_out_0_tdata }), +    .m_rfnoc_chdr_tlast  ({m_radio1_out_1_tlast , m_radio1_out_0_tlast }), +    .m_rfnoc_chdr_tvalid ({m_radio1_out_1_tvalid, m_radio1_out_0_tvalid}), +    .m_rfnoc_chdr_tready ({m_radio1_out_1_tready, m_radio1_out_0_tready}), +    .s_rfnoc_ctrl_tdata  (s_radio1_ctrl_tdata), +    .s_rfnoc_ctrl_tlast  (s_radio1_ctrl_tlast), +    .s_rfnoc_ctrl_tvalid (s_radio1_ctrl_tvalid), +    .s_rfnoc_ctrl_tready (s_radio1_ctrl_tready), +    .m_rfnoc_ctrl_tdata  (m_radio1_ctrl_tdata), +    .m_rfnoc_ctrl_tlast  (m_radio1_ctrl_tlast), +    .m_rfnoc_ctrl_tvalid (m_radio1_ctrl_tvalid), +    .m_rfnoc_ctrl_tready (m_radio1_ctrl_tready) +  ); + +  //----------------------------------- +  // replay0 +  //----------------------------------- + +  wire              replay0_mem_clk; +  wire [CHDR_W-1:0] s_replay0_in_3_tdata , s_replay0_in_2_tdata , s_replay0_in_1_tdata , s_replay0_in_0_tdata ; +  wire              s_replay0_in_3_tlast , s_replay0_in_2_tlast , s_replay0_in_1_tlast , s_replay0_in_0_tlast ; +  wire              s_replay0_in_3_tvalid, s_replay0_in_2_tvalid, s_replay0_in_1_tvalid, s_replay0_in_0_tvalid; +  wire              s_replay0_in_3_tready, s_replay0_in_2_tready, s_replay0_in_1_tready, s_replay0_in_0_tready; +  wire [CHDR_W-1:0] m_replay0_out_3_tdata , m_replay0_out_2_tdata , m_replay0_out_1_tdata , m_replay0_out_0_tdata ; +  wire              m_replay0_out_3_tlast , m_replay0_out_2_tlast , m_replay0_out_1_tlast , m_replay0_out_0_tlast ; +  wire              m_replay0_out_3_tvalid, m_replay0_out_2_tvalid, m_replay0_out_1_tvalid, m_replay0_out_0_tvalid; +  wire              m_replay0_out_3_tready, m_replay0_out_2_tready, m_replay0_out_1_tready, m_replay0_out_0_tready; + +  // axi_ram +  wire [   0:0] replay0_axi_rst; +  wire [   3:0] replay0_m_axi_awid; +  wire [ 191:0] replay0_m_axi_awaddr; +  wire [  31:0] replay0_m_axi_awlen; +  wire [  11:0] replay0_m_axi_awsize; +  wire [   7:0] replay0_m_axi_awburst; +  wire [   3:0] replay0_m_axi_awlock; +  wire [  15:0] replay0_m_axi_awcache; +  wire [  11:0] replay0_m_axi_awprot; +  wire [  15:0] replay0_m_axi_awqos; +  wire [  15:0] replay0_m_axi_awregion; +  wire [   3:0] replay0_m_axi_awuser; +  wire [   3:0] replay0_m_axi_awvalid; +  wire [   3:0] replay0_m_axi_awready; +  wire [2047:0] replay0_m_axi_wdata; +  wire [ 255:0] replay0_m_axi_wstrb; +  wire [   3:0] replay0_m_axi_wlast; +  wire [   3:0] replay0_m_axi_wuser; +  wire [   3:0] replay0_m_axi_wvalid; +  wire [   3:0] replay0_m_axi_wready; +  wire [   3:0] replay0_m_axi_bid; +  wire [   7:0] replay0_m_axi_bresp; +  wire [   3:0] replay0_m_axi_buser; +  wire [   3:0] replay0_m_axi_bvalid; +  wire [   3:0] replay0_m_axi_bready; +  wire [   3:0] replay0_m_axi_arid; +  wire [ 191:0] replay0_m_axi_araddr; +  wire [  31:0] replay0_m_axi_arlen; +  wire [  11:0] replay0_m_axi_arsize; +  wire [   7:0] replay0_m_axi_arburst; +  wire [   3:0] replay0_m_axi_arlock; +  wire [  15:0] replay0_m_axi_arcache; +  wire [  11:0] replay0_m_axi_arprot; +  wire [  15:0] replay0_m_axi_arqos; +  wire [  15:0] replay0_m_axi_arregion; +  wire [   3:0] replay0_m_axi_aruser; +  wire [   3:0] replay0_m_axi_arvalid; +  wire [   3:0] replay0_m_axi_arready; +  wire [   3:0] replay0_m_axi_rid; +  wire [2047:0] replay0_m_axi_rdata; +  wire [   7:0] replay0_m_axi_rresp; +  wire [   3:0] replay0_m_axi_rlast; +  wire [   3:0] replay0_m_axi_ruser; +  wire [   3:0] replay0_m_axi_rvalid; +  wire [   3:0] replay0_m_axi_rready; + +  rfnoc_block_replay #( +    .THIS_PORTID         (4), +    .CHDR_W              (CHDR_W), +    .NUM_PORTS           (4), +    .MEM_DATA_W          (128), +    .MEM_ADDR_W          (32), +    .MTU                 (MTU) +  ) b_replay0_2 ( +    .rfnoc_chdr_clk      (rfnoc_chdr_clk), +    .rfnoc_ctrl_clk      (rfnoc_ctrl_clk), +    .mem_clk             (replay0_mem_clk), +    .rfnoc_core_config   (rfnoc_core_config[512*3-1:512*2]), +    .rfnoc_core_status   (rfnoc_core_status[512*3-1:512*2]), +    .axi_rst             (replay0_axi_rst), +    .m_axi_awid          (replay0_m_axi_awid), +    .m_axi_awaddr        (replay0_m_axi_awaddr), +    .m_axi_awlen         (replay0_m_axi_awlen), +    .m_axi_awsize        (replay0_m_axi_awsize), +    .m_axi_awburst       (replay0_m_axi_awburst), +    .m_axi_awlock        (replay0_m_axi_awlock), +    .m_axi_awcache       (replay0_m_axi_awcache), +    .m_axi_awprot        (replay0_m_axi_awprot), +    .m_axi_awqos         (replay0_m_axi_awqos), +    .m_axi_awregion      (replay0_m_axi_awregion), +    .m_axi_awuser        (replay0_m_axi_awuser), +    .m_axi_awvalid       (replay0_m_axi_awvalid), +    .m_axi_awready       (replay0_m_axi_awready), +    .m_axi_wdata         (replay0_m_axi_wdata), +    .m_axi_wstrb         (replay0_m_axi_wstrb), +    .m_axi_wlast         (replay0_m_axi_wlast), +    .m_axi_wuser         (replay0_m_axi_wuser), +    .m_axi_wvalid        (replay0_m_axi_wvalid), +    .m_axi_wready        (replay0_m_axi_wready), +    .m_axi_bid           (replay0_m_axi_bid), +    .m_axi_bresp         (replay0_m_axi_bresp), +    .m_axi_buser         (replay0_m_axi_buser), +    .m_axi_bvalid        (replay0_m_axi_bvalid), +    .m_axi_bready        (replay0_m_axi_bready), +    .m_axi_arid          (replay0_m_axi_arid), +    .m_axi_araddr        (replay0_m_axi_araddr), +    .m_axi_arlen         (replay0_m_axi_arlen), +    .m_axi_arsize        (replay0_m_axi_arsize), +    .m_axi_arburst       (replay0_m_axi_arburst), +    .m_axi_arlock        (replay0_m_axi_arlock), +    .m_axi_arcache       (replay0_m_axi_arcache), +    .m_axi_arprot        (replay0_m_axi_arprot), +    .m_axi_arqos         (replay0_m_axi_arqos), +    .m_axi_arregion      (replay0_m_axi_arregion), +    .m_axi_aruser        (replay0_m_axi_aruser), +    .m_axi_arvalid       (replay0_m_axi_arvalid), +    .m_axi_arready       (replay0_m_axi_arready), +    .m_axi_rid           (replay0_m_axi_rid), +    .m_axi_rdata         (replay0_m_axi_rdata), +    .m_axi_rresp         (replay0_m_axi_rresp), +    .m_axi_rlast         (replay0_m_axi_rlast), +    .m_axi_ruser         (replay0_m_axi_ruser), +    .m_axi_rvalid        (replay0_m_axi_rvalid), +    .m_axi_rready        (replay0_m_axi_rready), +    .s_rfnoc_chdr_tdata  ({s_replay0_in_3_tdata , s_replay0_in_2_tdata , s_replay0_in_1_tdata , s_replay0_in_0_tdata }), +    .s_rfnoc_chdr_tlast  ({s_replay0_in_3_tlast , s_replay0_in_2_tlast , s_replay0_in_1_tlast , s_replay0_in_0_tlast }), +    .s_rfnoc_chdr_tvalid ({s_replay0_in_3_tvalid, s_replay0_in_2_tvalid, s_replay0_in_1_tvalid, s_replay0_in_0_tvalid}), +    .s_rfnoc_chdr_tready ({s_replay0_in_3_tready, s_replay0_in_2_tready, s_replay0_in_1_tready, s_replay0_in_0_tready}), +    .m_rfnoc_chdr_tdata  ({m_replay0_out_3_tdata , m_replay0_out_2_tdata , m_replay0_out_1_tdata , m_replay0_out_0_tdata }), +    .m_rfnoc_chdr_tlast  ({m_replay0_out_3_tlast , m_replay0_out_2_tlast , m_replay0_out_1_tlast , m_replay0_out_0_tlast }), +    .m_rfnoc_chdr_tvalid ({m_replay0_out_3_tvalid, m_replay0_out_2_tvalid, m_replay0_out_1_tvalid, m_replay0_out_0_tvalid}), +    .m_rfnoc_chdr_tready ({m_replay0_out_3_tready, m_replay0_out_2_tready, m_replay0_out_1_tready, m_replay0_out_0_tready}), +    .s_rfnoc_ctrl_tdata  (s_replay0_ctrl_tdata), +    .s_rfnoc_ctrl_tlast  (s_replay0_ctrl_tlast), +    .s_rfnoc_ctrl_tvalid (s_replay0_ctrl_tvalid), +    .s_rfnoc_ctrl_tready (s_replay0_ctrl_tready), +    .m_rfnoc_ctrl_tdata  (m_replay0_ctrl_tdata), +    .m_rfnoc_ctrl_tlast  (m_replay0_ctrl_tlast), +    .m_rfnoc_ctrl_tvalid (m_replay0_ctrl_tvalid), +    .m_rfnoc_ctrl_tready (m_replay0_ctrl_tready) +  ); + +  //--------------------------------------------------------------------------- +  // Static Router +  //--------------------------------------------------------------------------- + +  assign s_radio0_in_0_tdata = m_ep0_out0_tdata; +  assign s_radio0_in_0_tlast = m_ep0_out0_tlast; +  assign s_radio0_in_0_tvalid = m_ep0_out0_tvalid; +  assign m_ep0_out0_tready = s_radio0_in_0_tready; + +  assign s_ep0_in0_tdata = m_radio0_out_0_tdata; +  assign s_ep0_in0_tlast = m_radio0_out_0_tlast; +  assign s_ep0_in0_tvalid = m_radio0_out_0_tvalid; +  assign m_radio0_out_0_tready = s_ep0_in0_tready; + +  assign s_radio0_in_1_tdata = m_ep1_out0_tdata; +  assign s_radio0_in_1_tlast = m_ep1_out0_tlast; +  assign s_radio0_in_1_tvalid = m_ep1_out0_tvalid; +  assign m_ep1_out0_tready = s_radio0_in_1_tready; + +  assign s_ep1_in0_tdata = m_radio0_out_1_tdata; +  assign s_ep1_in0_tlast = m_radio0_out_1_tlast; +  assign s_ep1_in0_tvalid = m_radio0_out_1_tvalid; +  assign m_radio0_out_1_tready = s_ep1_in0_tready; + +  assign s_radio1_in_0_tdata = m_ep2_out0_tdata; +  assign s_radio1_in_0_tlast = m_ep2_out0_tlast; +  assign s_radio1_in_0_tvalid = m_ep2_out0_tvalid; +  assign m_ep2_out0_tready = s_radio1_in_0_tready; + +  assign s_ep2_in0_tdata = m_radio1_out_0_tdata; +  assign s_ep2_in0_tlast = m_radio1_out_0_tlast; +  assign s_ep2_in0_tvalid = m_radio1_out_0_tvalid; +  assign m_radio1_out_0_tready = s_ep2_in0_tready; + +  assign s_radio1_in_1_tdata = m_ep3_out0_tdata; +  assign s_radio1_in_1_tlast = m_ep3_out0_tlast; +  assign s_radio1_in_1_tvalid = m_ep3_out0_tvalid; +  assign m_ep3_out0_tready = s_radio1_in_1_tready; + +  assign s_ep3_in0_tdata = m_radio1_out_1_tdata; +  assign s_ep3_in0_tlast = m_radio1_out_1_tlast; +  assign s_ep3_in0_tvalid = m_radio1_out_1_tvalid; +  assign m_radio1_out_1_tready = s_ep3_in0_tready; + +  assign s_replay0_in_0_tdata = m_ep4_out0_tdata; +  assign s_replay0_in_0_tlast = m_ep4_out0_tlast; +  assign s_replay0_in_0_tvalid = m_ep4_out0_tvalid; +  assign m_ep4_out0_tready = s_replay0_in_0_tready; + +  assign s_ep4_in0_tdata = m_replay0_out_0_tdata; +  assign s_ep4_in0_tlast = m_replay0_out_0_tlast; +  assign s_ep4_in0_tvalid = m_replay0_out_0_tvalid; +  assign m_replay0_out_0_tready = s_ep4_in0_tready; + +  assign s_replay0_in_1_tdata = m_ep5_out0_tdata; +  assign s_replay0_in_1_tlast = m_ep5_out0_tlast; +  assign s_replay0_in_1_tvalid = m_ep5_out0_tvalid; +  assign m_ep5_out0_tready = s_replay0_in_1_tready; + +  assign s_ep5_in0_tdata = m_replay0_out_1_tdata; +  assign s_ep5_in0_tlast = m_replay0_out_1_tlast; +  assign s_ep5_in0_tvalid = m_replay0_out_1_tvalid; +  assign m_replay0_out_1_tready = s_ep5_in0_tready; + +  assign s_replay0_in_2_tdata = m_ep6_out0_tdata; +  assign s_replay0_in_2_tlast = m_ep6_out0_tlast; +  assign s_replay0_in_2_tvalid = m_ep6_out0_tvalid; +  assign m_ep6_out0_tready = s_replay0_in_2_tready; + +  assign s_ep6_in0_tdata = m_replay0_out_2_tdata; +  assign s_ep6_in0_tlast = m_replay0_out_2_tlast; +  assign s_ep6_in0_tvalid = m_replay0_out_2_tvalid; +  assign m_replay0_out_2_tready = s_ep6_in0_tready; + +  assign s_replay0_in_3_tdata = m_ep7_out0_tdata; +  assign s_replay0_in_3_tlast = m_ep7_out0_tlast; +  assign s_replay0_in_3_tvalid = m_ep7_out0_tvalid; +  assign m_ep7_out0_tready = s_replay0_in_3_tready; + +  assign s_ep7_in0_tdata = m_replay0_out_3_tdata; +  assign s_ep7_in0_tlast = m_replay0_out_3_tlast; +  assign s_ep7_in0_tvalid = m_replay0_out_3_tvalid; +  assign m_replay0_out_3_tready = s_ep7_in0_tready; + + +  //--------------------------------------------------------------------------- +  // Unused Ports +  //--------------------------------------------------------------------------- + + + +  //--------------------------------------------------------------------------- +  // Clock Domains +  //--------------------------------------------------------------------------- + +  assign radio0_radio_clk = radio_clk; +  assign radio1_radio_clk = radio_clk; +  assign replay0_mem_clk = dram_clk; + + +  //--------------------------------------------------------------------------- +  // IO Port Connection +  //--------------------------------------------------------------------------- + +  // Master/Slave Connections: +  assign m_ctrlport_radio0_req_wr = radio0_m_ctrlport_req_wr; +  assign m_ctrlport_radio0_req_rd = radio0_m_ctrlport_req_rd; +  assign m_ctrlport_radio0_req_addr = radio0_m_ctrlport_req_addr; +  assign m_ctrlport_radio0_req_data = radio0_m_ctrlport_req_data; +  assign m_ctrlport_radio0_req_byte_en = radio0_m_ctrlport_req_byte_en; +  assign m_ctrlport_radio0_req_has_time = radio0_m_ctrlport_req_has_time; +  assign m_ctrlport_radio0_req_time = radio0_m_ctrlport_req_time; +  assign radio0_m_ctrlport_resp_ack = m_ctrlport_radio0_resp_ack; +  assign radio0_m_ctrlport_resp_status = m_ctrlport_radio0_resp_status; +  assign radio0_m_ctrlport_resp_data = m_ctrlport_radio0_resp_data; + +  assign m_ctrlport_radio1_req_wr = radio1_m_ctrlport_req_wr; +  assign m_ctrlport_radio1_req_rd = radio1_m_ctrlport_req_rd; +  assign m_ctrlport_radio1_req_addr = radio1_m_ctrlport_req_addr; +  assign m_ctrlport_radio1_req_data = radio1_m_ctrlport_req_data; +  assign m_ctrlport_radio1_req_byte_en = radio1_m_ctrlport_req_byte_en; +  assign m_ctrlport_radio1_req_has_time = radio1_m_ctrlport_req_has_time; +  assign m_ctrlport_radio1_req_time = radio1_m_ctrlport_req_time; +  assign radio1_m_ctrlport_resp_ack = m_ctrlport_radio1_resp_ack; +  assign radio1_m_ctrlport_resp_status = m_ctrlport_radio1_resp_status; +  assign radio1_m_ctrlport_resp_data = m_ctrlport_radio1_resp_data; + +  assign radio0_radio_rx_data = radio_rx_data_radio0; +  assign radio0_radio_rx_stb = radio_rx_stb_radio0; +  assign radio_rx_running_radio0 = radio0_radio_rx_running; +  assign radio_tx_data_radio0 = radio0_radio_tx_data; +  assign radio0_radio_tx_stb = radio_tx_stb_radio0; +  assign radio_tx_running_radio0 = radio0_radio_tx_running; + +  assign radio1_radio_rx_data = radio_rx_data_radio1; +  assign radio1_radio_rx_stb = radio_rx_stb_radio1; +  assign radio_rx_running_radio1 = radio1_radio_rx_running; +  assign radio_tx_data_radio1 = radio1_radio_tx_data; +  assign radio1_radio_tx_stb = radio_tx_stb_radio1; +  assign radio_tx_running_radio1 = radio1_radio_tx_running; + +  assign replay0_axi_rst = axi_rst; +  assign m_axi_awid = replay0_m_axi_awid; +  assign m_axi_awaddr = replay0_m_axi_awaddr; +  assign m_axi_awlen = replay0_m_axi_awlen; +  assign m_axi_awsize = replay0_m_axi_awsize; +  assign m_axi_awburst = replay0_m_axi_awburst; +  assign m_axi_awlock = replay0_m_axi_awlock; +  assign m_axi_awcache = replay0_m_axi_awcache; +  assign m_axi_awprot = replay0_m_axi_awprot; +  assign m_axi_awqos = replay0_m_axi_awqos; +  assign m_axi_awregion = replay0_m_axi_awregion; +  assign m_axi_awuser = replay0_m_axi_awuser; +  assign m_axi_awvalid = replay0_m_axi_awvalid; +  assign replay0_m_axi_awready = m_axi_awready; +  assign m_axi_wdata = replay0_m_axi_wdata; +  assign m_axi_wstrb = replay0_m_axi_wstrb; +  assign m_axi_wlast = replay0_m_axi_wlast; +  assign m_axi_wuser = replay0_m_axi_wuser; +  assign m_axi_wvalid = replay0_m_axi_wvalid; +  assign replay0_m_axi_wready = m_axi_wready; +  assign replay0_m_axi_bid = m_axi_bid; +  assign replay0_m_axi_bresp = m_axi_bresp; +  assign replay0_m_axi_buser = m_axi_buser; +  assign replay0_m_axi_bvalid = m_axi_bvalid; +  assign m_axi_bready = replay0_m_axi_bready; +  assign m_axi_arid = replay0_m_axi_arid; +  assign m_axi_araddr = replay0_m_axi_araddr; +  assign m_axi_arlen = replay0_m_axi_arlen; +  assign m_axi_arsize = replay0_m_axi_arsize; +  assign m_axi_arburst = replay0_m_axi_arburst; +  assign m_axi_arlock = replay0_m_axi_arlock; +  assign m_axi_arcache = replay0_m_axi_arcache; +  assign m_axi_arprot = replay0_m_axi_arprot; +  assign m_axi_arqos = replay0_m_axi_arqos; +  assign m_axi_arregion = replay0_m_axi_arregion; +  assign m_axi_aruser = replay0_m_axi_aruser; +  assign m_axi_arvalid = replay0_m_axi_arvalid; +  assign replay0_m_axi_arready = m_axi_arready; +  assign replay0_m_axi_rid = m_axi_rid; +  assign replay0_m_axi_rdata = m_axi_rdata; +  assign replay0_m_axi_rresp = m_axi_rresp; +  assign replay0_m_axi_rlast = m_axi_rlast; +  assign replay0_m_axi_ruser = m_axi_ruser; +  assign replay0_m_axi_rvalid = m_axi_rvalid; +  assign m_axi_rready = replay0_m_axi_rready; + +  // Broadcaster/Listener Connections: +  assign radio0_radio_time = radio_time; + +  assign radio1_radio_time = radio_time; + +endmodule + + +`default_nettype wire diff --git a/fpga/usrp3/top/x400/x410_400_128_rfnoc_image_core.vh b/fpga/usrp3/top/x400/x410_400_128_rfnoc_image_core.vh new file mode 100644 index 000000000..229eeeefe --- /dev/null +++ b/fpga/usrp3/top/x400/x410_400_128_rfnoc_image_core.vh @@ -0,0 +1,21 @@ +// +// Copyright 2022 Ettus Research, A National Instruments Brand +// +// SPDX-License-Identifier: LGPL-3.0-or-later +// +// Header: rfnoc_image_core.vh (for x410) +// +// Description: +// +//   This is the header file for the RFNoC Image Core. +// +//   This file was automatically generated by the RFNoC image builder tool. +//   Re-running that tool will overwrite this file! +// +// File generated on: 2022-03-14T16:50:52.329591 +// Source: ./x410_400_128_rfnoc_image_core.yml +// Source SHA256: 78673c977afc0a046ef08c3070fd3600aac7ba8918ce79c698731d693678cd85 +// + +`define CHDR_WIDTH     128 +`define RFNOC_PROTOVER { 8'd1, 8'd0 } diff --git a/fpga/usrp3/top/x400/x410_400_128_rfnoc_image_core.yml b/fpga/usrp3/top/x400/x410_400_128_rfnoc_image_core.yml new file mode 100644 index 000000000..4c6f4a62e --- /dev/null +++ b/fpga/usrp3/top/x400/x410_400_128_rfnoc_image_core.yml @@ -0,0 +1,118 @@ +# General parameters +# ----------------------------------------- +schema: rfnoc_imagebuilder_args    # Identifier for the schema used to validate this file +copyright: 'Ettus Research, A National Instruments Brand' # Copyright information used in file headers +license: 'SPDX-License-Identifier: LGPL-3.0-or-later'     # License information used in file headers +version: '1.0'                     # File version +rfnoc_version: '1.0'               # RFNoC protocol version +chdr_width: 128                    # Bit width of the CHDR bus for this image +device: 'x410'                     # USRP type +image_core_name: 'x410_400_128'    # Name to use for the RFNoC Image Core files +default_target: 'X410_X4_400'      # Default make target + +# A list of all stream endpoints in design +# ---------------------------------------- +stream_endpoints: +  ep0:                       # Stream endpoint name +    ctrl: True                 # Endpoint passes control traffic +    data: True                 # Endpoint passes data traffic +    buff_size_bytes: 32768     # Stream endpoint buffer size +  ep1: +    ctrl: False +    data: True +    buff_size_bytes: 32768 +  ep2: +    ctrl: False +    data: True +    buff_size_bytes: 32768 +  ep3: +    ctrl: False +    data: True +    buff_size_bytes: 32768 +  ep4: +    ctrl: False +    data: True +    buff_size_bytes: 32768 +  ep5: +    ctrl: False +    data: True +    buff_size_bytes: 32768 +  ep6: +    ctrl: False +    data: True +    buff_size_bytes: 32768 +  ep7: +    ctrl: False +    data: True +    buff_size_bytes: 32768 + +# A list of all NoC blocks in design +# ---------------------------------- +noc_blocks: +  radio0: +    block_desc: 'radio.yml' +    parameters: +      NUM_PORTS: 2 +      NIPC: RADIO_NIPC +  radio1: +    block_desc: 'radio.yml' +    parameters: +      NUM_PORTS: 2 +      NIPC: RADIO_NIPC +  replay0: +    block_desc: 'replay.yml' +    parameters: +      NUM_PORTS: 4 +      MEM_DATA_W: 128 +      MEM_ADDR_W: 32 + +# A list of all static connections in design +# ------------------------------------------ +# Format: A list of connection maps (list of key-value pairs) with the following keys +#         - srcblk  = Source block to connect +#         - srcport = Port on the source block to connect +#         - dstblk  = Destination block to connect +#         - dstport = Port on the destination block to connect +connections: +  # Daughter Board 0 Radio +  - { srcblk: ep0,      srcport: out0,     dstblk: radio0,   dstport: in_0            } +  - { srcblk: radio0,   srcport: out_0,    dstblk: ep0,      dstport: in0             } +  - { srcblk: ep1,      srcport: out0,     dstblk: radio0,   dstport: in_1            } +  - { srcblk: radio0,   srcport: out_1,    dstblk: ep1,      dstport: in0             } +  # +  # Daughter Board 1 Radio +  - { srcblk: ep2,      srcport: out0,     dstblk: radio1,   dstport: in_0            } +  - { srcblk: radio1,   srcport: out_0,    dstblk: ep2,      dstport: in0             } +  - { srcblk: ep3,      srcport: out0,     dstblk: radio1,   dstport: in_1            } +  - { srcblk: radio1,   srcport: out_1,    dstblk: ep3,      dstport: in0             } +  # +  # Replay +  - { srcblk: ep4,      srcport: out0,     dstblk: replay0,  dstport: in_0            } +  - { srcblk: replay0,  srcport: out_0,    dstblk: ep4,      dstport: in0             } +  - { srcblk: ep5,      srcport: out0,     dstblk: replay0,  dstport: in_1            } +  - { srcblk: replay0,  srcport: out_1,    dstblk: ep5,      dstport: in0             } +  - { srcblk: ep6,      srcport: out0,     dstblk: replay0,  dstport: in_2            } +  - { srcblk: replay0,  srcport: out_2,    dstblk: ep6,      dstport: in0             } +  - { srcblk: ep7,      srcport: out0,     dstblk: replay0,  dstport: in_3            } +  - { srcblk: replay0,  srcport: out_3,    dstblk: ep7,      dstport: in0             } +  # +  # BSP Connections +  - { srcblk: radio0,   srcport: ctrlport, dstblk: _device_, dstport: ctrlport_radio0 } +  - { srcblk: radio1,   srcport: ctrlport, dstblk: _device_, dstport: ctrlport_radio1 } +  - { srcblk: _device_, srcport: radio0,   dstblk: radio0,   dstport: radio           } +  - { srcblk: _device_, srcport: radio1,   dstblk: radio1,   dstport: radio           } +  - { srcblk: _device_, srcport: time,     dstblk: radio0,   dstport: time            } +  - { srcblk: _device_, srcport: time,     dstblk: radio1,   dstport: time            } +  - { srcblk: replay0,  srcport: axi_ram,  dstblk: _device_, dstport: dram            } + +# A list of all clock domain connections in design +# ------------------------------------------------ +# Format: A list of connection maps (list of key-value pairs) with the following keys +#         - srcblk  = Source block to connect (Always "_device_") +#         - srcport = Clock domain on the source block to connect +#         - dstblk  = Destination block to connect +#         - dstport = Clock domain on the destination block to connect +clk_domains: +  - { srcblk: _device_, srcport: radio, dstblk: radio0,  dstport: radio } +  - { srcblk: _device_, srcport: radio, dstblk: radio1,  dstport: radio } +  - { srcblk: _device_, srcport: dram,  dstblk: replay0, dstport: mem   } diff --git a/fpga/usrp3/top/x400/x410_400_128_static_router.hex b/fpga/usrp3/top/x400/x410_400_128_static_router.hex new file mode 100644 index 000000000..d9d6460b2 --- /dev/null +++ b/fpga/usrp3/top/x400/x410_400_128_static_router.hex @@ -0,0 +1,17 @@ +00000010 +00400240 +02400040 +00800241 +02410080 +00c00280 +028000c0 +01000281 +02810100 +014002c0 +02c00140 +018002c1 +02c10180 +01c002c2 +02c201c0 +020002c3 +02c30200 | 
