aboutsummaryrefslogtreecommitdiffstats
path: root/fpga/usrp3
diff options
context:
space:
mode:
Diffstat (limited to 'fpga/usrp3')
-rw-r--r--fpga/usrp3/top/e31x/e310_rfnoc_image_core.v433
-rw-r--r--fpga/usrp3/top/e31x/e310_rfnoc_image_core.vh21
-rw-r--r--fpga/usrp3/top/e31x/e310_rfnoc_image_core.yml3
-rw-r--r--fpga/usrp3/top/e320/e320_rfnoc_image_core.v1091
-rw-r--r--fpga/usrp3/top/e320/e320_rfnoc_image_core.vh21
-rw-r--r--fpga/usrp3/top/n3xx/n300_bist_image_core.v951
-rw-r--r--fpga/usrp3/top/n3xx/n300_rfnoc_image_core.v1103
-rw-r--r--fpga/usrp3/top/n3xx/n300_rfnoc_image_core.vh21
-rw-r--r--fpga/usrp3/top/n3xx/n310_bist_image_core.v1247
-rw-r--r--fpga/usrp3/top/n3xx/n310_rfnoc_image_core.v1685
-rw-r--r--fpga/usrp3/top/n3xx/n310_rfnoc_image_core.vh21
-rw-r--r--fpga/usrp3/top/n3xx/n320_bist_image_core.v1117
-rw-r--r--fpga/usrp3/top/n3xx/n320_rfnoc_image_core.v1413
-rw-r--r--fpga/usrp3/top/n3xx/n320_rfnoc_image_core.vh21
-rw-r--r--fpga/usrp3/top/x300/x300_rfnoc_image_core.v1541
-rw-r--r--fpga/usrp3/top/x300/x300_rfnoc_image_core.vh21
-rw-r--r--fpga/usrp3/top/x300/x310_rfnoc_image_core.v1541
-rw-r--r--fpga/usrp3/top/x300/x310_rfnoc_image_core.vh21
18 files changed, 6492 insertions, 5780 deletions
diff --git a/fpga/usrp3/top/e31x/e310_rfnoc_image_core.v b/fpga/usrp3/top/e31x/e310_rfnoc_image_core.v
index 9b288ad16..5d3e47f35 100644
--- a/fpga/usrp3/top/e31x/e310_rfnoc_image_core.v
+++ b/fpga/usrp3/top/e31x/e310_rfnoc_image_core.v
@@ -1,68 +1,86 @@
//
-// Copyright 2020 Ettus Research, A National Instruments Brand
+// Copyright 2021 Ettus Research, A National Instruments Brand
//
// SPDX-License-Identifier: LGPL-3.0-or-later
//
-
// Module: rfnoc_image_core (for e31x)
-// This file was autogenerated by UHD's image builder tool (rfnoc_image_builder)
-// Re-running that tool will overwrite this file!
-// File generated on: 2020-09-08T10:54:16.062742
+//
+// 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: 2021-05-03T08:51:11.395850
// Source: e310_rfnoc_image_core.yml
-// Source SHA256: 00908abb846aaf175d1f8f2e75c6d39a3cd4958b326ab3125f4a1023c7b78b39
+// Source SHA256: 7fef622f1ae280dd7573abd823c7a6bbecf51921a74cea948e6bfb9f8f65e2cc
+//
+
+`default_nettype none
+
module rfnoc_image_core #(
- parameter [15:0] PROTOVER = {8'd1, 8'd0}
-)(
+ parameter CHDR_W = 64,
+ 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,
// Basic
- input wire [15:0] device_id,
-//// IO ports //////////////////////////////////
-// ctrlport_radio
- output wire [ 1-1:0] m_ctrlport_req_wr,
- output wire [ 1-1:0] m_ctrlport_req_rd,
- output wire [ 20-1:0] m_ctrlport_req_addr,
- output wire [ 32-1:0] m_ctrlport_req_data,
- output wire [ 4-1:0] m_ctrlport_req_byte_en,
- output wire [ 1-1:0] m_ctrlport_req_has_time,
- output wire [ 64-1:0] m_ctrlport_req_time,
- input wire [ 1-1:0] m_ctrlport_resp_ack,
- input wire [ 2-1:0] m_ctrlport_resp_status,
- input wire [ 32-1:0] m_ctrlport_resp_data,
-// time_keeper
- input wire [ 64-1:0] radio_time,
-// x300_radio
- input wire [ 64-1:0] radio_rx_data,
- input wire [ 2-1:0] radio_rx_stb,
- output wire [ 2-1:0] radio_rx_running,
- output wire [ 64-1:0] radio_tx_data,
- input wire [ 2-1:0] radio_tx_stb,
- output wire [ 2-1:0] radio_tx_running,
- // Transport 0 (dma dma)
- input wire [64-1:0] s_dma_tdata,
- input wire s_dma_tlast,
- input wire s_dma_tvalid,
- output wire s_dma_tready,
- output wire [64-1:0] m_dma_tdata,
- output wire m_dma_tlast,
- output wire m_dma_tvalid,
- input wire m_dma_tready
+ input wire [ 15:0] device_id,
+
+ // IO ports /////////////////////////
+
+ // ctrlport_radio
+ output wire [ 0:0] m_ctrlport_req_wr,
+ output wire [ 0:0] m_ctrlport_req_rd,
+ output wire [ 19:0] m_ctrlport_req_addr,
+ output wire [ 31:0] m_ctrlport_req_data,
+ output wire [ 3:0] m_ctrlport_req_byte_en,
+ output wire [ 0:0] m_ctrlport_req_has_time,
+ output wire [ 63:0] m_ctrlport_req_time,
+ input wire [ 0:0] m_ctrlport_resp_ack,
+ input wire [ 1:0] m_ctrlport_resp_status,
+ input wire [ 31:0] m_ctrlport_resp_data,
+ // time_keeper
+ input wire [ 63:0] radio_time,
+ // x300_radio
+ input wire [ 63:0] radio_rx_data,
+ input wire [ 1:0] radio_rx_stb,
+ output wire [ 1:0] radio_rx_running,
+ output wire [ 63:0] radio_tx_data,
+ input wire [ 1:0] radio_tx_stb,
+ output wire [ 1:0] radio_tx_running,
+
+ // Transport Adapters ///////////////
+
+ // Transport 0 (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 CHDR_W = 64;
- localparam MTU = 10;
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;
@@ -95,12 +113,12 @@ module rfnoc_image_core #(
.clk (rfnoc_chdr_clk),
.reset (rfnoc_chdr_rst),
.device_id (device_id),
- .s_axis_tdata ({ep1_to_xb_tdata, ep0_to_xb_tdata, s_dma_tdata}),
- .s_axis_tlast ({ep1_to_xb_tlast, ep0_to_xb_tlast, s_dma_tlast}),
+ .s_axis_tdata ({ep1_to_xb_tdata , ep0_to_xb_tdata , s_dma_tdata }),
+ .s_axis_tlast ({ep1_to_xb_tlast , ep0_to_xb_tlast , s_dma_tlast }),
.s_axis_tvalid ({ep1_to_xb_tvalid, ep0_to_xb_tvalid, s_dma_tvalid}),
.s_axis_tready ({ep1_to_xb_tready, ep0_to_xb_tready, s_dma_tready}),
- .m_axis_tdata ({xb_to_ep1_tdata, xb_to_ep0_tdata, m_dma_tdata}),
- .m_axis_tlast ({xb_to_ep1_tlast, xb_to_ep0_tlast, m_dma_tlast}),
+ .m_axis_tdata ({xb_to_ep1_tdata , xb_to_ep0_tdata , m_dma_tdata }),
+ .m_axis_tlast ({xb_to_ep1_tlast , xb_to_ep0_tlast , m_dma_tlast }),
.m_axis_tvalid ({xb_to_ep1_tvalid, xb_to_ep0_tvalid, m_dma_tvalid}),
.m_axis_tready ({xb_to_ep1_tready, xb_to_ep0_tready, m_dma_tready}),
.ext_rtcfg_stb (1'h0),
@@ -109,9 +127,18 @@ module rfnoc_image_core #(
.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 = 16384;
+ 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;
@@ -121,8 +148,8 @@ module rfnoc_image_core #(
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 [ 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;
@@ -135,23 +162,23 @@ module rfnoc_image_core #(
.NUM_DATA_O (1),
.INST_NUM (0),
.CTRL_XBAR_PORT (1),
- .INGRESS_BUFF_SIZE (14),
+ .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 ),
+ .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}),
@@ -160,20 +187,28 @@ module rfnoc_image_core #(
.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_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_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 )
+ .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 = 16384;
+ 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;
@@ -182,8 +217,8 @@ module rfnoc_image_core #(
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 [ 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;
@@ -196,23 +231,23 @@ module rfnoc_image_core #(
.NUM_DATA_O (1),
.INST_NUM (1),
.CTRL_XBAR_PORT (2),
- .INGRESS_BUFF_SIZE (14),
+ .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 ),
+ .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}),
@@ -221,34 +256,33 @@ module rfnoc_image_core #(
.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_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_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 )
+ .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_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;
axis_ctrl_crossbar_nxn #(
.WIDTH (32),
@@ -272,9 +306,11 @@ module rfnoc_image_core #(
.deadlock_detected()
);
- // ----------------------------------------------------
+
+ //---------------------------------------------------------------------------
// RFNoC Core Kernel
- // ----------------------------------------------------
+ //---------------------------------------------------------------------------
+
wire [(512*1)-1:0] rfnoc_core_config, rfnoc_core_status;
rfnoc_core_kernel #(
@@ -299,12 +335,12 @@ module rfnoc_image_core #(
.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_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_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),
@@ -312,13 +348,15 @@ module rfnoc_image_core #(
.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 ;
@@ -329,113 +367,115 @@ module rfnoc_image_core #(
wire m_radio0_out_1_tvalid, m_radio0_out_0_tvalid;
wire m_radio0_out_1_tready, m_radio0_out_0_tready;
- // ctrl_port
- wire [ 1-1:0] radio0_m_ctrlport_req_wr;
- wire [ 1-1:0] radio0_m_ctrlport_req_rd;
- wire [ 20-1:0] radio0_m_ctrlport_req_addr;
- wire [ 32-1:0] radio0_m_ctrlport_req_data;
- wire [ 4-1:0] radio0_m_ctrlport_req_byte_en;
- wire [ 1-1:0] radio0_m_ctrlport_req_has_time;
- wire [ 64-1:0] radio0_m_ctrlport_req_time;
- wire [ 1-1:0] radio0_m_ctrlport_resp_ack;
- wire [ 2-1:0] radio0_m_ctrlport_resp_status;
- wire [ 32-1:0] radio0_m_ctrlport_resp_data;
- // time_keeper
- wire [ 64-1:0] radio0_radio_time;
- // x300_radio
- wire [ 64-1:0] radio0_radio_rx_data;
- wire [ 2-1:0] radio0_radio_rx_stb;
- wire [ 2-1:0] radio0_radio_rx_running;
- wire [ 64-1:0] radio0_radio_tx_data;
- wire [ 2-1:0] radio0_radio_tx_stb;
- wire [ 2-1:0] radio0_radio_tx_running;
+ // ctrl_port
+ 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_keeper
+ wire [ 63:0] radio0_radio_time;
+ // x300_radio
+ wire [ 63:0] radio0_radio_rx_data;
+ wire [ 1:0] radio0_radio_rx_stb;
+ wire [ 1:0] radio0_radio_rx_running;
+ wire [ 63:0] radio0_radio_tx_data;
+ wire [ 1:0] radio0_radio_tx_stb;
+ wire [ 1:0] radio0_radio_tx_running;
rfnoc_block_radio #(
- .THIS_PORTID(2),
- .CHDR_W(CHDR_W),
- .NUM_PORTS(2),
- .MTU(MTU)
+ .THIS_PORTID (2),
+ .CHDR_W (CHDR_W),
+ .NUM_PORTS (2),
+ .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),
+ .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_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)
+ .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)
);
-
- // ----------------------------------------------------
+ //---------------------------------------------------------------------------
// 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_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_radio0_in_1_tdata = m_ep1_out0_tdata ;
- assign s_radio0_in_1_tlast = m_ep1_out0_tlast ;
+ 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_ep0_in0_tdata = m_radio0_out_0_tdata ;
- assign s_ep0_in0_tlast = m_radio0_out_0_tlast ;
+ 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_ep1_in0_tdata = m_radio0_out_1_tdata ;
- assign s_ep1_in0_tlast = m_radio0_out_1_tlast ;
+ 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;
- // ----------------------------------------------------
+ //---------------------------------------------------------------------------
// Unused Ports
- // ----------------------------------------------------
+ //---------------------------------------------------------------------------
+
+
- // ----------------------------------------------------
+ //---------------------------------------------------------------------------
// Clock Domains
- // ----------------------------------------------------
+ //---------------------------------------------------------------------------
+
assign radio0_radio_clk = radio_clk;
- // ----------------------------------------------------
+ //---------------------------------------------------------------------------
// IO Port Connection
- // ----------------------------------------------------
+ //---------------------------------------------------------------------------
+
// Master/Slave Connections:
assign m_ctrlport_req_wr = radio0_m_ctrlport_req_wr;
assign m_ctrlport_req_rd = radio0_m_ctrlport_req_rd;
@@ -459,3 +499,6 @@ module rfnoc_image_core #(
assign radio0_radio_time = radio_time;
endmodule
+
+
+`default_nettype wire
diff --git a/fpga/usrp3/top/e31x/e310_rfnoc_image_core.vh b/fpga/usrp3/top/e31x/e310_rfnoc_image_core.vh
new file mode 100644
index 000000000..83ff8378c
--- /dev/null
+++ b/fpga/usrp3/top/e31x/e310_rfnoc_image_core.vh
@@ -0,0 +1,21 @@
+//
+// Copyright 2021 Ettus Research, A National Instruments Brand
+//
+// SPDX-License-Identifier: LGPL-3.0-or-later
+//
+// Header: rfnoc_image_core.vh (for e31x)
+//
+// 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: 2021-05-03T08:51:11.441866
+// Source: e310_rfnoc_image_core.yml
+// Source SHA256: 7fef622f1ae280dd7573abd823c7a6bbecf51921a74cea948e6bfb9f8f65e2cc
+//
+
+`define CHDR_WIDTH 64
+`define RFNOC_PROTOVER { 8'd1, 8'd0 }
diff --git a/fpga/usrp3/top/e31x/e310_rfnoc_image_core.yml b/fpga/usrp3/top/e31x/e310_rfnoc_image_core.yml
index f23dfa152..9ce36c66b 100644
--- a/fpga/usrp3/top/e31x/e310_rfnoc_image_core.yml
+++ b/fpga/usrp3/top/e31x/e310_rfnoc_image_core.yml
@@ -6,7 +6,8 @@ license: 'SPDX-License-Identifier: LGPL-3.0-or-later' # License information used
version: '1.0' # File version
rfnoc_version: '1.0' # RFNoC protocol version
chdr_width: 64 # Bit width of the CHDR bus for this image
-device: 'e310'
+device: 'e310' # USRP type
+image_core_name: 'e310' # Name to use for the RFNoC Image Core files
default_target: 'E310_SG3'
# A list of all stream endpoints in design
diff --git a/fpga/usrp3/top/e320/e320_rfnoc_image_core.v b/fpga/usrp3/top/e320/e320_rfnoc_image_core.v
index 0811c9cc7..928a26a60 100644
--- a/fpga/usrp3/top/e320/e320_rfnoc_image_core.v
+++ b/fpga/usrp3/top/e320/e320_rfnoc_image_core.v
@@ -1,19 +1,32 @@
//
-// Copyright 2019 Ettus Research, A National Instruments Brand
+// Copyright 2021 Ettus Research, A National Instruments Brand
//
// SPDX-License-Identifier: LGPL-3.0-or-later
//
-
// Module: rfnoc_image_core (for e320)
-// This file was autogenerated by UHD's image builder tool (rfnoc_image_builder)
-// Re-running that tool will overwrite this file!
-// File generated on: 2019-11-08T15:58:14.818480
-// Source: ./e320/e320_rfnoc_image_core.yml
-// Source SHA256: a2a7b213b5764ef6cb83fed9d744a415bf8a7f18a955fbe1f867590f5d8c5142
+//
+// 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: 2021-05-03T08:51:10.699215
+// Source: e320_rfnoc_image_core.yml
+// Source SHA256: 8b38ab7ba86e214c213ab62a63b698739c0858fdf10fcc5b737f87a56fb04454
+//
+
+`default_nettype none
+
module rfnoc_image_core #(
- parameter [15:0] PROTOVER = {8'd1, 8'd0}
-)(
+ parameter CHDR_W = 64,
+ parameter MTU = 10,
+ parameter [15:0] PROTOVER = {8'd1, 8'd0},
+ parameter RADIO_NIPC = 1
+) (
// Clocks
input wire chdr_aclk,
input wire ctrl_aclk,
@@ -21,104 +34,109 @@ module rfnoc_image_core #(
input wire radio_clk,
input wire dram_clk,
// Basic
- input wire [15:0] device_id,
-//// IO ports //////////////////////////////////
-// ctrl_port
- output wire [ 1-1:0] m_ctrlport_req_wr,
- output wire [ 1-1:0] m_ctrlport_req_rd,
- output wire [ 20-1:0] m_ctrlport_req_addr,
- output wire [ 32-1:0] m_ctrlport_req_data,
- output wire [ 4-1:0] m_ctrlport_req_byte_en,
- output wire [ 1-1:0] m_ctrlport_req_has_time,
- output wire [ 64-1:0] m_ctrlport_req_time,
- input wire [ 1-1:0] m_ctrlport_resp_ack,
- input wire [ 2-1:0] m_ctrlport_resp_status,
- input wire [ 32-1:0] m_ctrlport_resp_data,
-// time_keeper
- input wire [ 64-1:0] radio_time,
-// x300_radio
- input wire [ 64-1:0] radio_rx_data,
- input wire [ 2-1:0] radio_rx_stb,
- output wire [ 2-1:0] radio_rx_running,
- output wire [ 64-1:0] radio_tx_data,
- input wire [ 2-1:0] radio_tx_stb,
- output wire [ 2-1:0] radio_tx_running,
-// dram
- input wire [ 1-1:0] axi_rst,
- output wire [ 2-1:0] m_axi_awid,
- output wire [ 64-1:0] m_axi_awaddr,
- output wire [ 16-1:0] m_axi_awlen,
- output wire [ 6-1:0] m_axi_awsize,
- output wire [ 4-1:0] m_axi_awburst,
- output wire [ 2-1:0] m_axi_awlock,
- output wire [ 8-1:0] m_axi_awcache,
- output wire [ 6-1:0] m_axi_awprot,
- output wire [ 8-1:0] m_axi_awqos,
- output wire [ 8-1:0] m_axi_awregion,
- output wire [ 2-1:0] m_axi_awuser,
- output wire [ 2-1:0] m_axi_awvalid,
- input wire [ 2-1:0] m_axi_awready,
- output wire [128-1:0] m_axi_wdata,
- output wire [ 16-1:0] m_axi_wstrb,
- output wire [ 2-1:0] m_axi_wlast,
- output wire [ 2-1:0] m_axi_wuser,
- output wire [ 2-1:0] m_axi_wvalid,
- input wire [ 2-1:0] m_axi_wready,
- input wire [ 2-1:0] m_axi_bid,
- input wire [ 4-1:0] m_axi_bresp,
- input wire [ 2-1:0] m_axi_buser,
- input wire [ 2-1:0] m_axi_bvalid,
- output wire [ 2-1:0] m_axi_bready,
- output wire [ 2-1:0] m_axi_arid,
- output wire [ 64-1:0] m_axi_araddr,
- output wire [ 16-1:0] m_axi_arlen,
- output wire [ 6-1:0] m_axi_arsize,
- output wire [ 4-1:0] m_axi_arburst,
- output wire [ 2-1:0] m_axi_arlock,
- output wire [ 8-1:0] m_axi_arcache,
- output wire [ 6-1:0] m_axi_arprot,
- output wire [ 8-1:0] m_axi_arqos,
- output wire [ 8-1:0] m_axi_arregion,
- output wire [ 2-1:0] m_axi_aruser,
- output wire [ 2-1:0] m_axi_arvalid,
- input wire [ 2-1:0] m_axi_arready,
- input wire [ 2-1:0] m_axi_rid,
- input wire [128-1:0] m_axi_rdata,
- input wire [ 4-1:0] m_axi_rresp,
- input wire [ 2-1:0] m_axi_rlast,
- input wire [ 2-1:0] m_axi_ruser,
- input wire [ 2-1:0] m_axi_rvalid,
- output wire [ 2-1:0] m_axi_rready,
- // Transport 0 (eth 10G)
- input wire [64-1:0] s_eth_tdata,
- input wire s_eth_tlast,
- input wire s_eth_tvalid,
- output wire s_eth_tready,
- output wire [64-1:0] m_eth_tdata,
- output wire m_eth_tlast,
- output wire m_eth_tvalid,
- input wire m_eth_tready,
- // Transport 1 (dma dma)
- input wire [64-1:0] s_dma_tdata,
- input wire s_dma_tlast,
- input wire s_dma_tvalid,
- output wire s_dma_tready,
- output wire [64-1:0] m_dma_tdata,
- output wire m_dma_tlast,
- output wire m_dma_tvalid,
- input wire m_dma_tready
+ input wire [ 15:0] device_id,
+
+ // IO ports /////////////////////////
+
+ // ctrl_port
+ output wire [ 0:0] m_ctrlport_req_wr,
+ output wire [ 0:0] m_ctrlport_req_rd,
+ output wire [ 19:0] m_ctrlport_req_addr,
+ output wire [ 31:0] m_ctrlport_req_data,
+ output wire [ 3:0] m_ctrlport_req_byte_en,
+ output wire [ 0:0] m_ctrlport_req_has_time,
+ output wire [ 63:0] m_ctrlport_req_time,
+ input wire [ 0:0] m_ctrlport_resp_ack,
+ input wire [ 1:0] m_ctrlport_resp_status,
+ input wire [ 31:0] m_ctrlport_resp_data,
+ // time_keeper
+ input wire [ 63:0] radio_time,
+ // x300_radio
+ input wire [ 63:0] radio_rx_data,
+ input wire [ 1:0] radio_rx_stb,
+ output wire [ 1:0] radio_rx_running,
+ output wire [ 63:0] radio_tx_data,
+ input wire [ 1:0] radio_tx_stb,
+ output wire [ 1:0] radio_tx_running,
+ // dram
+ input wire [ 0:0] axi_rst,
+ output wire [ 3:0] m_axi_awid,
+ output wire [ 127: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 [ 255:0] m_axi_wdata,
+ output wire [ 31: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 [ 127: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 [ 255: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 (eth)
+ input wire [CHDR_W-1:0] s_eth_tdata,
+ input wire s_eth_tlast,
+ input wire s_eth_tvalid,
+ output wire s_eth_tready,
+ output wire [CHDR_W-1:0] m_eth_tdata,
+ output wire m_eth_tlast,
+ output wire m_eth_tvalid,
+ input wire m_eth_tready,
+ // Transport 1 (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 CHDR_W = 64;
- localparam MTU = 10;
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;
@@ -167,12 +185,12 @@ module rfnoc_image_core #(
.clk (rfnoc_chdr_clk),
.reset (rfnoc_chdr_rst),
.device_id (device_id),
- .s_axis_tdata ({ep3_to_xb_tdata, ep2_to_xb_tdata, ep1_to_xb_tdata, ep0_to_xb_tdata, s_dma_tdata, s_eth_tdata}),
- .s_axis_tlast ({ep3_to_xb_tlast, ep2_to_xb_tlast, ep1_to_xb_tlast, ep0_to_xb_tlast, s_dma_tlast, s_eth_tlast}),
+ .s_axis_tdata ({ep3_to_xb_tdata , ep2_to_xb_tdata , ep1_to_xb_tdata , ep0_to_xb_tdata , s_dma_tdata , s_eth_tdata }),
+ .s_axis_tlast ({ep3_to_xb_tlast , ep2_to_xb_tlast , ep1_to_xb_tlast , ep0_to_xb_tlast , s_dma_tlast , s_eth_tlast }),
.s_axis_tvalid ({ep3_to_xb_tvalid, ep2_to_xb_tvalid, ep1_to_xb_tvalid, ep0_to_xb_tvalid, s_dma_tvalid, s_eth_tvalid}),
.s_axis_tready ({ep3_to_xb_tready, ep2_to_xb_tready, ep1_to_xb_tready, ep0_to_xb_tready, s_dma_tready, s_eth_tready}),
- .m_axis_tdata ({xb_to_ep3_tdata, xb_to_ep2_tdata, xb_to_ep1_tdata, xb_to_ep0_tdata, m_dma_tdata, m_eth_tdata}),
- .m_axis_tlast ({xb_to_ep3_tlast, xb_to_ep2_tlast, xb_to_ep1_tlast, xb_to_ep0_tlast, m_dma_tlast, m_eth_tlast}),
+ .m_axis_tdata ({xb_to_ep3_tdata , xb_to_ep2_tdata , xb_to_ep1_tdata , xb_to_ep0_tdata , m_dma_tdata , m_eth_tdata }),
+ .m_axis_tlast ({xb_to_ep3_tlast , xb_to_ep2_tlast , xb_to_ep1_tlast , xb_to_ep0_tlast , m_dma_tlast , m_eth_tlast }),
.m_axis_tvalid ({xb_to_ep3_tvalid, xb_to_ep2_tvalid, xb_to_ep1_tvalid, xb_to_ep0_tvalid, m_dma_tvalid, m_eth_tvalid}),
.m_axis_tready ({xb_to_ep3_tready, xb_to_ep2_tready, xb_to_ep1_tready, xb_to_ep0_tready, m_dma_tready, m_eth_tready}),
.ext_rtcfg_stb (1'h0),
@@ -181,9 +199,18 @@ module rfnoc_image_core #(
.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;
+ 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;
@@ -193,8 +220,8 @@ module rfnoc_image_core #(
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 [ 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;
@@ -207,23 +234,23 @@ module rfnoc_image_core #(
.NUM_DATA_O (1),
.INST_NUM (0),
.CTRL_XBAR_PORT (1),
- .INGRESS_BUFF_SIZE (15),
+ .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 ),
+ .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}),
@@ -232,20 +259,28 @@ module rfnoc_image_core #(
.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_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_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 )
+ .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;
+ 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;
@@ -254,8 +289,8 @@ module rfnoc_image_core #(
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 [ 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;
@@ -268,23 +303,23 @@ module rfnoc_image_core #(
.NUM_DATA_O (1),
.INST_NUM (1),
.CTRL_XBAR_PORT (2),
- .INGRESS_BUFF_SIZE (15),
+ .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 ),
+ .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}),
@@ -293,20 +328,28 @@ module rfnoc_image_core #(
.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_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_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 )
+ .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 = 8192;
+ 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;
@@ -315,8 +358,8 @@ module rfnoc_image_core #(
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 [ 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;
@@ -329,23 +372,23 @@ module rfnoc_image_core #(
.NUM_DATA_O (1),
.INST_NUM (2),
.CTRL_XBAR_PORT (3),
- .INGRESS_BUFF_SIZE (13),
+ .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 ),
+ .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}),
@@ -354,20 +397,28 @@ module rfnoc_image_core #(
.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_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_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 )
+ .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 = 8192;
+ 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;
@@ -376,8 +427,8 @@ module rfnoc_image_core #(
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 [ 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;
@@ -390,23 +441,23 @@ module rfnoc_image_core #(
.NUM_DATA_O (1),
.INST_NUM (3),
.CTRL_XBAR_PORT (4),
- .INGRESS_BUFF_SIZE (13),
+ .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 ),
+ .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}),
@@ -415,46 +466,45 @@ module rfnoc_image_core #(
.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_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_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 )
+ .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_duc0_ctrl_tdata , s_duc0_ctrl_tdata ;
- wire m_duc0_ctrl_tlast , s_duc0_ctrl_tlast ;
- wire m_duc0_ctrl_tvalid, s_duc0_ctrl_tvalid;
- wire m_duc0_ctrl_tready, s_duc0_ctrl_tready;
- wire [31:0] m_ddc0_ctrl_tdata , s_ddc0_ctrl_tdata ;
- wire m_ddc0_ctrl_tlast , s_ddc0_ctrl_tlast ;
- wire m_ddc0_ctrl_tvalid, s_ddc0_ctrl_tvalid;
- wire m_ddc0_ctrl_tready, s_ddc0_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_fifo0_ctrl_tdata , s_fifo0_ctrl_tdata ;
- wire m_fifo0_ctrl_tlast , s_fifo0_ctrl_tlast ;
- wire m_fifo0_ctrl_tvalid, s_fifo0_ctrl_tvalid;
- wire m_fifo0_ctrl_tready, s_fifo0_ctrl_tready;
+ //---------------------------------------------------------------------------
+
+ 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_duc0_ctrl_tdata, s_duc0_ctrl_tdata;
+ wire m_duc0_ctrl_tlast, s_duc0_ctrl_tlast;
+ wire m_duc0_ctrl_tvalid, s_duc0_ctrl_tvalid;
+ wire m_duc0_ctrl_tready, s_duc0_ctrl_tready;
+ wire [31:0] m_ddc0_ctrl_tdata, s_ddc0_ctrl_tdata;
+ wire m_ddc0_ctrl_tlast, s_ddc0_ctrl_tlast;
+ wire m_ddc0_ctrl_tvalid, s_ddc0_ctrl_tvalid;
+ wire m_ddc0_ctrl_tready, s_ddc0_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_fifo0_ctrl_tdata, s_fifo0_ctrl_tdata;
+ wire m_fifo0_ctrl_tlast, s_fifo0_ctrl_tlast;
+ wire m_fifo0_ctrl_tvalid, s_fifo0_ctrl_tvalid;
+ wire m_fifo0_ctrl_tready, s_fifo0_ctrl_tready;
axis_ctrl_crossbar_nxn #(
.WIDTH (32),
@@ -478,9 +528,11 @@ module rfnoc_image_core #(
.deadlock_detected()
);
- // ----------------------------------------------------
+
+ //---------------------------------------------------------------------------
// RFNoC Core Kernel
- // ----------------------------------------------------
+ //---------------------------------------------------------------------------
+
wire [(512*4)-1:0] rfnoc_core_config, rfnoc_core_status;
rfnoc_core_kernel #(
@@ -505,12 +557,12 @@ module rfnoc_image_core #(
.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_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_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),
@@ -518,13 +570,15 @@ module rfnoc_image_core #(
.rfnoc_core_status (rfnoc_core_status)
);
- // ----------------------------------------------------
+
+ //---------------------------------------------------------------------------
// Blocks
- // ----------------------------------------------------
+ //---------------------------------------------------------------------------
- // ----------------------------------------------------
+ //-----------------------------------
// duc0
- // ----------------------------------------------------
+ //-----------------------------------
+
wire duc0_ce_clk;
wire [CHDR_W-1:0] s_duc0_in_1_tdata , s_duc0_in_0_tdata ;
wire s_duc0_in_1_tlast , s_duc0_in_0_tlast ;
@@ -535,44 +589,41 @@ module rfnoc_image_core #(
wire m_duc0_out_1_tvalid, m_duc0_out_0_tvalid;
wire m_duc0_out_1_tready, m_duc0_out_0_tready;
-
rfnoc_block_duc #(
- .THIS_PORTID(2),
- .CHDR_W(CHDR_W),
- .NUM_PORTS(2),
- .NUM_HB(3),
- .CIC_MAX_INTERP(255),
- .MTU(MTU)
+ .THIS_PORTID (2),
+ .CHDR_W (CHDR_W),
+ .NUM_PORTS (2),
+ .NUM_HB (3),
+ .CIC_MAX_INTERP (255),
+ .MTU (MTU)
) b_duc0_0 (
- .rfnoc_chdr_clk (rfnoc_chdr_clk),
- .rfnoc_ctrl_clk (rfnoc_ctrl_clk),
- .ce_clk(duc0_ce_clk),
- .rfnoc_core_config (rfnoc_core_config[512*1-1:512*0]),
- .rfnoc_core_status (rfnoc_core_status[512*1-1:512*0]),
-
-
- .s_rfnoc_chdr_tdata ({s_duc0_in_1_tdata , s_duc0_in_0_tdata }),
- .s_rfnoc_chdr_tlast ({s_duc0_in_1_tlast , s_duc0_in_0_tlast }),
- .s_rfnoc_chdr_tvalid({s_duc0_in_1_tvalid, s_duc0_in_0_tvalid}),
- .s_rfnoc_chdr_tready({s_duc0_in_1_tready, s_duc0_in_0_tready}),
- .m_rfnoc_chdr_tdata ({m_duc0_out_1_tdata , m_duc0_out_0_tdata }),
- .m_rfnoc_chdr_tlast ({m_duc0_out_1_tlast , m_duc0_out_0_tlast }),
- .m_rfnoc_chdr_tvalid({m_duc0_out_1_tvalid, m_duc0_out_0_tvalid}),
- .m_rfnoc_chdr_tready({m_duc0_out_1_tready, m_duc0_out_0_tready}),
- .s_rfnoc_ctrl_tdata (s_duc0_ctrl_tdata ),
- .s_rfnoc_ctrl_tlast (s_duc0_ctrl_tlast ),
- .s_rfnoc_ctrl_tvalid(s_duc0_ctrl_tvalid),
- .s_rfnoc_ctrl_tready(s_duc0_ctrl_tready),
- .m_rfnoc_ctrl_tdata (m_duc0_ctrl_tdata ),
- .m_rfnoc_ctrl_tlast (m_duc0_ctrl_tlast ),
- .m_rfnoc_ctrl_tvalid(m_duc0_ctrl_tvalid),
- .m_rfnoc_ctrl_tready(m_duc0_ctrl_tready)
+ .rfnoc_chdr_clk (rfnoc_chdr_clk),
+ .rfnoc_ctrl_clk (rfnoc_ctrl_clk),
+ .ce_clk (duc0_ce_clk),
+ .rfnoc_core_config (rfnoc_core_config[512*1-1:512*0]),
+ .rfnoc_core_status (rfnoc_core_status[512*1-1:512*0]),
+ .s_rfnoc_chdr_tdata ({s_duc0_in_1_tdata , s_duc0_in_0_tdata }),
+ .s_rfnoc_chdr_tlast ({s_duc0_in_1_tlast , s_duc0_in_0_tlast }),
+ .s_rfnoc_chdr_tvalid ({s_duc0_in_1_tvalid, s_duc0_in_0_tvalid}),
+ .s_rfnoc_chdr_tready ({s_duc0_in_1_tready, s_duc0_in_0_tready}),
+ .m_rfnoc_chdr_tdata ({m_duc0_out_1_tdata , m_duc0_out_0_tdata }),
+ .m_rfnoc_chdr_tlast ({m_duc0_out_1_tlast , m_duc0_out_0_tlast }),
+ .m_rfnoc_chdr_tvalid ({m_duc0_out_1_tvalid, m_duc0_out_0_tvalid}),
+ .m_rfnoc_chdr_tready ({m_duc0_out_1_tready, m_duc0_out_0_tready}),
+ .s_rfnoc_ctrl_tdata (s_duc0_ctrl_tdata),
+ .s_rfnoc_ctrl_tlast (s_duc0_ctrl_tlast),
+ .s_rfnoc_ctrl_tvalid (s_duc0_ctrl_tvalid),
+ .s_rfnoc_ctrl_tready (s_duc0_ctrl_tready),
+ .m_rfnoc_ctrl_tdata (m_duc0_ctrl_tdata),
+ .m_rfnoc_ctrl_tlast (m_duc0_ctrl_tlast),
+ .m_rfnoc_ctrl_tvalid (m_duc0_ctrl_tvalid),
+ .m_rfnoc_ctrl_tready (m_duc0_ctrl_tready)
);
-
- // ----------------------------------------------------
+ //-----------------------------------
// ddc0
- // ----------------------------------------------------
+ //-----------------------------------
+
wire ddc0_ce_clk;
wire [CHDR_W-1:0] s_ddc0_in_1_tdata , s_ddc0_in_0_tdata ;
wire s_ddc0_in_1_tlast , s_ddc0_in_0_tlast ;
@@ -583,44 +634,41 @@ module rfnoc_image_core #(
wire m_ddc0_out_1_tvalid, m_ddc0_out_0_tvalid;
wire m_ddc0_out_1_tready, m_ddc0_out_0_tready;
-
rfnoc_block_ddc #(
- .THIS_PORTID(3),
- .CHDR_W(CHDR_W),
- .NUM_PORTS(2),
- .NUM_HB(3),
- .CIC_MAX_DECIM(255),
- .MTU(MTU)
+ .THIS_PORTID (3),
+ .CHDR_W (CHDR_W),
+ .NUM_PORTS (2),
+ .NUM_HB (3),
+ .CIC_MAX_DECIM (255),
+ .MTU (MTU)
) b_ddc0_1 (
- .rfnoc_chdr_clk (rfnoc_chdr_clk),
- .rfnoc_ctrl_clk (rfnoc_ctrl_clk),
- .ce_clk(ddc0_ce_clk),
- .rfnoc_core_config (rfnoc_core_config[512*2-1:512*1]),
- .rfnoc_core_status (rfnoc_core_status[512*2-1:512*1]),
-
-
- .s_rfnoc_chdr_tdata ({s_ddc0_in_1_tdata , s_ddc0_in_0_tdata }),
- .s_rfnoc_chdr_tlast ({s_ddc0_in_1_tlast , s_ddc0_in_0_tlast }),
- .s_rfnoc_chdr_tvalid({s_ddc0_in_1_tvalid, s_ddc0_in_0_tvalid}),
- .s_rfnoc_chdr_tready({s_ddc0_in_1_tready, s_ddc0_in_0_tready}),
- .m_rfnoc_chdr_tdata ({m_ddc0_out_1_tdata , m_ddc0_out_0_tdata }),
- .m_rfnoc_chdr_tlast ({m_ddc0_out_1_tlast , m_ddc0_out_0_tlast }),
- .m_rfnoc_chdr_tvalid({m_ddc0_out_1_tvalid, m_ddc0_out_0_tvalid}),
- .m_rfnoc_chdr_tready({m_ddc0_out_1_tready, m_ddc0_out_0_tready}),
- .s_rfnoc_ctrl_tdata (s_ddc0_ctrl_tdata ),
- .s_rfnoc_ctrl_tlast (s_ddc0_ctrl_tlast ),
- .s_rfnoc_ctrl_tvalid(s_ddc0_ctrl_tvalid),
- .s_rfnoc_ctrl_tready(s_ddc0_ctrl_tready),
- .m_rfnoc_ctrl_tdata (m_ddc0_ctrl_tdata ),
- .m_rfnoc_ctrl_tlast (m_ddc0_ctrl_tlast ),
- .m_rfnoc_ctrl_tvalid(m_ddc0_ctrl_tvalid),
- .m_rfnoc_ctrl_tready(m_ddc0_ctrl_tready)
+ .rfnoc_chdr_clk (rfnoc_chdr_clk),
+ .rfnoc_ctrl_clk (rfnoc_ctrl_clk),
+ .ce_clk (ddc0_ce_clk),
+ .rfnoc_core_config (rfnoc_core_config[512*2-1:512*1]),
+ .rfnoc_core_status (rfnoc_core_status[512*2-1:512*1]),
+ .s_rfnoc_chdr_tdata ({s_ddc0_in_1_tdata , s_ddc0_in_0_tdata }),
+ .s_rfnoc_chdr_tlast ({s_ddc0_in_1_tlast , s_ddc0_in_0_tlast }),
+ .s_rfnoc_chdr_tvalid ({s_ddc0_in_1_tvalid, s_ddc0_in_0_tvalid}),
+ .s_rfnoc_chdr_tready ({s_ddc0_in_1_tready, s_ddc0_in_0_tready}),
+ .m_rfnoc_chdr_tdata ({m_ddc0_out_1_tdata , m_ddc0_out_0_tdata }),
+ .m_rfnoc_chdr_tlast ({m_ddc0_out_1_tlast , m_ddc0_out_0_tlast }),
+ .m_rfnoc_chdr_tvalid ({m_ddc0_out_1_tvalid, m_ddc0_out_0_tvalid}),
+ .m_rfnoc_chdr_tready ({m_ddc0_out_1_tready, m_ddc0_out_0_tready}),
+ .s_rfnoc_ctrl_tdata (s_ddc0_ctrl_tdata),
+ .s_rfnoc_ctrl_tlast (s_ddc0_ctrl_tlast),
+ .s_rfnoc_ctrl_tvalid (s_ddc0_ctrl_tvalid),
+ .s_rfnoc_ctrl_tready (s_ddc0_ctrl_tready),
+ .m_rfnoc_ctrl_tdata (m_ddc0_ctrl_tdata),
+ .m_rfnoc_ctrl_tlast (m_ddc0_ctrl_tlast),
+ .m_rfnoc_ctrl_tvalid (m_ddc0_ctrl_tvalid),
+ .m_rfnoc_ctrl_tready (m_ddc0_ctrl_tready)
);
-
- // ----------------------------------------------------
+ //-----------------------------------
// 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 ;
@@ -631,79 +679,77 @@ module rfnoc_image_core #(
wire m_radio0_out_1_tvalid, m_radio0_out_0_tvalid;
wire m_radio0_out_1_tready, m_radio0_out_0_tready;
- // ctrl_port
- wire [ 1-1:0] radio0_m_ctrlport_req_wr;
- wire [ 1-1:0] radio0_m_ctrlport_req_rd;
- wire [ 20-1:0] radio0_m_ctrlport_req_addr;
- wire [ 32-1:0] radio0_m_ctrlport_req_data;
- wire [ 4-1:0] radio0_m_ctrlport_req_byte_en;
- wire [ 1-1:0] radio0_m_ctrlport_req_has_time;
- wire [ 64-1:0] radio0_m_ctrlport_req_time;
- wire [ 1-1:0] radio0_m_ctrlport_resp_ack;
- wire [ 2-1:0] radio0_m_ctrlport_resp_status;
- wire [ 32-1:0] radio0_m_ctrlport_resp_data;
- // time_keeper
- wire [ 64-1:0] radio0_radio_time;
- // x300_radio
- wire [ 64-1:0] radio0_radio_rx_data;
- wire [ 2-1:0] radio0_radio_rx_stb;
- wire [ 2-1:0] radio0_radio_rx_running;
- wire [ 64-1:0] radio0_radio_tx_data;
- wire [ 2-1:0] radio0_radio_tx_stb;
- wire [ 2-1:0] radio0_radio_tx_running;
+ // ctrl_port
+ 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_keeper
+ wire [ 63:0] radio0_radio_time;
+ // x300_radio
+ wire [ 63:0] radio0_radio_rx_data;
+ wire [ 1:0] radio0_radio_rx_stb;
+ wire [ 1:0] radio0_radio_rx_running;
+ wire [ 63:0] radio0_radio_tx_data;
+ wire [ 1:0] radio0_radio_tx_stb;
+ wire [ 1:0] radio0_radio_tx_running;
rfnoc_block_radio #(
- .THIS_PORTID(4),
- .CHDR_W(CHDR_W),
- .NUM_PORTS(2),
- .MTU(MTU)
+ .THIS_PORTID (4),
+ .CHDR_W (CHDR_W),
+ .NUM_PORTS (2),
+ .MTU (MTU)
) b_radio0_2 (
- .rfnoc_chdr_clk (rfnoc_chdr_clk),
- .rfnoc_ctrl_clk (rfnoc_ctrl_clk),
- .radio_clk(radio0_radio_clk),
- .rfnoc_core_config (rfnoc_core_config[512*3-1:512*2]),
- .rfnoc_core_status (rfnoc_core_status[512*3-1:512*2]),
-
- .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),
+ .rfnoc_chdr_clk (rfnoc_chdr_clk),
+ .rfnoc_ctrl_clk (rfnoc_ctrl_clk),
+ .radio_clk (radio0_radio_clk),
+ .rfnoc_core_config (rfnoc_core_config[512*3-1:512*2]),
+ .rfnoc_core_status (rfnoc_core_status[512*3-1:512*2]),
+ .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_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)
+ .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)
);
-
- // ----------------------------------------------------
+ //-----------------------------------
// fifo0
- // ----------------------------------------------------
+ //-----------------------------------
+
wire fifo0_mem_clk;
wire [CHDR_W-1:0] s_fifo0_in_1_tdata , s_fifo0_in_0_tdata ;
wire s_fifo0_in_1_tlast , s_fifo0_in_0_tlast ;
@@ -714,215 +760,217 @@ module rfnoc_image_core #(
wire m_fifo0_out_1_tvalid, m_fifo0_out_0_tvalid;
wire m_fifo0_out_1_tready, m_fifo0_out_0_tready;
- // axi_ram
- wire [ 1-1:0] fifo0_axi_rst;
- wire [ 2-1:0] fifo0_m_axi_awid;
- wire [ 64-1:0] fifo0_m_axi_awaddr;
- wire [ 16-1:0] fifo0_m_axi_awlen;
- wire [ 6-1:0] fifo0_m_axi_awsize;
- wire [ 4-1:0] fifo0_m_axi_awburst;
- wire [ 2-1:0] fifo0_m_axi_awlock;
- wire [ 8-1:0] fifo0_m_axi_awcache;
- wire [ 6-1:0] fifo0_m_axi_awprot;
- wire [ 8-1:0] fifo0_m_axi_awqos;
- wire [ 8-1:0] fifo0_m_axi_awregion;
- wire [ 2-1:0] fifo0_m_axi_awuser;
- wire [ 2-1:0] fifo0_m_axi_awvalid;
- wire [ 2-1:0] fifo0_m_axi_awready;
- wire [128-1:0] fifo0_m_axi_wdata;
- wire [ 16-1:0] fifo0_m_axi_wstrb;
- wire [ 2-1:0] fifo0_m_axi_wlast;
- wire [ 2-1:0] fifo0_m_axi_wuser;
- wire [ 2-1:0] fifo0_m_axi_wvalid;
- wire [ 2-1:0] fifo0_m_axi_wready;
- wire [ 2-1:0] fifo0_m_axi_bid;
- wire [ 4-1:0] fifo0_m_axi_bresp;
- wire [ 2-1:0] fifo0_m_axi_buser;
- wire [ 2-1:0] fifo0_m_axi_bvalid;
- wire [ 2-1:0] fifo0_m_axi_bready;
- wire [ 2-1:0] fifo0_m_axi_arid;
- wire [ 64-1:0] fifo0_m_axi_araddr;
- wire [ 16-1:0] fifo0_m_axi_arlen;
- wire [ 6-1:0] fifo0_m_axi_arsize;
- wire [ 4-1:0] fifo0_m_axi_arburst;
- wire [ 2-1:0] fifo0_m_axi_arlock;
- wire [ 8-1:0] fifo0_m_axi_arcache;
- wire [ 6-1:0] fifo0_m_axi_arprot;
- wire [ 8-1:0] fifo0_m_axi_arqos;
- wire [ 8-1:0] fifo0_m_axi_arregion;
- wire [ 2-1:0] fifo0_m_axi_aruser;
- wire [ 2-1:0] fifo0_m_axi_arvalid;
- wire [ 2-1:0] fifo0_m_axi_arready;
- wire [ 2-1:0] fifo0_m_axi_rid;
- wire [128-1:0] fifo0_m_axi_rdata;
- wire [ 4-1:0] fifo0_m_axi_rresp;
- wire [ 2-1:0] fifo0_m_axi_rlast;
- wire [ 2-1:0] fifo0_m_axi_ruser;
- wire [ 2-1:0] fifo0_m_axi_rvalid;
- wire [ 2-1:0] fifo0_m_axi_rready;
+ // axi_ram
+ wire [ 0:0] fifo0_axi_rst;
+ wire [ 3:0] fifo0_m_axi_awid;
+ wire [ 127:0] fifo0_m_axi_awaddr;
+ wire [ 31:0] fifo0_m_axi_awlen;
+ wire [ 11:0] fifo0_m_axi_awsize;
+ wire [ 7:0] fifo0_m_axi_awburst;
+ wire [ 3:0] fifo0_m_axi_awlock;
+ wire [ 15:0] fifo0_m_axi_awcache;
+ wire [ 11:0] fifo0_m_axi_awprot;
+ wire [ 15:0] fifo0_m_axi_awqos;
+ wire [ 15:0] fifo0_m_axi_awregion;
+ wire [ 3:0] fifo0_m_axi_awuser;
+ wire [ 3:0] fifo0_m_axi_awvalid;
+ wire [ 3:0] fifo0_m_axi_awready;
+ wire [ 255:0] fifo0_m_axi_wdata;
+ wire [ 31:0] fifo0_m_axi_wstrb;
+ wire [ 3:0] fifo0_m_axi_wlast;
+ wire [ 3:0] fifo0_m_axi_wuser;
+ wire [ 3:0] fifo0_m_axi_wvalid;
+ wire [ 3:0] fifo0_m_axi_wready;
+ wire [ 3:0] fifo0_m_axi_bid;
+ wire [ 7:0] fifo0_m_axi_bresp;
+ wire [ 3:0] fifo0_m_axi_buser;
+ wire [ 3:0] fifo0_m_axi_bvalid;
+ wire [ 3:0] fifo0_m_axi_bready;
+ wire [ 3:0] fifo0_m_axi_arid;
+ wire [ 127:0] fifo0_m_axi_araddr;
+ wire [ 31:0] fifo0_m_axi_arlen;
+ wire [ 11:0] fifo0_m_axi_arsize;
+ wire [ 7:0] fifo0_m_axi_arburst;
+ wire [ 3:0] fifo0_m_axi_arlock;
+ wire [ 15:0] fifo0_m_axi_arcache;
+ wire [ 11:0] fifo0_m_axi_arprot;
+ wire [ 15:0] fifo0_m_axi_arqos;
+ wire [ 15:0] fifo0_m_axi_arregion;
+ wire [ 3:0] fifo0_m_axi_aruser;
+ wire [ 3:0] fifo0_m_axi_arvalid;
+ wire [ 3:0] fifo0_m_axi_arready;
+ wire [ 3:0] fifo0_m_axi_rid;
+ wire [ 255:0] fifo0_m_axi_rdata;
+ wire [ 7:0] fifo0_m_axi_rresp;
+ wire [ 3:0] fifo0_m_axi_rlast;
+ wire [ 3:0] fifo0_m_axi_ruser;
+ wire [ 3:0] fifo0_m_axi_rvalid;
+ wire [ 3:0] fifo0_m_axi_rready;
rfnoc_block_axi_ram_fifo #(
- .THIS_PORTID(5),
- .CHDR_W(CHDR_W),
- .MEM_ADDR_W(31),
- .MEM_DATA_W(64),
- .MEM_CLK_RATE(300e6),
- .FIFO_ADDR_BASE({31'h02000000, 31'h00000000}),
- .FIFO_ADDR_MASK({31'h01FFFFFF, 31'h01FFFFFF}),
- .NUM_PORTS(2),
- .MTU(MTU)
+ .THIS_PORTID (5),
+ .CHDR_W (CHDR_W),
+ .MEM_ADDR_W (31),
+ .MEM_DATA_W (64),
+ .MEM_CLK_RATE (300e6),
+ .FIFO_ADDR_BASE ({31'h02000000, 31'h00000000}),
+ .FIFO_ADDR_MASK ({31'h01FFFFFF, 31'h01FFFFFF}),
+ .NUM_PORTS (2),
+ .MTU (MTU)
) b_fifo0_3 (
- .rfnoc_chdr_clk (rfnoc_chdr_clk),
- .rfnoc_ctrl_clk (rfnoc_ctrl_clk),
- .mem_clk(fifo0_mem_clk),
- .rfnoc_core_config (rfnoc_core_config[512*4-1:512*3]),
- .rfnoc_core_status (rfnoc_core_status[512*4-1:512*3]),
-
- .axi_rst(fifo0_axi_rst),
- .m_axi_awid(fifo0_m_axi_awid),
- .m_axi_awaddr(fifo0_m_axi_awaddr),
- .m_axi_awlen(fifo0_m_axi_awlen),
- .m_axi_awsize(fifo0_m_axi_awsize),
- .m_axi_awburst(fifo0_m_axi_awburst),
- .m_axi_awlock(fifo0_m_axi_awlock),
- .m_axi_awcache(fifo0_m_axi_awcache),
- .m_axi_awprot(fifo0_m_axi_awprot),
- .m_axi_awqos(fifo0_m_axi_awqos),
- .m_axi_awregion(fifo0_m_axi_awregion),
- .m_axi_awuser(fifo0_m_axi_awuser),
- .m_axi_awvalid(fifo0_m_axi_awvalid),
- .m_axi_awready(fifo0_m_axi_awready),
- .m_axi_wdata(fifo0_m_axi_wdata),
- .m_axi_wstrb(fifo0_m_axi_wstrb),
- .m_axi_wlast(fifo0_m_axi_wlast),
- .m_axi_wuser(fifo0_m_axi_wuser),
- .m_axi_wvalid(fifo0_m_axi_wvalid),
- .m_axi_wready(fifo0_m_axi_wready),
- .m_axi_bid(fifo0_m_axi_bid),
- .m_axi_bresp(fifo0_m_axi_bresp),
- .m_axi_buser(fifo0_m_axi_buser),
- .m_axi_bvalid(fifo0_m_axi_bvalid),
- .m_axi_bready(fifo0_m_axi_bready),
- .m_axi_arid(fifo0_m_axi_arid),
- .m_axi_araddr(fifo0_m_axi_araddr),
- .m_axi_arlen(fifo0_m_axi_arlen),
- .m_axi_arsize(fifo0_m_axi_arsize),
- .m_axi_arburst(fifo0_m_axi_arburst),
- .m_axi_arlock(fifo0_m_axi_arlock),
- .m_axi_arcache(fifo0_m_axi_arcache),
- .m_axi_arprot(fifo0_m_axi_arprot),
- .m_axi_arqos(fifo0_m_axi_arqos),
- .m_axi_arregion(fifo0_m_axi_arregion),
- .m_axi_aruser(fifo0_m_axi_aruser),
- .m_axi_arvalid(fifo0_m_axi_arvalid),
- .m_axi_arready(fifo0_m_axi_arready),
- .m_axi_rid(fifo0_m_axi_rid),
- .m_axi_rdata(fifo0_m_axi_rdata),
- .m_axi_rresp(fifo0_m_axi_rresp),
- .m_axi_rlast(fifo0_m_axi_rlast),
- .m_axi_ruser(fifo0_m_axi_ruser),
- .m_axi_rvalid(fifo0_m_axi_rvalid),
- .m_axi_rready(fifo0_m_axi_rready),
-
- .s_rfnoc_chdr_tdata ({s_fifo0_in_1_tdata , s_fifo0_in_0_tdata }),
- .s_rfnoc_chdr_tlast ({s_fifo0_in_1_tlast , s_fifo0_in_0_tlast }),
- .s_rfnoc_chdr_tvalid({s_fifo0_in_1_tvalid, s_fifo0_in_0_tvalid}),
- .s_rfnoc_chdr_tready({s_fifo0_in_1_tready, s_fifo0_in_0_tready}),
- .m_rfnoc_chdr_tdata ({m_fifo0_out_1_tdata , m_fifo0_out_0_tdata }),
- .m_rfnoc_chdr_tlast ({m_fifo0_out_1_tlast , m_fifo0_out_0_tlast }),
- .m_rfnoc_chdr_tvalid({m_fifo0_out_1_tvalid, m_fifo0_out_0_tvalid}),
- .m_rfnoc_chdr_tready({m_fifo0_out_1_tready, m_fifo0_out_0_tready}),
- .s_rfnoc_ctrl_tdata (s_fifo0_ctrl_tdata ),
- .s_rfnoc_ctrl_tlast (s_fifo0_ctrl_tlast ),
- .s_rfnoc_ctrl_tvalid(s_fifo0_ctrl_tvalid),
- .s_rfnoc_ctrl_tready(s_fifo0_ctrl_tready),
- .m_rfnoc_ctrl_tdata (m_fifo0_ctrl_tdata ),
- .m_rfnoc_ctrl_tlast (m_fifo0_ctrl_tlast ),
- .m_rfnoc_ctrl_tvalid(m_fifo0_ctrl_tvalid),
- .m_rfnoc_ctrl_tready(m_fifo0_ctrl_tready)
+ .rfnoc_chdr_clk (rfnoc_chdr_clk),
+ .rfnoc_ctrl_clk (rfnoc_ctrl_clk),
+ .mem_clk (fifo0_mem_clk),
+ .rfnoc_core_config (rfnoc_core_config[512*4-1:512*3]),
+ .rfnoc_core_status (rfnoc_core_status[512*4-1:512*3]),
+ .axi_rst (fifo0_axi_rst),
+ .m_axi_awid (fifo0_m_axi_awid),
+ .m_axi_awaddr (fifo0_m_axi_awaddr),
+ .m_axi_awlen (fifo0_m_axi_awlen),
+ .m_axi_awsize (fifo0_m_axi_awsize),
+ .m_axi_awburst (fifo0_m_axi_awburst),
+ .m_axi_awlock (fifo0_m_axi_awlock),
+ .m_axi_awcache (fifo0_m_axi_awcache),
+ .m_axi_awprot (fifo0_m_axi_awprot),
+ .m_axi_awqos (fifo0_m_axi_awqos),
+ .m_axi_awregion (fifo0_m_axi_awregion),
+ .m_axi_awuser (fifo0_m_axi_awuser),
+ .m_axi_awvalid (fifo0_m_axi_awvalid),
+ .m_axi_awready (fifo0_m_axi_awready),
+ .m_axi_wdata (fifo0_m_axi_wdata),
+ .m_axi_wstrb (fifo0_m_axi_wstrb),
+ .m_axi_wlast (fifo0_m_axi_wlast),
+ .m_axi_wuser (fifo0_m_axi_wuser),
+ .m_axi_wvalid (fifo0_m_axi_wvalid),
+ .m_axi_wready (fifo0_m_axi_wready),
+ .m_axi_bid (fifo0_m_axi_bid),
+ .m_axi_bresp (fifo0_m_axi_bresp),
+ .m_axi_buser (fifo0_m_axi_buser),
+ .m_axi_bvalid (fifo0_m_axi_bvalid),
+ .m_axi_bready (fifo0_m_axi_bready),
+ .m_axi_arid (fifo0_m_axi_arid),
+ .m_axi_araddr (fifo0_m_axi_araddr),
+ .m_axi_arlen (fifo0_m_axi_arlen),
+ .m_axi_arsize (fifo0_m_axi_arsize),
+ .m_axi_arburst (fifo0_m_axi_arburst),
+ .m_axi_arlock (fifo0_m_axi_arlock),
+ .m_axi_arcache (fifo0_m_axi_arcache),
+ .m_axi_arprot (fifo0_m_axi_arprot),
+ .m_axi_arqos (fifo0_m_axi_arqos),
+ .m_axi_arregion (fifo0_m_axi_arregion),
+ .m_axi_aruser (fifo0_m_axi_aruser),
+ .m_axi_arvalid (fifo0_m_axi_arvalid),
+ .m_axi_arready (fifo0_m_axi_arready),
+ .m_axi_rid (fifo0_m_axi_rid),
+ .m_axi_rdata (fifo0_m_axi_rdata),
+ .m_axi_rresp (fifo0_m_axi_rresp),
+ .m_axi_rlast (fifo0_m_axi_rlast),
+ .m_axi_ruser (fifo0_m_axi_ruser),
+ .m_axi_rvalid (fifo0_m_axi_rvalid),
+ .m_axi_rready (fifo0_m_axi_rready),
+ .s_rfnoc_chdr_tdata ({s_fifo0_in_1_tdata , s_fifo0_in_0_tdata }),
+ .s_rfnoc_chdr_tlast ({s_fifo0_in_1_tlast , s_fifo0_in_0_tlast }),
+ .s_rfnoc_chdr_tvalid ({s_fifo0_in_1_tvalid, s_fifo0_in_0_tvalid}),
+ .s_rfnoc_chdr_tready ({s_fifo0_in_1_tready, s_fifo0_in_0_tready}),
+ .m_rfnoc_chdr_tdata ({m_fifo0_out_1_tdata , m_fifo0_out_0_tdata }),
+ .m_rfnoc_chdr_tlast ({m_fifo0_out_1_tlast , m_fifo0_out_0_tlast }),
+ .m_rfnoc_chdr_tvalid ({m_fifo0_out_1_tvalid, m_fifo0_out_0_tvalid}),
+ .m_rfnoc_chdr_tready ({m_fifo0_out_1_tready, m_fifo0_out_0_tready}),
+ .s_rfnoc_ctrl_tdata (s_fifo0_ctrl_tdata),
+ .s_rfnoc_ctrl_tlast (s_fifo0_ctrl_tlast),
+ .s_rfnoc_ctrl_tvalid (s_fifo0_ctrl_tvalid),
+ .s_rfnoc_ctrl_tready (s_fifo0_ctrl_tready),
+ .m_rfnoc_ctrl_tdata (m_fifo0_ctrl_tdata),
+ .m_rfnoc_ctrl_tlast (m_fifo0_ctrl_tlast),
+ .m_rfnoc_ctrl_tvalid (m_fifo0_ctrl_tvalid),
+ .m_rfnoc_ctrl_tready (m_fifo0_ctrl_tready)
);
-
- // ----------------------------------------------------
+ //---------------------------------------------------------------------------
// Static Router
- // ----------------------------------------------------
- assign s_duc0_in_0_tdata = m_ep0_out0_tdata ;
- assign s_duc0_in_0_tlast = m_ep0_out0_tlast ;
+ //---------------------------------------------------------------------------
+
+ assign s_duc0_in_0_tdata = m_ep0_out0_tdata;
+ assign s_duc0_in_0_tlast = m_ep0_out0_tlast;
assign s_duc0_in_0_tvalid = m_ep0_out0_tvalid;
assign m_ep0_out0_tready = s_duc0_in_0_tready;
- assign s_radio0_in_0_tdata = m_duc0_out_0_tdata ;
- assign s_radio0_in_0_tlast = m_duc0_out_0_tlast ;
+ assign s_radio0_in_0_tdata = m_duc0_out_0_tdata;
+ assign s_radio0_in_0_tlast = m_duc0_out_0_tlast;
assign s_radio0_in_0_tvalid = m_duc0_out_0_tvalid;
assign m_duc0_out_0_tready = s_radio0_in_0_tready;
- assign s_ddc0_in_0_tdata = m_radio0_out_0_tdata ;
- assign s_ddc0_in_0_tlast = m_radio0_out_0_tlast ;
+ assign s_ddc0_in_0_tdata = m_radio0_out_0_tdata;
+ assign s_ddc0_in_0_tlast = m_radio0_out_0_tlast;
assign s_ddc0_in_0_tvalid = m_radio0_out_0_tvalid;
assign m_radio0_out_0_tready = s_ddc0_in_0_tready;
- assign s_ep0_in0_tdata = m_ddc0_out_0_tdata ;
- assign s_ep0_in0_tlast = m_ddc0_out_0_tlast ;
+ assign s_ep0_in0_tdata = m_ddc0_out_0_tdata;
+ assign s_ep0_in0_tlast = m_ddc0_out_0_tlast;
assign s_ep0_in0_tvalid = m_ddc0_out_0_tvalid;
assign m_ddc0_out_0_tready = s_ep0_in0_tready;
- assign s_duc0_in_1_tdata = m_ep1_out0_tdata ;
- assign s_duc0_in_1_tlast = m_ep1_out0_tlast ;
+ assign s_duc0_in_1_tdata = m_ep1_out0_tdata;
+ assign s_duc0_in_1_tlast = m_ep1_out0_tlast;
assign s_duc0_in_1_tvalid = m_ep1_out0_tvalid;
assign m_ep1_out0_tready = s_duc0_in_1_tready;
- assign s_radio0_in_1_tdata = m_duc0_out_1_tdata ;
- assign s_radio0_in_1_tlast = m_duc0_out_1_tlast ;
+ assign s_radio0_in_1_tdata = m_duc0_out_1_tdata;
+ assign s_radio0_in_1_tlast = m_duc0_out_1_tlast;
assign s_radio0_in_1_tvalid = m_duc0_out_1_tvalid;
assign m_duc0_out_1_tready = s_radio0_in_1_tready;
- assign s_ddc0_in_1_tdata = m_radio0_out_1_tdata ;
- assign s_ddc0_in_1_tlast = m_radio0_out_1_tlast ;
+ assign s_ddc0_in_1_tdata = m_radio0_out_1_tdata;
+ assign s_ddc0_in_1_tlast = m_radio0_out_1_tlast;
assign s_ddc0_in_1_tvalid = m_radio0_out_1_tvalid;
assign m_radio0_out_1_tready = s_ddc0_in_1_tready;
- assign s_ep1_in0_tdata = m_ddc0_out_1_tdata ;
- assign s_ep1_in0_tlast = m_ddc0_out_1_tlast ;
+ assign s_ep1_in0_tdata = m_ddc0_out_1_tdata;
+ assign s_ep1_in0_tlast = m_ddc0_out_1_tlast;
assign s_ep1_in0_tvalid = m_ddc0_out_1_tvalid;
assign m_ddc0_out_1_tready = s_ep1_in0_tready;
- assign s_fifo0_in_0_tdata = m_ep2_out0_tdata ;
- assign s_fifo0_in_0_tlast = m_ep2_out0_tlast ;
+ assign s_fifo0_in_0_tdata = m_ep2_out0_tdata;
+ assign s_fifo0_in_0_tlast = m_ep2_out0_tlast;
assign s_fifo0_in_0_tvalid = m_ep2_out0_tvalid;
assign m_ep2_out0_tready = s_fifo0_in_0_tready;
- assign s_ep2_in0_tdata = m_fifo0_out_0_tdata ;
- assign s_ep2_in0_tlast = m_fifo0_out_0_tlast ;
+ assign s_ep2_in0_tdata = m_fifo0_out_0_tdata;
+ assign s_ep2_in0_tlast = m_fifo0_out_0_tlast;
assign s_ep2_in0_tvalid = m_fifo0_out_0_tvalid;
assign m_fifo0_out_0_tready = s_ep2_in0_tready;
- assign s_fifo0_in_1_tdata = m_ep3_out0_tdata ;
- assign s_fifo0_in_1_tlast = m_ep3_out0_tlast ;
+ assign s_fifo0_in_1_tdata = m_ep3_out0_tdata;
+ assign s_fifo0_in_1_tlast = m_ep3_out0_tlast;
assign s_fifo0_in_1_tvalid = m_ep3_out0_tvalid;
assign m_ep3_out0_tready = s_fifo0_in_1_tready;
- assign s_ep3_in0_tdata = m_fifo0_out_1_tdata ;
- assign s_ep3_in0_tlast = m_fifo0_out_1_tlast ;
+ assign s_ep3_in0_tdata = m_fifo0_out_1_tdata;
+ assign s_ep3_in0_tlast = m_fifo0_out_1_tlast;
assign s_ep3_in0_tvalid = m_fifo0_out_1_tvalid;
assign m_fifo0_out_1_tready = s_ep3_in0_tready;
- // ----------------------------------------------------
+ //---------------------------------------------------------------------------
// Unused Ports
- // ----------------------------------------------------
+ //---------------------------------------------------------------------------
+
- // ----------------------------------------------------
+
+ //---------------------------------------------------------------------------
// Clock Domains
- // ----------------------------------------------------
+ //---------------------------------------------------------------------------
+
assign radio0_radio_clk = radio_clk;
assign duc0_ce_clk = rfnoc_chdr_clk;
assign ddc0_ce_clk = rfnoc_chdr_clk;
assign fifo0_mem_clk = dram_clk;
- // ----------------------------------------------------
+ //---------------------------------------------------------------------------
// IO Port Connection
- // ----------------------------------------------------
+ //---------------------------------------------------------------------------
+
// Master/Slave Connections:
assign m_ctrlport_req_wr = radio0_m_ctrlport_req_wr;
assign m_ctrlport_req_rd = radio0_m_ctrlport_req_rd;
@@ -992,3 +1040,6 @@ module rfnoc_image_core #(
assign radio0_radio_time = radio_time;
endmodule
+
+
+`default_nettype wire
diff --git a/fpga/usrp3/top/e320/e320_rfnoc_image_core.vh b/fpga/usrp3/top/e320/e320_rfnoc_image_core.vh
new file mode 100644
index 000000000..7e7b3f72d
--- /dev/null
+++ b/fpga/usrp3/top/e320/e320_rfnoc_image_core.vh
@@ -0,0 +1,21 @@
+//
+// Copyright 2021 Ettus Research, A National Instruments Brand
+//
+// SPDX-License-Identifier: LGPL-3.0-or-later
+//
+// Header: rfnoc_image_core.vh (for e320)
+//
+// 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: 2021-05-03T08:51:10.746455
+// Source: e320_rfnoc_image_core.yml
+// Source SHA256: 8b38ab7ba86e214c213ab62a63b698739c0858fdf10fcc5b737f87a56fb04454
+//
+
+`define CHDR_WIDTH 64
+`define RFNOC_PROTOVER { 8'd1, 8'd0 }
diff --git a/fpga/usrp3/top/n3xx/n300_bist_image_core.v b/fpga/usrp3/top/n3xx/n300_bist_image_core.v
index 31d4eeb86..77c3429dd 100644
--- a/fpga/usrp3/top/n3xx/n300_bist_image_core.v
+++ b/fpga/usrp3/top/n3xx/n300_bist_image_core.v
@@ -1,19 +1,32 @@
//
-// Copyright 2019 Ettus Research, A National Instruments Brand
+// Copyright 2021 Ettus Research, A National Instruments Brand
//
// SPDX-License-Identifier: LGPL-3.0-or-later
//
-
// Module: rfnoc_image_core (for n300)
-// This file was autogenerated by UHD's image builder tool (rfnoc_image_builder)
-// Re-running that tool will overwrite this file!
-// File generated on: 2019-11-08T15:58:13.938765
-// Source: ./n3xx/n300_bist_image_core.yml
-// Source SHA256: 3bed6bab7b614594eb5ea4e49b34a6e9560b10ff4622c1033c206bec1f4a0f2c
+//
+// 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: 2021-05-03T08:51:04.740210
+// Source: n300_bist_image_core.yml
+// Source SHA256: 209edc7c95f0a9fd8b96b6d10a40849f3ee84e5fc85a37696cc7510cd74c4af6
+//
+
+`default_nettype none
+
module rfnoc_image_core #(
- parameter [15:0] PROTOVER = {8'd1, 8'd0}
-)(
+ parameter CHDR_W = 64,
+ parameter MTU = 10,
+ parameter [15:0] PROTOVER = {8'd1, 8'd0},
+ parameter RADIO_NIPC = 1
+) (
// Clocks
input wire chdr_aclk,
input wire ctrl_aclk,
@@ -21,113 +34,118 @@ module rfnoc_image_core #(
input wire radio_clk,
input wire dram_clk,
// Basic
- input wire [15:0] device_id,
-//// IO ports //////////////////////////////////
-// ctrlport_radio0
- output wire [ 1-1:0] m_ctrlport_radio0_req_wr,
- output wire [ 1-1:0] m_ctrlport_radio0_req_rd,
- output wire [ 20-1:0] m_ctrlport_radio0_req_addr,
- output wire [ 32-1:0] m_ctrlport_radio0_req_data,
- output wire [ 4-1:0] m_ctrlport_radio0_req_byte_en,
- output wire [ 1-1:0] m_ctrlport_radio0_req_has_time,
- output wire [ 64-1:0] m_ctrlport_radio0_req_time,
- input wire [ 1-1:0] m_ctrlport_radio0_resp_ack,
- input wire [ 2-1:0] m_ctrlport_radio0_resp_status,
- input wire [ 32-1:0] m_ctrlport_radio0_resp_data,
-// time_keeper
- input wire [ 64-1:0] radio_time,
-// x300_radio0
- input wire [ 64-1:0] radio_rx_data_radio0,
- input wire [ 2-1:0] radio_rx_stb_radio0,
- output wire [ 2-1:0] radio_rx_running_radio0,
- output wire [ 64-1:0] radio_tx_data_radio0,
- input wire [ 2-1:0] radio_tx_stb_radio0,
- output wire [ 2-1:0] radio_tx_running_radio0,
-// dram
- input wire [ 1-1:0] axi_rst,
- output wire [ 4-1:0] m_axi_awid,
- output wire [128-1:0] m_axi_awaddr,
- output wire [ 32-1:0] m_axi_awlen,
- output wire [ 12-1:0] m_axi_awsize,
- output wire [ 8-1:0] m_axi_awburst,
- output wire [ 4-1:0] m_axi_awlock,
- output wire [ 16-1:0] m_axi_awcache,
- output wire [ 12-1:0] m_axi_awprot,
- output wire [ 16-1:0] m_axi_awqos,
- output wire [ 16-1:0] m_axi_awregion,
- output wire [ 4-1:0] m_axi_awuser,
- output wire [ 4-1:0] m_axi_awvalid,
- input wire [ 4-1:0] m_axi_awready,
- output wire [256-1:0] m_axi_wdata,
- output wire [ 32-1:0] m_axi_wstrb,
- output wire [ 4-1:0] m_axi_wlast,
- output wire [ 4-1:0] m_axi_wuser,
- output wire [ 4-1:0] m_axi_wvalid,
- input wire [ 4-1:0] m_axi_wready,
- input wire [ 4-1:0] m_axi_bid,
- input wire [ 8-1:0] m_axi_bresp,
- input wire [ 4-1:0] m_axi_buser,
- input wire [ 4-1:0] m_axi_bvalid,
- output wire [ 4-1:0] m_axi_bready,
- output wire [ 4-1:0] m_axi_arid,
- output wire [128-1:0] m_axi_araddr,
- output wire [ 32-1:0] m_axi_arlen,
- output wire [ 12-1:0] m_axi_arsize,
- output wire [ 8-1:0] m_axi_arburst,
- output wire [ 4-1:0] m_axi_arlock,
- output wire [ 16-1:0] m_axi_arcache,
- output wire [ 12-1:0] m_axi_arprot,
- output wire [ 16-1:0] m_axi_arqos,
- output wire [ 16-1:0] m_axi_arregion,
- output wire [ 4-1:0] m_axi_aruser,
- output wire [ 4-1:0] m_axi_arvalid,
- input wire [ 4-1:0] m_axi_arready,
- input wire [ 4-1:0] m_axi_rid,
- input wire [256-1:0] m_axi_rdata,
- input wire [ 8-1:0] m_axi_rresp,
- input wire [ 4-1:0] m_axi_rlast,
- input wire [ 4-1:0] m_axi_ruser,
- input wire [ 4-1:0] m_axi_rvalid,
- output wire [ 4-1:0] m_axi_rready,
- // Transport 0 (eth0 1G)
- input wire [64-1:0] s_eth0_tdata,
- input wire s_eth0_tlast,
- input wire s_eth0_tvalid,
- output wire s_eth0_tready,
- output wire [64-1:0] m_eth0_tdata,
- output wire m_eth0_tlast,
- output wire m_eth0_tvalid,
- input wire m_eth0_tready,
- // Transport 1 (eth1 10G)
- input wire [64-1:0] s_eth1_tdata,
- input wire s_eth1_tlast,
- input wire s_eth1_tvalid,
- output wire s_eth1_tready,
- output wire [64-1:0] m_eth1_tdata,
- output wire m_eth1_tlast,
- output wire m_eth1_tvalid,
- input wire m_eth1_tready,
- // Transport 2 (dma dma)
- input wire [64-1:0] s_dma_tdata,
- input wire s_dma_tlast,
- input wire s_dma_tvalid,
- output wire s_dma_tready,
- output wire [64-1:0] m_dma_tdata,
- output wire m_dma_tlast,
- output wire m_dma_tvalid,
- input wire m_dma_tready
+ 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,
+ // time_keeper
+ input wire [ 63:0] radio_time,
+ // x300_radio0
+ input wire [ 63:0] radio_rx_data_radio0,
+ input wire [ 1:0] radio_rx_stb_radio0,
+ output wire [ 1:0] radio_rx_running_radio0,
+ output wire [ 63:0] radio_tx_data_radio0,
+ input wire [ 1:0] radio_tx_stb_radio0,
+ output wire [ 1:0] radio_tx_running_radio0,
+ // dram
+ input wire [ 0:0] axi_rst,
+ output wire [ 3:0] m_axi_awid,
+ output wire [ 127: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 [ 255:0] m_axi_wdata,
+ output wire [ 31: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 [ 127: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 [ 255: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 (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 CHDR_W = 64;
- localparam MTU = 10;
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;
@@ -176,12 +194,12 @@ module rfnoc_image_core #(
.clk (rfnoc_chdr_clk),
.reset (rfnoc_chdr_rst),
.device_id (device_id),
- .s_axis_tdata ({ep5_to_xb_tdata, ep4_to_xb_tdata, ep1_to_xb_tdata, ep0_to_xb_tdata, s_dma_tdata, s_eth1_tdata, s_eth0_tdata}),
- .s_axis_tlast ({ep5_to_xb_tlast, ep4_to_xb_tlast, ep1_to_xb_tlast, ep0_to_xb_tlast, s_dma_tlast, s_eth1_tlast, s_eth0_tlast}),
+ .s_axis_tdata ({ep5_to_xb_tdata , ep4_to_xb_tdata , ep1_to_xb_tdata , ep0_to_xb_tdata , s_dma_tdata , s_eth1_tdata , s_eth0_tdata }),
+ .s_axis_tlast ({ep5_to_xb_tlast , ep4_to_xb_tlast , ep1_to_xb_tlast , ep0_to_xb_tlast , s_dma_tlast , s_eth1_tlast , s_eth0_tlast }),
.s_axis_tvalid ({ep5_to_xb_tvalid, ep4_to_xb_tvalid, ep1_to_xb_tvalid, ep0_to_xb_tvalid, s_dma_tvalid, s_eth1_tvalid, s_eth0_tvalid}),
.s_axis_tready ({ep5_to_xb_tready, ep4_to_xb_tready, ep1_to_xb_tready, ep0_to_xb_tready, s_dma_tready, s_eth1_tready, s_eth0_tready}),
- .m_axis_tdata ({xb_to_ep5_tdata, xb_to_ep4_tdata, xb_to_ep1_tdata, xb_to_ep0_tdata, m_dma_tdata, m_eth1_tdata, m_eth0_tdata}),
- .m_axis_tlast ({xb_to_ep5_tlast, xb_to_ep4_tlast, xb_to_ep1_tlast, xb_to_ep0_tlast, m_dma_tlast, m_eth1_tlast, m_eth0_tlast}),
+ .m_axis_tdata ({xb_to_ep5_tdata , xb_to_ep4_tdata , xb_to_ep1_tdata , xb_to_ep0_tdata , m_dma_tdata , m_eth1_tdata , m_eth0_tdata }),
+ .m_axis_tlast ({xb_to_ep5_tlast , xb_to_ep4_tlast , xb_to_ep1_tlast , xb_to_ep0_tlast , m_dma_tlast , m_eth1_tlast , m_eth0_tlast }),
.m_axis_tvalid ({xb_to_ep5_tvalid, xb_to_ep4_tvalid, xb_to_ep1_tvalid, xb_to_ep0_tvalid, m_dma_tvalid, m_eth1_tvalid, m_eth0_tvalid}),
.m_axis_tready ({xb_to_ep5_tready, xb_to_ep4_tready, xb_to_ep1_tready, xb_to_ep0_tready, m_dma_tready, m_eth1_tready, m_eth0_tready}),
.ext_rtcfg_stb (1'h0),
@@ -190,9 +208,18 @@ module rfnoc_image_core #(
.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 = 16384;
+ 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;
@@ -202,8 +229,8 @@ module rfnoc_image_core #(
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 [ 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;
@@ -216,23 +243,23 @@ module rfnoc_image_core #(
.NUM_DATA_O (1),
.INST_NUM (0),
.CTRL_XBAR_PORT (1),
- .INGRESS_BUFF_SIZE (14),
+ .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 ),
+ .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}),
@@ -241,20 +268,28 @@ module rfnoc_image_core #(
.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_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_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 )
+ .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 = 16384;
+ 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;
@@ -263,8 +298,8 @@ module rfnoc_image_core #(
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 [ 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;
@@ -277,23 +312,23 @@ module rfnoc_image_core #(
.NUM_DATA_O (1),
.INST_NUM (1),
.CTRL_XBAR_PORT (2),
- .INGRESS_BUFF_SIZE (14),
+ .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 ),
+ .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}),
@@ -302,20 +337,28 @@ module rfnoc_image_core #(
.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_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_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 )
+ .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 = 16384;
+ 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;
@@ -324,8 +367,8 @@ module rfnoc_image_core #(
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 [ 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;
@@ -338,23 +381,23 @@ module rfnoc_image_core #(
.NUM_DATA_O (1),
.INST_NUM (2),
.CTRL_XBAR_PORT (3),
- .INGRESS_BUFF_SIZE (14),
+ .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 ),
+ .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}),
@@ -363,20 +406,28 @@ module rfnoc_image_core #(
.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_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_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 )
+ .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 = 16384;
+ 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;
@@ -385,8 +436,8 @@ module rfnoc_image_core #(
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 [ 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;
@@ -399,23 +450,23 @@ module rfnoc_image_core #(
.NUM_DATA_O (1),
.INST_NUM (3),
.CTRL_XBAR_PORT (4),
- .INGRESS_BUFF_SIZE (14),
+ .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 ),
+ .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}),
@@ -424,38 +475,37 @@ module rfnoc_image_core #(
.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_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_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 )
+ .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_fifo0_ctrl_tdata , s_fifo0_ctrl_tdata ;
- wire m_fifo0_ctrl_tlast , s_fifo0_ctrl_tlast ;
- wire m_fifo0_ctrl_tvalid, s_fifo0_ctrl_tvalid;
- wire m_fifo0_ctrl_tready, s_fifo0_ctrl_tready;
+ //---------------------------------------------------------------------------
+
+ 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_fifo0_ctrl_tdata, s_fifo0_ctrl_tdata;
+ wire m_fifo0_ctrl_tlast, s_fifo0_ctrl_tlast;
+ wire m_fifo0_ctrl_tvalid, s_fifo0_ctrl_tvalid;
+ wire m_fifo0_ctrl_tready, s_fifo0_ctrl_tready;
axis_ctrl_crossbar_nxn #(
.WIDTH (32),
@@ -479,9 +529,11 @@ module rfnoc_image_core #(
.deadlock_detected()
);
- // ----------------------------------------------------
+
+ //---------------------------------------------------------------------------
// RFNoC Core Kernel
- // ----------------------------------------------------
+ //---------------------------------------------------------------------------
+
wire [(512*2)-1:0] rfnoc_core_config, rfnoc_core_status;
rfnoc_core_kernel #(
@@ -506,12 +558,12 @@ module rfnoc_image_core #(
.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_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_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),
@@ -519,13 +571,15 @@ module rfnoc_image_core #(
.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 ;
@@ -536,79 +590,77 @@ module rfnoc_image_core #(
wire m_radio0_out_1_tvalid, m_radio0_out_0_tvalid;
wire m_radio0_out_1_tready, m_radio0_out_0_tready;
- // ctrl_port
- wire [ 1-1:0] radio0_m_ctrlport_req_wr;
- wire [ 1-1:0] radio0_m_ctrlport_req_rd;
- wire [ 20-1:0] radio0_m_ctrlport_req_addr;
- wire [ 32-1:0] radio0_m_ctrlport_req_data;
- wire [ 4-1:0] radio0_m_ctrlport_req_byte_en;
- wire [ 1-1:0] radio0_m_ctrlport_req_has_time;
- wire [ 64-1:0] radio0_m_ctrlport_req_time;
- wire [ 1-1:0] radio0_m_ctrlport_resp_ack;
- wire [ 2-1:0] radio0_m_ctrlport_resp_status;
- wire [ 32-1:0] radio0_m_ctrlport_resp_data;
- // time_keeper
- wire [ 64-1:0] radio0_radio_time;
- // x300_radio
- wire [ 64-1:0] radio0_radio_rx_data;
- wire [ 2-1:0] radio0_radio_rx_stb;
- wire [ 2-1:0] radio0_radio_rx_running;
- wire [ 64-1:0] radio0_radio_tx_data;
- wire [ 2-1:0] radio0_radio_tx_stb;
- wire [ 2-1:0] radio0_radio_tx_running;
+ // ctrl_port
+ 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_keeper
+ wire [ 63:0] radio0_radio_time;
+ // x300_radio
+ wire [ 63:0] radio0_radio_rx_data;
+ wire [ 1:0] radio0_radio_rx_stb;
+ wire [ 1:0] radio0_radio_rx_running;
+ wire [ 63:0] radio0_radio_tx_data;
+ wire [ 1:0] radio0_radio_tx_stb;
+ wire [ 1:0] radio0_radio_tx_running;
rfnoc_block_radio #(
- .THIS_PORTID(2),
- .CHDR_W(CHDR_W),
- .NUM_PORTS(2),
- .MTU(MTU)
+ .THIS_PORTID (2),
+ .CHDR_W (CHDR_W),
+ .NUM_PORTS (2),
+ .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),
+ .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_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)
+ .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)
);
-
- // ----------------------------------------------------
+ //-----------------------------------
// fifo0
- // ----------------------------------------------------
+ //-----------------------------------
+
wire fifo0_mem_clk;
wire [CHDR_W-1:0] s_fifo0_in_3_tdata , s_fifo0_in_2_tdata , s_fifo0_in_1_tdata , s_fifo0_in_0_tdata ;
wire s_fifo0_in_3_tlast , s_fifo0_in_2_tlast , s_fifo0_in_1_tlast , s_fifo0_in_0_tlast ;
@@ -619,182 +671,181 @@ module rfnoc_image_core #(
wire m_fifo0_out_3_tvalid, m_fifo0_out_2_tvalid, m_fifo0_out_1_tvalid, m_fifo0_out_0_tvalid;
wire m_fifo0_out_3_tready, m_fifo0_out_2_tready, m_fifo0_out_1_tready, m_fifo0_out_0_tready;
- // axi_ram
- wire [ 1-1:0] fifo0_axi_rst;
- wire [ 4-1:0] fifo0_m_axi_awid;
- wire [128-1:0] fifo0_m_axi_awaddr;
- wire [ 32-1:0] fifo0_m_axi_awlen;
- wire [ 12-1:0] fifo0_m_axi_awsize;
- wire [ 8-1:0] fifo0_m_axi_awburst;
- wire [ 4-1:0] fifo0_m_axi_awlock;
- wire [ 16-1:0] fifo0_m_axi_awcache;
- wire [ 12-1:0] fifo0_m_axi_awprot;
- wire [ 16-1:0] fifo0_m_axi_awqos;
- wire [ 16-1:0] fifo0_m_axi_awregion;
- wire [ 4-1:0] fifo0_m_axi_awuser;
- wire [ 4-1:0] fifo0_m_axi_awvalid;
- wire [ 4-1:0] fifo0_m_axi_awready;
- wire [256-1:0] fifo0_m_axi_wdata;
- wire [ 32-1:0] fifo0_m_axi_wstrb;
- wire [ 4-1:0] fifo0_m_axi_wlast;
- wire [ 4-1:0] fifo0_m_axi_wuser;
- wire [ 4-1:0] fifo0_m_axi_wvalid;
- wire [ 4-1:0] fifo0_m_axi_wready;
- wire [ 4-1:0] fifo0_m_axi_bid;
- wire [ 8-1:0] fifo0_m_axi_bresp;
- wire [ 4-1:0] fifo0_m_axi_buser;
- wire [ 4-1:0] fifo0_m_axi_bvalid;
- wire [ 4-1:0] fifo0_m_axi_bready;
- wire [ 4-1:0] fifo0_m_axi_arid;
- wire [128-1:0] fifo0_m_axi_araddr;
- wire [ 32-1:0] fifo0_m_axi_arlen;
- wire [ 12-1:0] fifo0_m_axi_arsize;
- wire [ 8-1:0] fifo0_m_axi_arburst;
- wire [ 4-1:0] fifo0_m_axi_arlock;
- wire [ 16-1:0] fifo0_m_axi_arcache;
- wire [ 12-1:0] fifo0_m_axi_arprot;
- wire [ 16-1:0] fifo0_m_axi_arqos;
- wire [ 16-1:0] fifo0_m_axi_arregion;
- wire [ 4-1:0] fifo0_m_axi_aruser;
- wire [ 4-1:0] fifo0_m_axi_arvalid;
- wire [ 4-1:0] fifo0_m_axi_arready;
- wire [ 4-1:0] fifo0_m_axi_rid;
- wire [256-1:0] fifo0_m_axi_rdata;
- wire [ 8-1:0] fifo0_m_axi_rresp;
- wire [ 4-1:0] fifo0_m_axi_rlast;
- wire [ 4-1:0] fifo0_m_axi_ruser;
- wire [ 4-1:0] fifo0_m_axi_rvalid;
- wire [ 4-1:0] fifo0_m_axi_rready;
+ // axi_ram
+ wire [ 0:0] fifo0_axi_rst;
+ wire [ 3:0] fifo0_m_axi_awid;
+ wire [ 127:0] fifo0_m_axi_awaddr;
+ wire [ 31:0] fifo0_m_axi_awlen;
+ wire [ 11:0] fifo0_m_axi_awsize;
+ wire [ 7:0] fifo0_m_axi_awburst;
+ wire [ 3:0] fifo0_m_axi_awlock;
+ wire [ 15:0] fifo0_m_axi_awcache;
+ wire [ 11:0] fifo0_m_axi_awprot;
+ wire [ 15:0] fifo0_m_axi_awqos;
+ wire [ 15:0] fifo0_m_axi_awregion;
+ wire [ 3:0] fifo0_m_axi_awuser;
+ wire [ 3:0] fifo0_m_axi_awvalid;
+ wire [ 3:0] fifo0_m_axi_awready;
+ wire [ 255:0] fifo0_m_axi_wdata;
+ wire [ 31:0] fifo0_m_axi_wstrb;
+ wire [ 3:0] fifo0_m_axi_wlast;
+ wire [ 3:0] fifo0_m_axi_wuser;
+ wire [ 3:0] fifo0_m_axi_wvalid;
+ wire [ 3:0] fifo0_m_axi_wready;
+ wire [ 3:0] fifo0_m_axi_bid;
+ wire [ 7:0] fifo0_m_axi_bresp;
+ wire [ 3:0] fifo0_m_axi_buser;
+ wire [ 3:0] fifo0_m_axi_bvalid;
+ wire [ 3:0] fifo0_m_axi_bready;
+ wire [ 3:0] fifo0_m_axi_arid;
+ wire [ 127:0] fifo0_m_axi_araddr;
+ wire [ 31:0] fifo0_m_axi_arlen;
+ wire [ 11:0] fifo0_m_axi_arsize;
+ wire [ 7:0] fifo0_m_axi_arburst;
+ wire [ 3:0] fifo0_m_axi_arlock;
+ wire [ 15:0] fifo0_m_axi_arcache;
+ wire [ 11:0] fifo0_m_axi_arprot;
+ wire [ 15:0] fifo0_m_axi_arqos;
+ wire [ 15:0] fifo0_m_axi_arregion;
+ wire [ 3:0] fifo0_m_axi_aruser;
+ wire [ 3:0] fifo0_m_axi_arvalid;
+ wire [ 3:0] fifo0_m_axi_arready;
+ wire [ 3:0] fifo0_m_axi_rid;
+ wire [ 255:0] fifo0_m_axi_rdata;
+ wire [ 7:0] fifo0_m_axi_rresp;
+ wire [ 3:0] fifo0_m_axi_rlast;
+ wire [ 3:0] fifo0_m_axi_ruser;
+ wire [ 3:0] fifo0_m_axi_rvalid;
+ wire [ 3:0] fifo0_m_axi_rready;
rfnoc_block_axi_ram_fifo #(
- .THIS_PORTID(3),
- .CHDR_W(CHDR_W),
- .NUM_PORTS(4),
- .MEM_DATA_W(64),
- .MEM_ADDR_W(31),
- .FIFO_ADDR_BASE({30'h06000000, 30'h04000000, 30'h02000000, 30'h00000000}),
- .FIFO_ADDR_MASK({30'h01FFFFFF, 30'h01FFFFFF, 30'h01FFFFFF, 30'h01FFFFFF}),
- .MEM_CLK_RATE(303819444),
- .MTU(MTU)
+ .THIS_PORTID (3),
+ .CHDR_W (CHDR_W),
+ .NUM_PORTS (4),
+ .MEM_DATA_W (64),
+ .MEM_ADDR_W (31),
+ .FIFO_ADDR_BASE ({30'h06000000, 30'h04000000, 30'h02000000, 30'h00000000}),
+ .FIFO_ADDR_MASK ({30'h01FFFFFF, 30'h01FFFFFF, 30'h01FFFFFF, 30'h01FFFFFF}),
+ .MEM_CLK_RATE (303819444),
+ .MTU (MTU)
) b_fifo0_1 (
- .rfnoc_chdr_clk (rfnoc_chdr_clk),
- .rfnoc_ctrl_clk (rfnoc_ctrl_clk),
- .mem_clk(fifo0_mem_clk),
- .rfnoc_core_config (rfnoc_core_config[512*2-1:512*1]),
- .rfnoc_core_status (rfnoc_core_status[512*2-1:512*1]),
-
- .axi_rst(fifo0_axi_rst),
- .m_axi_awid(fifo0_m_axi_awid),
- .m_axi_awaddr(fifo0_m_axi_awaddr),
- .m_axi_awlen(fifo0_m_axi_awlen),
- .m_axi_awsize(fifo0_m_axi_awsize),
- .m_axi_awburst(fifo0_m_axi_awburst),
- .m_axi_awlock(fifo0_m_axi_awlock),
- .m_axi_awcache(fifo0_m_axi_awcache),
- .m_axi_awprot(fifo0_m_axi_awprot),
- .m_axi_awqos(fifo0_m_axi_awqos),
- .m_axi_awregion(fifo0_m_axi_awregion),
- .m_axi_awuser(fifo0_m_axi_awuser),
- .m_axi_awvalid(fifo0_m_axi_awvalid),
- .m_axi_awready(fifo0_m_axi_awready),
- .m_axi_wdata(fifo0_m_axi_wdata),
- .m_axi_wstrb(fifo0_m_axi_wstrb),
- .m_axi_wlast(fifo0_m_axi_wlast),
- .m_axi_wuser(fifo0_m_axi_wuser),
- .m_axi_wvalid(fifo0_m_axi_wvalid),
- .m_axi_wready(fifo0_m_axi_wready),
- .m_axi_bid(fifo0_m_axi_bid),
- .m_axi_bresp(fifo0_m_axi_bresp),
- .m_axi_buser(fifo0_m_axi_buser),
- .m_axi_bvalid(fifo0_m_axi_bvalid),
- .m_axi_bready(fifo0_m_axi_bready),
- .m_axi_arid(fifo0_m_axi_arid),
- .m_axi_araddr(fifo0_m_axi_araddr),
- .m_axi_arlen(fifo0_m_axi_arlen),
- .m_axi_arsize(fifo0_m_axi_arsize),
- .m_axi_arburst(fifo0_m_axi_arburst),
- .m_axi_arlock(fifo0_m_axi_arlock),
- .m_axi_arcache(fifo0_m_axi_arcache),
- .m_axi_arprot(fifo0_m_axi_arprot),
- .m_axi_arqos(fifo0_m_axi_arqos),
- .m_axi_arregion(fifo0_m_axi_arregion),
- .m_axi_aruser(fifo0_m_axi_aruser),
- .m_axi_arvalid(fifo0_m_axi_arvalid),
- .m_axi_arready(fifo0_m_axi_arready),
- .m_axi_rid(fifo0_m_axi_rid),
- .m_axi_rdata(fifo0_m_axi_rdata),
- .m_axi_rresp(fifo0_m_axi_rresp),
- .m_axi_rlast(fifo0_m_axi_rlast),
- .m_axi_ruser(fifo0_m_axi_ruser),
- .m_axi_rvalid(fifo0_m_axi_rvalid),
- .m_axi_rready(fifo0_m_axi_rready),
-
- .s_rfnoc_chdr_tdata ({s_fifo0_in_3_tdata , s_fifo0_in_2_tdata , s_fifo0_in_1_tdata , s_fifo0_in_0_tdata }),
- .s_rfnoc_chdr_tlast ({s_fifo0_in_3_tlast , s_fifo0_in_2_tlast , s_fifo0_in_1_tlast , s_fifo0_in_0_tlast }),
- .s_rfnoc_chdr_tvalid({s_fifo0_in_3_tvalid, s_fifo0_in_2_tvalid, s_fifo0_in_1_tvalid, s_fifo0_in_0_tvalid}),
- .s_rfnoc_chdr_tready({s_fifo0_in_3_tready, s_fifo0_in_2_tready, s_fifo0_in_1_tready, s_fifo0_in_0_tready}),
- .m_rfnoc_chdr_tdata ({m_fifo0_out_3_tdata , m_fifo0_out_2_tdata , m_fifo0_out_1_tdata , m_fifo0_out_0_tdata }),
- .m_rfnoc_chdr_tlast ({m_fifo0_out_3_tlast , m_fifo0_out_2_tlast , m_fifo0_out_1_tlast , m_fifo0_out_0_tlast }),
- .m_rfnoc_chdr_tvalid({m_fifo0_out_3_tvalid, m_fifo0_out_2_tvalid, m_fifo0_out_1_tvalid, m_fifo0_out_0_tvalid}),
- .m_rfnoc_chdr_tready({m_fifo0_out_3_tready, m_fifo0_out_2_tready, m_fifo0_out_1_tready, m_fifo0_out_0_tready}),
- .s_rfnoc_ctrl_tdata (s_fifo0_ctrl_tdata ),
- .s_rfnoc_ctrl_tlast (s_fifo0_ctrl_tlast ),
- .s_rfnoc_ctrl_tvalid(s_fifo0_ctrl_tvalid),
- .s_rfnoc_ctrl_tready(s_fifo0_ctrl_tready),
- .m_rfnoc_ctrl_tdata (m_fifo0_ctrl_tdata ),
- .m_rfnoc_ctrl_tlast (m_fifo0_ctrl_tlast ),
- .m_rfnoc_ctrl_tvalid(m_fifo0_ctrl_tvalid),
- .m_rfnoc_ctrl_tready(m_fifo0_ctrl_tready)
+ .rfnoc_chdr_clk (rfnoc_chdr_clk),
+ .rfnoc_ctrl_clk (rfnoc_ctrl_clk),
+ .mem_clk (fifo0_mem_clk),
+ .rfnoc_core_config (rfnoc_core_config[512*2-1:512*1]),
+ .rfnoc_core_status (rfnoc_core_status[512*2-1:512*1]),
+ .axi_rst (fifo0_axi_rst),
+ .m_axi_awid (fifo0_m_axi_awid),
+ .m_axi_awaddr (fifo0_m_axi_awaddr),
+ .m_axi_awlen (fifo0_m_axi_awlen),
+ .m_axi_awsize (fifo0_m_axi_awsize),
+ .m_axi_awburst (fifo0_m_axi_awburst),
+ .m_axi_awlock (fifo0_m_axi_awlock),
+ .m_axi_awcache (fifo0_m_axi_awcache),
+ .m_axi_awprot (fifo0_m_axi_awprot),
+ .m_axi_awqos (fifo0_m_axi_awqos),
+ .m_axi_awregion (fifo0_m_axi_awregion),
+ .m_axi_awuser (fifo0_m_axi_awuser),
+ .m_axi_awvalid (fifo0_m_axi_awvalid),
+ .m_axi_awready (fifo0_m_axi_awready),
+ .m_axi_wdata (fifo0_m_axi_wdata),
+ .m_axi_wstrb (fifo0_m_axi_wstrb),
+ .m_axi_wlast (fifo0_m_axi_wlast),
+ .m_axi_wuser (fifo0_m_axi_wuser),
+ .m_axi_wvalid (fifo0_m_axi_wvalid),
+ .m_axi_wready (fifo0_m_axi_wready),
+ .m_axi_bid (fifo0_m_axi_bid),
+ .m_axi_bresp (fifo0_m_axi_bresp),
+ .m_axi_buser (fifo0_m_axi_buser),
+ .m_axi_bvalid (fifo0_m_axi_bvalid),
+ .m_axi_bready (fifo0_m_axi_bready),
+ .m_axi_arid (fifo0_m_axi_arid),
+ .m_axi_araddr (fifo0_m_axi_araddr),
+ .m_axi_arlen (fifo0_m_axi_arlen),
+ .m_axi_arsize (fifo0_m_axi_arsize),
+ .m_axi_arburst (fifo0_m_axi_arburst),
+ .m_axi_arlock (fifo0_m_axi_arlock),
+ .m_axi_arcache (fifo0_m_axi_arcache),
+ .m_axi_arprot (fifo0_m_axi_arprot),
+ .m_axi_arqos (fifo0_m_axi_arqos),
+ .m_axi_arregion (fifo0_m_axi_arregion),
+ .m_axi_aruser (fifo0_m_axi_aruser),
+ .m_axi_arvalid (fifo0_m_axi_arvalid),
+ .m_axi_arready (fifo0_m_axi_arready),
+ .m_axi_rid (fifo0_m_axi_rid),
+ .m_axi_rdata (fifo0_m_axi_rdata),
+ .m_axi_rresp (fifo0_m_axi_rresp),
+ .m_axi_rlast (fifo0_m_axi_rlast),
+ .m_axi_ruser (fifo0_m_axi_ruser),
+ .m_axi_rvalid (fifo0_m_axi_rvalid),
+ .m_axi_rready (fifo0_m_axi_rready),
+ .s_rfnoc_chdr_tdata ({s_fifo0_in_3_tdata , s_fifo0_in_2_tdata , s_fifo0_in_1_tdata , s_fifo0_in_0_tdata }),
+ .s_rfnoc_chdr_tlast ({s_fifo0_in_3_tlast , s_fifo0_in_2_tlast , s_fifo0_in_1_tlast , s_fifo0_in_0_tlast }),
+ .s_rfnoc_chdr_tvalid ({s_fifo0_in_3_tvalid, s_fifo0_in_2_tvalid, s_fifo0_in_1_tvalid, s_fifo0_in_0_tvalid}),
+ .s_rfnoc_chdr_tready ({s_fifo0_in_3_tready, s_fifo0_in_2_tready, s_fifo0_in_1_tready, s_fifo0_in_0_tready}),
+ .m_rfnoc_chdr_tdata ({m_fifo0_out_3_tdata , m_fifo0_out_2_tdata , m_fifo0_out_1_tdata , m_fifo0_out_0_tdata }),
+ .m_rfnoc_chdr_tlast ({m_fifo0_out_3_tlast , m_fifo0_out_2_tlast , m_fifo0_out_1_tlast , m_fifo0_out_0_tlast }),
+ .m_rfnoc_chdr_tvalid ({m_fifo0_out_3_tvalid, m_fifo0_out_2_tvalid, m_fifo0_out_1_tvalid, m_fifo0_out_0_tvalid}),
+ .m_rfnoc_chdr_tready ({m_fifo0_out_3_tready, m_fifo0_out_2_tready, m_fifo0_out_1_tready, m_fifo0_out_0_tready}),
+ .s_rfnoc_ctrl_tdata (s_fifo0_ctrl_tdata),
+ .s_rfnoc_ctrl_tlast (s_fifo0_ctrl_tlast),
+ .s_rfnoc_ctrl_tvalid (s_fifo0_ctrl_tvalid),
+ .s_rfnoc_ctrl_tready (s_fifo0_ctrl_tready),
+ .m_rfnoc_ctrl_tdata (m_fifo0_ctrl_tdata),
+ .m_rfnoc_ctrl_tlast (m_fifo0_ctrl_tlast),
+ .m_rfnoc_ctrl_tvalid (m_fifo0_ctrl_tvalid),
+ .m_rfnoc_ctrl_tready (m_fifo0_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_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_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_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_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_fifo0_in_0_tdata = m_ep4_out0_tdata ;
- assign s_fifo0_in_0_tlast = m_ep4_out0_tlast ;
+ assign s_fifo0_in_0_tdata = m_ep4_out0_tdata;
+ assign s_fifo0_in_0_tlast = m_ep4_out0_tlast;
assign s_fifo0_in_0_tvalid = m_ep4_out0_tvalid;
assign m_ep4_out0_tready = s_fifo0_in_0_tready;
- assign s_ep4_in0_tdata = m_fifo0_out_0_tdata ;
- assign s_ep4_in0_tlast = m_fifo0_out_0_tlast ;
+ assign s_ep4_in0_tdata = m_fifo0_out_0_tdata;
+ assign s_ep4_in0_tlast = m_fifo0_out_0_tlast;
assign s_ep4_in0_tvalid = m_fifo0_out_0_tvalid;
assign m_fifo0_out_0_tready = s_ep4_in0_tready;
- assign s_fifo0_in_1_tdata = m_ep5_out0_tdata ;
- assign s_fifo0_in_1_tlast = m_ep5_out0_tlast ;
+ assign s_fifo0_in_1_tdata = m_ep5_out0_tdata;
+ assign s_fifo0_in_1_tlast = m_ep5_out0_tlast;
assign s_fifo0_in_1_tvalid = m_ep5_out0_tvalid;
assign m_ep5_out0_tready = s_fifo0_in_1_tready;
- assign s_ep5_in0_tdata = m_fifo0_out_1_tdata ;
- assign s_ep5_in0_tlast = m_fifo0_out_1_tlast ;
+ assign s_ep5_in0_tdata = m_fifo0_out_1_tdata;
+ assign s_ep5_in0_tlast = m_fifo0_out_1_tlast;
assign s_ep5_in0_tvalid = m_fifo0_out_1_tvalid;
assign m_fifo0_out_1_tready = s_ep5_in0_tready;
- // ----------------------------------------------------
+ //---------------------------------------------------------------------------
// Unused Ports
- // ----------------------------------------------------
+ //---------------------------------------------------------------------------
+
assign s_fifo0_in_2_tdata = {CHDR_W{1'b0}};
assign s_fifo0_in_2_tlast = 1'b0;
assign s_fifo0_in_2_tvalid = 1'b0;
@@ -804,16 +855,19 @@ module rfnoc_image_core #(
assign m_fifo0_out_2_tready = 1'b1;
assign m_fifo0_out_3_tready = 1'b1;
- // ----------------------------------------------------
+
+ //---------------------------------------------------------------------------
// Clock Domains
- // ----------------------------------------------------
+ //---------------------------------------------------------------------------
+
assign radio0_radio_clk = radio_clk;
assign fifo0_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;
@@ -883,3 +937,6 @@ module rfnoc_image_core #(
assign radio0_radio_time = radio_time;
endmodule
+
+
+`default_nettype wire
diff --git a/fpga/usrp3/top/n3xx/n300_rfnoc_image_core.v b/fpga/usrp3/top/n3xx/n300_rfnoc_image_core.v
index 43b9ffc81..19807fa9b 100644
--- a/fpga/usrp3/top/n3xx/n300_rfnoc_image_core.v
+++ b/fpga/usrp3/top/n3xx/n300_rfnoc_image_core.v
@@ -1,19 +1,32 @@
//
-// Copyright 2020 Ettus Research, A National Instruments Brand
+// Copyright 2021 Ettus Research, A National Instruments Brand
//
// SPDX-License-Identifier: LGPL-3.0-or-later
//
-
// Module: rfnoc_image_core (for n300)
-// This file was autogenerated by UHD's image builder tool (rfnoc_image_builder)
-// Re-running that tool will overwrite this file!
-// File generated on: 2020-09-02T12:02:55.936585
-// Source: ./n300_rfnoc_image_core.yml
-// Source SHA256: e9dd3107c1f434abca5d183f64dfc5e53d52192f5d488cab07b239c3b44b2593
+//
+// 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: 2021-05-03T08:51:08.459279
+// Source: n300_rfnoc_image_core.yml
+// Source SHA256: 64f2b862b3e60cb0456befb88ea28825b6bba271ff4e86a24ab618932773a861
+//
+
+`default_nettype none
+
module rfnoc_image_core #(
- parameter [15:0] PROTOVER = {8'd1, 8'd0}
-)(
+ parameter CHDR_W = 64,
+ parameter MTU = 10,
+ parameter [15:0] PROTOVER = {8'd1, 8'd0},
+ parameter RADIO_NIPC = 1
+) (
// Clocks
input wire chdr_aclk,
input wire ctrl_aclk,
@@ -21,113 +34,118 @@ module rfnoc_image_core #(
input wire radio_clk,
input wire dram_clk,
// Basic
- input wire [15:0] device_id,
-//// IO ports //////////////////////////////////
-// ctrlport_radio0
- output wire [ 1-1:0] m_ctrlport_radio0_req_wr,
- output wire [ 1-1:0] m_ctrlport_radio0_req_rd,
- output wire [ 20-1:0] m_ctrlport_radio0_req_addr,
- output wire [ 32-1:0] m_ctrlport_radio0_req_data,
- output wire [ 4-1:0] m_ctrlport_radio0_req_byte_en,
- output wire [ 1-1:0] m_ctrlport_radio0_req_has_time,
- output wire [ 64-1:0] m_ctrlport_radio0_req_time,
- input wire [ 1-1:0] m_ctrlport_radio0_resp_ack,
- input wire [ 2-1:0] m_ctrlport_radio0_resp_status,
- input wire [ 32-1:0] m_ctrlport_radio0_resp_data,
-// time_keeper
- input wire [ 64-1:0] radio_time,
-// x300_radio0
- input wire [ 64-1:0] radio_rx_data_radio0,
- input wire [ 2-1:0] radio_rx_stb_radio0,
- output wire [ 2-1:0] radio_rx_running_radio0,
- output wire [ 64-1:0] radio_tx_data_radio0,
- input wire [ 2-1:0] radio_tx_stb_radio0,
- output wire [ 2-1:0] radio_tx_running_radio0,
-// dram
- input wire [ 1-1:0] axi_rst,
- output wire [ 4-1:0] m_axi_awid,
- output wire [128-1:0] m_axi_awaddr,
- output wire [ 32-1:0] m_axi_awlen,
- output wire [ 12-1:0] m_axi_awsize,
- output wire [ 8-1:0] m_axi_awburst,
- output wire [ 4-1:0] m_axi_awlock,
- output wire [ 16-1:0] m_axi_awcache,
- output wire [ 12-1:0] m_axi_awprot,
- output wire [ 16-1:0] m_axi_awqos,
- output wire [ 16-1:0] m_axi_awregion,
- output wire [ 4-1:0] m_axi_awuser,
- output wire [ 4-1:0] m_axi_awvalid,
- input wire [ 4-1:0] m_axi_awready,
- output wire [256-1:0] m_axi_wdata,
- output wire [ 32-1:0] m_axi_wstrb,
- output wire [ 4-1:0] m_axi_wlast,
- output wire [ 4-1:0] m_axi_wuser,
- output wire [ 4-1:0] m_axi_wvalid,
- input wire [ 4-1:0] m_axi_wready,
- input wire [ 4-1:0] m_axi_bid,
- input wire [ 8-1:0] m_axi_bresp,
- input wire [ 4-1:0] m_axi_buser,
- input wire [ 4-1:0] m_axi_bvalid,
- output wire [ 4-1:0] m_axi_bready,
- output wire [ 4-1:0] m_axi_arid,
- output wire [128-1:0] m_axi_araddr,
- output wire [ 32-1:0] m_axi_arlen,
- output wire [ 12-1:0] m_axi_arsize,
- output wire [ 8-1:0] m_axi_arburst,
- output wire [ 4-1:0] m_axi_arlock,
- output wire [ 16-1:0] m_axi_arcache,
- output wire [ 12-1:0] m_axi_arprot,
- output wire [ 16-1:0] m_axi_arqos,
- output wire [ 16-1:0] m_axi_arregion,
- output wire [ 4-1:0] m_axi_aruser,
- output wire [ 4-1:0] m_axi_arvalid,
- input wire [ 4-1:0] m_axi_arready,
- input wire [ 4-1:0] m_axi_rid,
- input wire [256-1:0] m_axi_rdata,
- input wire [ 8-1:0] m_axi_rresp,
- input wire [ 4-1:0] m_axi_rlast,
- input wire [ 4-1:0] m_axi_ruser,
- input wire [ 4-1:0] m_axi_rvalid,
- output wire [ 4-1:0] m_axi_rready,
- // Transport 0 (eth0 1G)
- input wire [64-1:0] s_eth0_tdata,
- input wire s_eth0_tlast,
- input wire s_eth0_tvalid,
- output wire s_eth0_tready,
- output wire [64-1:0] m_eth0_tdata,
- output wire m_eth0_tlast,
- output wire m_eth0_tvalid,
- input wire m_eth0_tready,
- // Transport 1 (eth1 10G)
- input wire [64-1:0] s_eth1_tdata,
- input wire s_eth1_tlast,
- input wire s_eth1_tvalid,
- output wire s_eth1_tready,
- output wire [64-1:0] m_eth1_tdata,
- output wire m_eth1_tlast,
- output wire m_eth1_tvalid,
- input wire m_eth1_tready,
- // Transport 2 (dma dma)
- input wire [64-1:0] s_dma_tdata,
- input wire s_dma_tlast,
- input wire s_dma_tvalid,
- output wire s_dma_tready,
- output wire [64-1:0] m_dma_tdata,
- output wire m_dma_tlast,
- output wire m_dma_tvalid,
- input wire m_dma_tready
+ 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,
+ // time_keeper
+ input wire [ 63:0] radio_time,
+ // x300_radio0
+ input wire [ 63:0] radio_rx_data_radio0,
+ input wire [ 1:0] radio_rx_stb_radio0,
+ output wire [ 1:0] radio_rx_running_radio0,
+ output wire [ 63:0] radio_tx_data_radio0,
+ input wire [ 1:0] radio_tx_stb_radio0,
+ output wire [ 1:0] radio_tx_running_radio0,
+ // dram
+ input wire [ 0:0] axi_rst,
+ output wire [ 3:0] m_axi_awid,
+ output wire [ 127: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 [ 255:0] m_axi_wdata,
+ output wire [ 31: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 [ 127: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 [ 255: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 (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 CHDR_W = 64;
- localparam MTU = 10;
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;
@@ -176,12 +194,12 @@ module rfnoc_image_core #(
.clk (rfnoc_chdr_clk),
.reset (rfnoc_chdr_rst),
.device_id (device_id),
- .s_axis_tdata ({ep3_to_xb_tdata, ep2_to_xb_tdata, ep1_to_xb_tdata, ep0_to_xb_tdata, s_dma_tdata, s_eth1_tdata, s_eth0_tdata}),
- .s_axis_tlast ({ep3_to_xb_tlast, ep2_to_xb_tlast, ep1_to_xb_tlast, ep0_to_xb_tlast, s_dma_tlast, s_eth1_tlast, s_eth0_tlast}),
+ .s_axis_tdata ({ep3_to_xb_tdata , ep2_to_xb_tdata , ep1_to_xb_tdata , ep0_to_xb_tdata , s_dma_tdata , s_eth1_tdata , s_eth0_tdata }),
+ .s_axis_tlast ({ep3_to_xb_tlast , ep2_to_xb_tlast , ep1_to_xb_tlast , ep0_to_xb_tlast , s_dma_tlast , s_eth1_tlast , s_eth0_tlast }),
.s_axis_tvalid ({ep3_to_xb_tvalid, ep2_to_xb_tvalid, ep1_to_xb_tvalid, ep0_to_xb_tvalid, s_dma_tvalid, s_eth1_tvalid, s_eth0_tvalid}),
.s_axis_tready ({ep3_to_xb_tready, ep2_to_xb_tready, ep1_to_xb_tready, ep0_to_xb_tready, s_dma_tready, s_eth1_tready, s_eth0_tready}),
- .m_axis_tdata ({xb_to_ep3_tdata, xb_to_ep2_tdata, xb_to_ep1_tdata, xb_to_ep0_tdata, m_dma_tdata, m_eth1_tdata, m_eth0_tdata}),
- .m_axis_tlast ({xb_to_ep3_tlast, xb_to_ep2_tlast, xb_to_ep1_tlast, xb_to_ep0_tlast, m_dma_tlast, m_eth1_tlast, m_eth0_tlast}),
+ .m_axis_tdata ({xb_to_ep3_tdata , xb_to_ep2_tdata , xb_to_ep1_tdata , xb_to_ep0_tdata , m_dma_tdata , m_eth1_tdata , m_eth0_tdata }),
+ .m_axis_tlast ({xb_to_ep3_tlast , xb_to_ep2_tlast , xb_to_ep1_tlast , xb_to_ep0_tlast , m_dma_tlast , m_eth1_tlast , m_eth0_tlast }),
.m_axis_tvalid ({xb_to_ep3_tvalid, xb_to_ep2_tvalid, xb_to_ep1_tvalid, xb_to_ep0_tvalid, m_dma_tvalid, m_eth1_tvalid, m_eth0_tvalid}),
.m_axis_tready ({xb_to_ep3_tready, xb_to_ep2_tready, xb_to_ep1_tready, xb_to_ep0_tready, m_dma_tready, m_eth1_tready, m_eth0_tready}),
.ext_rtcfg_stb (1'h0),
@@ -190,9 +208,18 @@ module rfnoc_image_core #(
.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;
+ 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;
@@ -202,8 +229,8 @@ module rfnoc_image_core #(
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 [ 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;
@@ -216,23 +243,23 @@ module rfnoc_image_core #(
.NUM_DATA_O (1),
.INST_NUM (0),
.CTRL_XBAR_PORT (1),
- .INGRESS_BUFF_SIZE (15),
+ .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 ),
+ .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}),
@@ -241,20 +268,28 @@ module rfnoc_image_core #(
.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_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_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 )
+ .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;
+ 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;
@@ -263,8 +298,8 @@ module rfnoc_image_core #(
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 [ 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;
@@ -277,23 +312,23 @@ module rfnoc_image_core #(
.NUM_DATA_O (1),
.INST_NUM (1),
.CTRL_XBAR_PORT (2),
- .INGRESS_BUFF_SIZE (15),
+ .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 ),
+ .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}),
@@ -302,20 +337,28 @@ module rfnoc_image_core #(
.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_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_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 )
+ .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 = 4096;
+ 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;
@@ -324,8 +367,8 @@ module rfnoc_image_core #(
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 [ 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;
@@ -338,23 +381,23 @@ module rfnoc_image_core #(
.NUM_DATA_O (1),
.INST_NUM (2),
.CTRL_XBAR_PORT (3),
- .INGRESS_BUFF_SIZE (12),
+ .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 ),
+ .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}),
@@ -363,20 +406,28 @@ module rfnoc_image_core #(
.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_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_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 )
+ .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 = 4096;
+ 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;
@@ -385,8 +436,8 @@ module rfnoc_image_core #(
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 [ 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;
@@ -399,23 +450,23 @@ module rfnoc_image_core #(
.NUM_DATA_O (1),
.INST_NUM (3),
.CTRL_XBAR_PORT (4),
- .INGRESS_BUFF_SIZE (12),
+ .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 ),
+ .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}),
@@ -424,46 +475,45 @@ module rfnoc_image_core #(
.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_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_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 )
+ .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_duc0_ctrl_tdata , s_duc0_ctrl_tdata ;
- wire m_duc0_ctrl_tlast , s_duc0_ctrl_tlast ;
- wire m_duc0_ctrl_tvalid, s_duc0_ctrl_tvalid;
- wire m_duc0_ctrl_tready, s_duc0_ctrl_tready;
- wire [31:0] m_ddc0_ctrl_tdata , s_ddc0_ctrl_tdata ;
- wire m_ddc0_ctrl_tlast , s_ddc0_ctrl_tlast ;
- wire m_ddc0_ctrl_tvalid, s_ddc0_ctrl_tvalid;
- wire m_ddc0_ctrl_tready, s_ddc0_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_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;
+ //---------------------------------------------------------------------------
+
+ 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_duc0_ctrl_tdata, s_duc0_ctrl_tdata;
+ wire m_duc0_ctrl_tlast, s_duc0_ctrl_tlast;
+ wire m_duc0_ctrl_tvalid, s_duc0_ctrl_tvalid;
+ wire m_duc0_ctrl_tready, s_duc0_ctrl_tready;
+ wire [31:0] m_ddc0_ctrl_tdata, s_ddc0_ctrl_tdata;
+ wire m_ddc0_ctrl_tlast, s_ddc0_ctrl_tlast;
+ wire m_ddc0_ctrl_tvalid, s_ddc0_ctrl_tvalid;
+ wire m_ddc0_ctrl_tready, s_ddc0_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_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),
@@ -487,9 +537,11 @@ module rfnoc_image_core #(
.deadlock_detected()
);
- // ----------------------------------------------------
+
+ //---------------------------------------------------------------------------
// RFNoC Core Kernel
- // ----------------------------------------------------
+ //---------------------------------------------------------------------------
+
wire [(512*4)-1:0] rfnoc_core_config, rfnoc_core_status;
rfnoc_core_kernel #(
@@ -514,12 +566,12 @@ module rfnoc_image_core #(
.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_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_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),
@@ -527,13 +579,15 @@ module rfnoc_image_core #(
.rfnoc_core_status (rfnoc_core_status)
);
- // ----------------------------------------------------
+
+ //---------------------------------------------------------------------------
// Blocks
- // ----------------------------------------------------
+ //---------------------------------------------------------------------------
- // ----------------------------------------------------
+ //-----------------------------------
// duc0
- // ----------------------------------------------------
+ //-----------------------------------
+
wire duc0_ce_clk;
wire [CHDR_W-1:0] s_duc0_in_1_tdata , s_duc0_in_0_tdata ;
wire s_duc0_in_1_tlast , s_duc0_in_0_tlast ;
@@ -544,44 +598,41 @@ module rfnoc_image_core #(
wire m_duc0_out_1_tvalid, m_duc0_out_0_tvalid;
wire m_duc0_out_1_tready, m_duc0_out_0_tready;
-
rfnoc_block_duc #(
- .THIS_PORTID(2),
- .CHDR_W(CHDR_W),
- .NUM_PORTS(2),
- .NUM_HB(3),
- .CIC_MAX_INTERP(255),
- .MTU(MTU)
+ .THIS_PORTID (2),
+ .CHDR_W (CHDR_W),
+ .NUM_PORTS (2),
+ .NUM_HB (3),
+ .CIC_MAX_INTERP (255),
+ .MTU (MTU)
) b_duc0_0 (
- .rfnoc_chdr_clk (rfnoc_chdr_clk),
- .rfnoc_ctrl_clk (rfnoc_ctrl_clk),
- .ce_clk(duc0_ce_clk),
- .rfnoc_core_config (rfnoc_core_config[512*1-1:512*0]),
- .rfnoc_core_status (rfnoc_core_status[512*1-1:512*0]),
-
-
- .s_rfnoc_chdr_tdata ({s_duc0_in_1_tdata , s_duc0_in_0_tdata }),
- .s_rfnoc_chdr_tlast ({s_duc0_in_1_tlast , s_duc0_in_0_tlast }),
- .s_rfnoc_chdr_tvalid({s_duc0_in_1_tvalid, s_duc0_in_0_tvalid}),
- .s_rfnoc_chdr_tready({s_duc0_in_1_tready, s_duc0_in_0_tready}),
- .m_rfnoc_chdr_tdata ({m_duc0_out_1_tdata , m_duc0_out_0_tdata }),
- .m_rfnoc_chdr_tlast ({m_duc0_out_1_tlast , m_duc0_out_0_tlast }),
- .m_rfnoc_chdr_tvalid({m_duc0_out_1_tvalid, m_duc0_out_0_tvalid}),
- .m_rfnoc_chdr_tready({m_duc0_out_1_tready, m_duc0_out_0_tready}),
- .s_rfnoc_ctrl_tdata (s_duc0_ctrl_tdata ),
- .s_rfnoc_ctrl_tlast (s_duc0_ctrl_tlast ),
- .s_rfnoc_ctrl_tvalid(s_duc0_ctrl_tvalid),
- .s_rfnoc_ctrl_tready(s_duc0_ctrl_tready),
- .m_rfnoc_ctrl_tdata (m_duc0_ctrl_tdata ),
- .m_rfnoc_ctrl_tlast (m_duc0_ctrl_tlast ),
- .m_rfnoc_ctrl_tvalid(m_duc0_ctrl_tvalid),
- .m_rfnoc_ctrl_tready(m_duc0_ctrl_tready)
+ .rfnoc_chdr_clk (rfnoc_chdr_clk),
+ .rfnoc_ctrl_clk (rfnoc_ctrl_clk),
+ .ce_clk (duc0_ce_clk),
+ .rfnoc_core_config (rfnoc_core_config[512*1-1:512*0]),
+ .rfnoc_core_status (rfnoc_core_status[512*1-1:512*0]),
+ .s_rfnoc_chdr_tdata ({s_duc0_in_1_tdata , s_duc0_in_0_tdata }),
+ .s_rfnoc_chdr_tlast ({s_duc0_in_1_tlast , s_duc0_in_0_tlast }),
+ .s_rfnoc_chdr_tvalid ({s_duc0_in_1_tvalid, s_duc0_in_0_tvalid}),
+ .s_rfnoc_chdr_tready ({s_duc0_in_1_tready, s_duc0_in_0_tready}),
+ .m_rfnoc_chdr_tdata ({m_duc0_out_1_tdata , m_duc0_out_0_tdata }),
+ .m_rfnoc_chdr_tlast ({m_duc0_out_1_tlast , m_duc0_out_0_tlast }),
+ .m_rfnoc_chdr_tvalid ({m_duc0_out_1_tvalid, m_duc0_out_0_tvalid}),
+ .m_rfnoc_chdr_tready ({m_duc0_out_1_tready, m_duc0_out_0_tready}),
+ .s_rfnoc_ctrl_tdata (s_duc0_ctrl_tdata),
+ .s_rfnoc_ctrl_tlast (s_duc0_ctrl_tlast),
+ .s_rfnoc_ctrl_tvalid (s_duc0_ctrl_tvalid),
+ .s_rfnoc_ctrl_tready (s_duc0_ctrl_tready),
+ .m_rfnoc_ctrl_tdata (m_duc0_ctrl_tdata),
+ .m_rfnoc_ctrl_tlast (m_duc0_ctrl_tlast),
+ .m_rfnoc_ctrl_tvalid (m_duc0_ctrl_tvalid),
+ .m_rfnoc_ctrl_tready (m_duc0_ctrl_tready)
);
-
- // ----------------------------------------------------
+ //-----------------------------------
// ddc0
- // ----------------------------------------------------
+ //-----------------------------------
+
wire ddc0_ce_clk;
wire [CHDR_W-1:0] s_ddc0_in_1_tdata , s_ddc0_in_0_tdata ;
wire s_ddc0_in_1_tlast , s_ddc0_in_0_tlast ;
@@ -592,44 +643,41 @@ module rfnoc_image_core #(
wire m_ddc0_out_1_tvalid, m_ddc0_out_0_tvalid;
wire m_ddc0_out_1_tready, m_ddc0_out_0_tready;
-
rfnoc_block_ddc #(
- .THIS_PORTID(3),
- .CHDR_W(CHDR_W),
- .NUM_PORTS(2),
- .NUM_HB(3),
- .CIC_MAX_DECIM(255),
- .MTU(MTU)
+ .THIS_PORTID (3),
+ .CHDR_W (CHDR_W),
+ .NUM_PORTS (2),
+ .NUM_HB (3),
+ .CIC_MAX_DECIM (255),
+ .MTU (MTU)
) b_ddc0_1 (
- .rfnoc_chdr_clk (rfnoc_chdr_clk),
- .rfnoc_ctrl_clk (rfnoc_ctrl_clk),
- .ce_clk(ddc0_ce_clk),
- .rfnoc_core_config (rfnoc_core_config[512*2-1:512*1]),
- .rfnoc_core_status (rfnoc_core_status[512*2-1:512*1]),
-
-
- .s_rfnoc_chdr_tdata ({s_ddc0_in_1_tdata , s_ddc0_in_0_tdata }),
- .s_rfnoc_chdr_tlast ({s_ddc0_in_1_tlast , s_ddc0_in_0_tlast }),
- .s_rfnoc_chdr_tvalid({s_ddc0_in_1_tvalid, s_ddc0_in_0_tvalid}),
- .s_rfnoc_chdr_tready({s_ddc0_in_1_tready, s_ddc0_in_0_tready}),
- .m_rfnoc_chdr_tdata ({m_ddc0_out_1_tdata , m_ddc0_out_0_tdata }),
- .m_rfnoc_chdr_tlast ({m_ddc0_out_1_tlast , m_ddc0_out_0_tlast }),
- .m_rfnoc_chdr_tvalid({m_ddc0_out_1_tvalid, m_ddc0_out_0_tvalid}),
- .m_rfnoc_chdr_tready({m_ddc0_out_1_tready, m_ddc0_out_0_tready}),
- .s_rfnoc_ctrl_tdata (s_ddc0_ctrl_tdata ),
- .s_rfnoc_ctrl_tlast (s_ddc0_ctrl_tlast ),
- .s_rfnoc_ctrl_tvalid(s_ddc0_ctrl_tvalid),
- .s_rfnoc_ctrl_tready(s_ddc0_ctrl_tready),
- .m_rfnoc_ctrl_tdata (m_ddc0_ctrl_tdata ),
- .m_rfnoc_ctrl_tlast (m_ddc0_ctrl_tlast ),
- .m_rfnoc_ctrl_tvalid(m_ddc0_ctrl_tvalid),
- .m_rfnoc_ctrl_tready(m_ddc0_ctrl_tready)
+ .rfnoc_chdr_clk (rfnoc_chdr_clk),
+ .rfnoc_ctrl_clk (rfnoc_ctrl_clk),
+ .ce_clk (ddc0_ce_clk),
+ .rfnoc_core_config (rfnoc_core_config[512*2-1:512*1]),
+ .rfnoc_core_status (rfnoc_core_status[512*2-1:512*1]),
+ .s_rfnoc_chdr_tdata ({s_ddc0_in_1_tdata , s_ddc0_in_0_tdata }),
+ .s_rfnoc_chdr_tlast ({s_ddc0_in_1_tlast , s_ddc0_in_0_tlast }),
+ .s_rfnoc_chdr_tvalid ({s_ddc0_in_1_tvalid, s_ddc0_in_0_tvalid}),
+ .s_rfnoc_chdr_tready ({s_ddc0_in_1_tready, s_ddc0_in_0_tready}),
+ .m_rfnoc_chdr_tdata ({m_ddc0_out_1_tdata , m_ddc0_out_0_tdata }),
+ .m_rfnoc_chdr_tlast ({m_ddc0_out_1_tlast , m_ddc0_out_0_tlast }),
+ .m_rfnoc_chdr_tvalid ({m_ddc0_out_1_tvalid, m_ddc0_out_0_tvalid}),
+ .m_rfnoc_chdr_tready ({m_ddc0_out_1_tready, m_ddc0_out_0_tready}),
+ .s_rfnoc_ctrl_tdata (s_ddc0_ctrl_tdata),
+ .s_rfnoc_ctrl_tlast (s_ddc0_ctrl_tlast),
+ .s_rfnoc_ctrl_tvalid (s_ddc0_ctrl_tvalid),
+ .s_rfnoc_ctrl_tready (s_ddc0_ctrl_tready),
+ .m_rfnoc_ctrl_tdata (m_ddc0_ctrl_tdata),
+ .m_rfnoc_ctrl_tlast (m_ddc0_ctrl_tlast),
+ .m_rfnoc_ctrl_tvalid (m_ddc0_ctrl_tvalid),
+ .m_rfnoc_ctrl_tready (m_ddc0_ctrl_tready)
);
-
- // ----------------------------------------------------
+ //-----------------------------------
// 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 ;
@@ -640,79 +688,77 @@ module rfnoc_image_core #(
wire m_radio0_out_1_tvalid, m_radio0_out_0_tvalid;
wire m_radio0_out_1_tready, m_radio0_out_0_tready;
- // ctrl_port
- wire [ 1-1:0] radio0_m_ctrlport_req_wr;
- wire [ 1-1:0] radio0_m_ctrlport_req_rd;
- wire [ 20-1:0] radio0_m_ctrlport_req_addr;
- wire [ 32-1:0] radio0_m_ctrlport_req_data;
- wire [ 4-1:0] radio0_m_ctrlport_req_byte_en;
- wire [ 1-1:0] radio0_m_ctrlport_req_has_time;
- wire [ 64-1:0] radio0_m_ctrlport_req_time;
- wire [ 1-1:0] radio0_m_ctrlport_resp_ack;
- wire [ 2-1:0] radio0_m_ctrlport_resp_status;
- wire [ 32-1:0] radio0_m_ctrlport_resp_data;
- // time_keeper
- wire [ 64-1:0] radio0_radio_time;
- // x300_radio
- wire [ 64-1:0] radio0_radio_rx_data;
- wire [ 2-1:0] radio0_radio_rx_stb;
- wire [ 2-1:0] radio0_radio_rx_running;
- wire [ 64-1:0] radio0_radio_tx_data;
- wire [ 2-1:0] radio0_radio_tx_stb;
- wire [ 2-1:0] radio0_radio_tx_running;
+ // ctrl_port
+ 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_keeper
+ wire [ 63:0] radio0_radio_time;
+ // x300_radio
+ wire [ 63:0] radio0_radio_rx_data;
+ wire [ 1:0] radio0_radio_rx_stb;
+ wire [ 1:0] radio0_radio_rx_running;
+ wire [ 63:0] radio0_radio_tx_data;
+ wire [ 1:0] radio0_radio_tx_stb;
+ wire [ 1:0] radio0_radio_tx_running;
rfnoc_block_radio #(
- .THIS_PORTID(4),
- .CHDR_W(CHDR_W),
- .NUM_PORTS(2),
- .MTU(MTU)
+ .THIS_PORTID (4),
+ .CHDR_W (CHDR_W),
+ .NUM_PORTS (2),
+ .MTU (MTU)
) b_radio0_2 (
- .rfnoc_chdr_clk (rfnoc_chdr_clk),
- .rfnoc_ctrl_clk (rfnoc_ctrl_clk),
- .radio_clk(radio0_radio_clk),
- .rfnoc_core_config (rfnoc_core_config[512*3-1:512*2]),
- .rfnoc_core_status (rfnoc_core_status[512*3-1:512*2]),
-
- .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),
+ .rfnoc_chdr_clk (rfnoc_chdr_clk),
+ .rfnoc_ctrl_clk (rfnoc_ctrl_clk),
+ .radio_clk (radio0_radio_clk),
+ .rfnoc_core_config (rfnoc_core_config[512*3-1:512*2]),
+ .rfnoc_core_status (rfnoc_core_status[512*3-1:512*2]),
+ .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_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)
+ .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)
);
-
- // ----------------------------------------------------
+ //-----------------------------------
// replay0
- // ----------------------------------------------------
+ //-----------------------------------
+
wire replay0_mem_clk;
wire [CHDR_W-1:0] s_replay0_in_1_tdata , s_replay0_in_0_tdata ;
wire s_replay0_in_1_tlast , s_replay0_in_0_tlast ;
@@ -723,212 +769,214 @@ module rfnoc_image_core #(
wire m_replay0_out_1_tvalid, m_replay0_out_0_tvalid;
wire m_replay0_out_1_tready, m_replay0_out_0_tready;
- // axi_ram
- wire [ 1-1:0] replay0_axi_rst;
- wire [ 4-1:0] replay0_m_axi_awid;
- wire [128-1:0] replay0_m_axi_awaddr;
- wire [ 32-1:0] replay0_m_axi_awlen;
- wire [ 12-1:0] replay0_m_axi_awsize;
- wire [ 8-1:0] replay0_m_axi_awburst;
- wire [ 4-1:0] replay0_m_axi_awlock;
- wire [ 16-1:0] replay0_m_axi_awcache;
- wire [ 12-1:0] replay0_m_axi_awprot;
- wire [ 16-1:0] replay0_m_axi_awqos;
- wire [ 16-1:0] replay0_m_axi_awregion;
- wire [ 4-1:0] replay0_m_axi_awuser;
- wire [ 4-1:0] replay0_m_axi_awvalid;
- wire [ 4-1:0] replay0_m_axi_awready;
- wire [256-1:0] replay0_m_axi_wdata;
- wire [ 32-1:0] replay0_m_axi_wstrb;
- wire [ 4-1:0] replay0_m_axi_wlast;
- wire [ 4-1:0] replay0_m_axi_wuser;
- wire [ 4-1:0] replay0_m_axi_wvalid;
- wire [ 4-1:0] replay0_m_axi_wready;
- wire [ 4-1:0] replay0_m_axi_bid;
- wire [ 8-1:0] replay0_m_axi_bresp;
- wire [ 4-1:0] replay0_m_axi_buser;
- wire [ 4-1:0] replay0_m_axi_bvalid;
- wire [ 4-1:0] replay0_m_axi_bready;
- wire [ 4-1:0] replay0_m_axi_arid;
- wire [128-1:0] replay0_m_axi_araddr;
- wire [ 32-1:0] replay0_m_axi_arlen;
- wire [ 12-1:0] replay0_m_axi_arsize;
- wire [ 8-1:0] replay0_m_axi_arburst;
- wire [ 4-1:0] replay0_m_axi_arlock;
- wire [ 16-1:0] replay0_m_axi_arcache;
- wire [ 12-1:0] replay0_m_axi_arprot;
- wire [ 16-1:0] replay0_m_axi_arqos;
- wire [ 16-1:0] replay0_m_axi_arregion;
- wire [ 4-1:0] replay0_m_axi_aruser;
- wire [ 4-1:0] replay0_m_axi_arvalid;
- wire [ 4-1:0] replay0_m_axi_arready;
- wire [ 4-1:0] replay0_m_axi_rid;
- wire [256-1:0] replay0_m_axi_rdata;
- wire [ 8-1:0] replay0_m_axi_rresp;
- wire [ 4-1:0] replay0_m_axi_rlast;
- wire [ 4-1:0] replay0_m_axi_ruser;
- wire [ 4-1:0] replay0_m_axi_rvalid;
- wire [ 4-1:0] replay0_m_axi_rready;
+ // axi_ram
+ wire [ 0:0] replay0_axi_rst;
+ wire [ 3:0] replay0_m_axi_awid;
+ wire [ 127: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 [ 255:0] replay0_m_axi_wdata;
+ wire [ 31: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 [ 127: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 [ 255: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(5),
- .CHDR_W(CHDR_W),
- .NUM_PORTS(2),
- .MEM_ADDR_W(31),
- .MEM_DATA_W(64),
- .MTU(MTU)
+ .THIS_PORTID (5),
+ .CHDR_W (CHDR_W),
+ .NUM_PORTS (2),
+ .MEM_ADDR_W (31),
+ .MEM_DATA_W (64),
+ .MTU (MTU)
) b_replay0_3 (
- .rfnoc_chdr_clk (rfnoc_chdr_clk),
- .rfnoc_ctrl_clk (rfnoc_ctrl_clk),
- .mem_clk(replay0_mem_clk),
- .rfnoc_core_config (rfnoc_core_config[512*4-1:512*3]),
- .rfnoc_core_status (rfnoc_core_status[512*4-1:512*3]),
-
- .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_1_tdata , s_replay0_in_0_tdata }),
- .s_rfnoc_chdr_tlast ({s_replay0_in_1_tlast , s_replay0_in_0_tlast }),
- .s_rfnoc_chdr_tvalid({s_replay0_in_1_tvalid, s_replay0_in_0_tvalid}),
- .s_rfnoc_chdr_tready({s_replay0_in_1_tready, s_replay0_in_0_tready}),
- .m_rfnoc_chdr_tdata ({m_replay0_out_1_tdata , m_replay0_out_0_tdata }),
- .m_rfnoc_chdr_tlast ({m_replay0_out_1_tlast , m_replay0_out_0_tlast }),
- .m_rfnoc_chdr_tvalid({m_replay0_out_1_tvalid, m_replay0_out_0_tvalid}),
- .m_rfnoc_chdr_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)
+ .rfnoc_chdr_clk (rfnoc_chdr_clk),
+ .rfnoc_ctrl_clk (rfnoc_ctrl_clk),
+ .mem_clk (replay0_mem_clk),
+ .rfnoc_core_config (rfnoc_core_config[512*4-1:512*3]),
+ .rfnoc_core_status (rfnoc_core_status[512*4-1:512*3]),
+ .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_1_tdata , s_replay0_in_0_tdata }),
+ .s_rfnoc_chdr_tlast ({s_replay0_in_1_tlast , s_replay0_in_0_tlast }),
+ .s_rfnoc_chdr_tvalid ({s_replay0_in_1_tvalid, s_replay0_in_0_tvalid}),
+ .s_rfnoc_chdr_tready ({s_replay0_in_1_tready, s_replay0_in_0_tready}),
+ .m_rfnoc_chdr_tdata ({m_replay0_out_1_tdata , m_replay0_out_0_tdata }),
+ .m_rfnoc_chdr_tlast ({m_replay0_out_1_tlast , m_replay0_out_0_tlast }),
+ .m_rfnoc_chdr_tvalid ({m_replay0_out_1_tvalid, m_replay0_out_0_tvalid}),
+ .m_rfnoc_chdr_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_duc0_in_0_tdata = m_ep0_out0_tdata ;
- assign s_duc0_in_0_tlast = m_ep0_out0_tlast ;
+ //---------------------------------------------------------------------------
+
+ assign s_duc0_in_0_tdata = m_ep0_out0_tdata;
+ assign s_duc0_in_0_tlast = m_ep0_out0_tlast;
assign s_duc0_in_0_tvalid = m_ep0_out0_tvalid;
assign m_ep0_out0_tready = s_duc0_in_0_tready;
- assign s_radio0_in_0_tdata = m_duc0_out_0_tdata ;
- assign s_radio0_in_0_tlast = m_duc0_out_0_tlast ;
+ assign s_radio0_in_0_tdata = m_duc0_out_0_tdata;
+ assign s_radio0_in_0_tlast = m_duc0_out_0_tlast;
assign s_radio0_in_0_tvalid = m_duc0_out_0_tvalid;
assign m_duc0_out_0_tready = s_radio0_in_0_tready;
- assign s_ddc0_in_0_tdata = m_radio0_out_0_tdata ;
- assign s_ddc0_in_0_tlast = m_radio0_out_0_tlast ;
+ assign s_ddc0_in_0_tdata = m_radio0_out_0_tdata;
+ assign s_ddc0_in_0_tlast = m_radio0_out_0_tlast;
assign s_ddc0_in_0_tvalid = m_radio0_out_0_tvalid;
assign m_radio0_out_0_tready = s_ddc0_in_0_tready;
- assign s_ep0_in0_tdata = m_ddc0_out_0_tdata ;
- assign s_ep0_in0_tlast = m_ddc0_out_0_tlast ;
+ assign s_ep0_in0_tdata = m_ddc0_out_0_tdata;
+ assign s_ep0_in0_tlast = m_ddc0_out_0_tlast;
assign s_ep0_in0_tvalid = m_ddc0_out_0_tvalid;
assign m_ddc0_out_0_tready = s_ep0_in0_tready;
- assign s_duc0_in_1_tdata = m_ep1_out0_tdata ;
- assign s_duc0_in_1_tlast = m_ep1_out0_tlast ;
+ assign s_duc0_in_1_tdata = m_ep1_out0_tdata;
+ assign s_duc0_in_1_tlast = m_ep1_out0_tlast;
assign s_duc0_in_1_tvalid = m_ep1_out0_tvalid;
assign m_ep1_out0_tready = s_duc0_in_1_tready;
- assign s_radio0_in_1_tdata = m_duc0_out_1_tdata ;
- assign s_radio0_in_1_tlast = m_duc0_out_1_tlast ;
+ assign s_radio0_in_1_tdata = m_duc0_out_1_tdata;
+ assign s_radio0_in_1_tlast = m_duc0_out_1_tlast;
assign s_radio0_in_1_tvalid = m_duc0_out_1_tvalid;
assign m_duc0_out_1_tready = s_radio0_in_1_tready;
- assign s_ddc0_in_1_tdata = m_radio0_out_1_tdata ;
- assign s_ddc0_in_1_tlast = m_radio0_out_1_tlast ;
+ assign s_ddc0_in_1_tdata = m_radio0_out_1_tdata;
+ assign s_ddc0_in_1_tlast = m_radio0_out_1_tlast;
assign s_ddc0_in_1_tvalid = m_radio0_out_1_tvalid;
assign m_radio0_out_1_tready = s_ddc0_in_1_tready;
- assign s_ep1_in0_tdata = m_ddc0_out_1_tdata ;
- assign s_ep1_in0_tlast = m_ddc0_out_1_tlast ;
+ assign s_ep1_in0_tdata = m_ddc0_out_1_tdata;
+ assign s_ep1_in0_tlast = m_ddc0_out_1_tlast;
assign s_ep1_in0_tvalid = m_ddc0_out_1_tvalid;
assign m_ddc0_out_1_tready = s_ep1_in0_tready;
- assign s_replay0_in_0_tdata = m_ep2_out0_tdata ;
- assign s_replay0_in_0_tlast = m_ep2_out0_tlast ;
+ assign s_replay0_in_0_tdata = m_ep2_out0_tdata;
+ assign s_replay0_in_0_tlast = m_ep2_out0_tlast;
assign s_replay0_in_0_tvalid = m_ep2_out0_tvalid;
assign m_ep2_out0_tready = s_replay0_in_0_tready;
- assign s_ep2_in0_tdata = m_replay0_out_0_tdata ;
- assign s_ep2_in0_tlast = m_replay0_out_0_tlast ;
+ assign s_ep2_in0_tdata = m_replay0_out_0_tdata;
+ assign s_ep2_in0_tlast = m_replay0_out_0_tlast;
assign s_ep2_in0_tvalid = m_replay0_out_0_tvalid;
assign m_replay0_out_0_tready = s_ep2_in0_tready;
- assign s_replay0_in_1_tdata = m_ep3_out0_tdata ;
- assign s_replay0_in_1_tlast = m_ep3_out0_tlast ;
+ assign s_replay0_in_1_tdata = m_ep3_out0_tdata;
+ assign s_replay0_in_1_tlast = m_ep3_out0_tlast;
assign s_replay0_in_1_tvalid = m_ep3_out0_tvalid;
assign m_ep3_out0_tready = s_replay0_in_1_tready;
- assign s_ep3_in0_tdata = m_replay0_out_1_tdata ;
- assign s_ep3_in0_tlast = m_replay0_out_1_tlast ;
+ assign s_ep3_in0_tdata = m_replay0_out_1_tdata;
+ assign s_ep3_in0_tlast = m_replay0_out_1_tlast;
assign s_ep3_in0_tvalid = m_replay0_out_1_tvalid;
assign m_replay0_out_1_tready = s_ep3_in0_tready;
- // ----------------------------------------------------
+ //---------------------------------------------------------------------------
// Unused Ports
- // ----------------------------------------------------
+ //---------------------------------------------------------------------------
+
- // ----------------------------------------------------
+
+ //---------------------------------------------------------------------------
// Clock Domains
- // ----------------------------------------------------
+ //---------------------------------------------------------------------------
+
assign radio0_radio_clk = radio_clk;
assign ddc0_ce_clk = rfnoc_chdr_clk;
assign duc0_ce_clk = rfnoc_chdr_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;
@@ -998,3 +1046,6 @@ module rfnoc_image_core #(
assign radio0_radio_time = radio_time;
endmodule
+
+
+`default_nettype wire
diff --git a/fpga/usrp3/top/n3xx/n300_rfnoc_image_core.vh b/fpga/usrp3/top/n3xx/n300_rfnoc_image_core.vh
new file mode 100644
index 000000000..4c2d73748
--- /dev/null
+++ b/fpga/usrp3/top/n3xx/n300_rfnoc_image_core.vh
@@ -0,0 +1,21 @@
+//
+// Copyright 2021 Ettus Research, A National Instruments Brand
+//
+// SPDX-License-Identifier: LGPL-3.0-or-later
+//
+// Header: rfnoc_image_core.vh (for n300)
+//
+// 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: 2021-05-03T08:51:08.505495
+// Source: n300_rfnoc_image_core.yml
+// Source SHA256: 64f2b862b3e60cb0456befb88ea28825b6bba271ff4e86a24ab618932773a861
+//
+
+`define CHDR_WIDTH 64
+`define RFNOC_PROTOVER { 8'd1, 8'd0 }
diff --git a/fpga/usrp3/top/n3xx/n310_bist_image_core.v b/fpga/usrp3/top/n3xx/n310_bist_image_core.v
index 64989fb3f..5d08da4af 100644
--- a/fpga/usrp3/top/n3xx/n310_bist_image_core.v
+++ b/fpga/usrp3/top/n3xx/n310_bist_image_core.v
@@ -1,19 +1,32 @@
//
-// Copyright 2019 Ettus Research, A National Instruments Brand
+// Copyright 2021 Ettus Research, A National Instruments Brand
//
// SPDX-License-Identifier: LGPL-3.0-or-later
//
-
// Module: rfnoc_image_core (for n310)
-// This file was autogenerated by UHD's image builder tool (rfnoc_image_builder)
-// Re-running that tool will overwrite this file!
-// File generated on: 2019-11-08T15:58:14.371732
-// Source: ./n3xx/n310_bist_image_core.yml
-// Source SHA256: 1a9ffb97d9678e700ad2aa172d206b6be9af30c7c0b014c21007d1de028a59d4
+//
+// 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: 2021-05-03T08:51:05.500549
+// Source: n310_bist_image_core.yml
+// Source SHA256: fe5a985fa2e6edde671a8fb818d11a583d818a74f707df9bb107901060780eea
+//
+
+`default_nettype none
+
module rfnoc_image_core #(
- parameter [15:0] PROTOVER = {8'd1, 8'd0}
-)(
+ parameter CHDR_W = 64,
+ parameter MTU = 10,
+ parameter [15:0] PROTOVER = {8'd1, 8'd0},
+ parameter RADIO_NIPC = 1
+) (
// Clocks
input wire chdr_aclk,
input wire ctrl_aclk,
@@ -21,131 +34,136 @@ module rfnoc_image_core #(
input wire radio_clk,
input wire dram_clk,
// Basic
- input wire [15:0] device_id,
-//// IO ports //////////////////////////////////
-// ctrlport_radio0
- output wire [ 1-1:0] m_ctrlport_radio0_req_wr,
- output wire [ 1-1:0] m_ctrlport_radio0_req_rd,
- output wire [ 20-1:0] m_ctrlport_radio0_req_addr,
- output wire [ 32-1:0] m_ctrlport_radio0_req_data,
- output wire [ 4-1:0] m_ctrlport_radio0_req_byte_en,
- output wire [ 1-1:0] m_ctrlport_radio0_req_has_time,
- output wire [ 64-1:0] m_ctrlport_radio0_req_time,
- input wire [ 1-1:0] m_ctrlport_radio0_resp_ack,
- input wire [ 2-1:0] m_ctrlport_radio0_resp_status,
- input wire [ 32-1:0] m_ctrlport_radio0_resp_data,
-// ctrlport_radio1
- output wire [ 1-1:0] m_ctrlport_radio1_req_wr,
- output wire [ 1-1:0] m_ctrlport_radio1_req_rd,
- output wire [ 20-1:0] m_ctrlport_radio1_req_addr,
- output wire [ 32-1:0] m_ctrlport_radio1_req_data,
- output wire [ 4-1:0] m_ctrlport_radio1_req_byte_en,
- output wire [ 1-1:0] m_ctrlport_radio1_req_has_time,
- output wire [ 64-1:0] m_ctrlport_radio1_req_time,
- input wire [ 1-1:0] m_ctrlport_radio1_resp_ack,
- input wire [ 2-1:0] m_ctrlport_radio1_resp_status,
- input wire [ 32-1:0] m_ctrlport_radio1_resp_data,
-// time_keeper
- input wire [ 64-1:0] radio_time,
-// x300_radio0
- input wire [ 64-1:0] radio_rx_data_radio0,
- input wire [ 2-1:0] radio_rx_stb_radio0,
- output wire [ 2-1:0] radio_rx_running_radio0,
- output wire [ 64-1:0] radio_tx_data_radio0,
- input wire [ 2-1:0] radio_tx_stb_radio0,
- output wire [ 2-1:0] radio_tx_running_radio0,
-// x300_radio1
- input wire [ 64-1:0] radio_rx_data_radio1,
- input wire [ 2-1:0] radio_rx_stb_radio1,
- output wire [ 2-1:0] radio_rx_running_radio1,
- output wire [ 64-1:0] radio_tx_data_radio1,
- input wire [ 2-1:0] radio_tx_stb_radio1,
- output wire [ 2-1:0] radio_tx_running_radio1,
-// dram
- input wire [ 1-1:0] axi_rst,
- output wire [ 4-1:0] m_axi_awid,
- output wire [128-1:0] m_axi_awaddr,
- output wire [ 32-1:0] m_axi_awlen,
- output wire [ 12-1:0] m_axi_awsize,
- output wire [ 8-1:0] m_axi_awburst,
- output wire [ 4-1:0] m_axi_awlock,
- output wire [ 16-1:0] m_axi_awcache,
- output wire [ 12-1:0] m_axi_awprot,
- output wire [ 16-1:0] m_axi_awqos,
- output wire [ 16-1:0] m_axi_awregion,
- output wire [ 4-1:0] m_axi_awuser,
- output wire [ 4-1:0] m_axi_awvalid,
- input wire [ 4-1:0] m_axi_awready,
- output wire [256-1:0] m_axi_wdata,
- output wire [ 32-1:0] m_axi_wstrb,
- output wire [ 4-1:0] m_axi_wlast,
- output wire [ 4-1:0] m_axi_wuser,
- output wire [ 4-1:0] m_axi_wvalid,
- input wire [ 4-1:0] m_axi_wready,
- input wire [ 4-1:0] m_axi_bid,
- input wire [ 8-1:0] m_axi_bresp,
- input wire [ 4-1:0] m_axi_buser,
- input wire [ 4-1:0] m_axi_bvalid,
- output wire [ 4-1:0] m_axi_bready,
- output wire [ 4-1:0] m_axi_arid,
- output wire [128-1:0] m_axi_araddr,
- output wire [ 32-1:0] m_axi_arlen,
- output wire [ 12-1:0] m_axi_arsize,
- output wire [ 8-1:0] m_axi_arburst,
- output wire [ 4-1:0] m_axi_arlock,
- output wire [ 16-1:0] m_axi_arcache,
- output wire [ 12-1:0] m_axi_arprot,
- output wire [ 16-1:0] m_axi_arqos,
- output wire [ 16-1:0] m_axi_arregion,
- output wire [ 4-1:0] m_axi_aruser,
- output wire [ 4-1:0] m_axi_arvalid,
- input wire [ 4-1:0] m_axi_arready,
- input wire [ 4-1:0] m_axi_rid,
- input wire [256-1:0] m_axi_rdata,
- input wire [ 8-1:0] m_axi_rresp,
- input wire [ 4-1:0] m_axi_rlast,
- input wire [ 4-1:0] m_axi_ruser,
- input wire [ 4-1:0] m_axi_rvalid,
- output wire [ 4-1:0] m_axi_rready,
- // Transport 0 (eth0 1G)
- input wire [64-1:0] s_eth0_tdata,
- input wire s_eth0_tlast,
- input wire s_eth0_tvalid,
- output wire s_eth0_tready,
- output wire [64-1:0] m_eth0_tdata,
- output wire m_eth0_tlast,
- output wire m_eth0_tvalid,
- input wire m_eth0_tready,
- // Transport 1 (eth1 10G)
- input wire [64-1:0] s_eth1_tdata,
- input wire s_eth1_tlast,
- input wire s_eth1_tvalid,
- output wire s_eth1_tready,
- output wire [64-1:0] m_eth1_tdata,
- output wire m_eth1_tlast,
- output wire m_eth1_tvalid,
- input wire m_eth1_tready,
- // Transport 2 (dma dma)
- input wire [64-1:0] s_dma_tdata,
- input wire s_dma_tlast,
- input wire s_dma_tvalid,
- output wire s_dma_tready,
- output wire [64-1:0] m_dma_tdata,
- output wire m_dma_tlast,
- output wire m_dma_tvalid,
- input wire m_dma_tready
+ 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_keeper
+ input wire [ 63:0] radio_time,
+ // x300_radio0
+ input wire [ 63:0] radio_rx_data_radio0,
+ input wire [ 1:0] radio_rx_stb_radio0,
+ output wire [ 1:0] radio_rx_running_radio0,
+ output wire [ 63:0] radio_tx_data_radio0,
+ input wire [ 1:0] radio_tx_stb_radio0,
+ output wire [ 1:0] radio_tx_running_radio0,
+ // x300_radio1
+ input wire [ 63:0] radio_rx_data_radio1,
+ input wire [ 1:0] radio_rx_stb_radio1,
+ output wire [ 1:0] radio_rx_running_radio1,
+ output wire [ 63:0] radio_tx_data_radio1,
+ input wire [ 1:0] radio_tx_stb_radio1,
+ output wire [ 1:0] radio_tx_running_radio1,
+ // dram
+ input wire [ 0:0] axi_rst,
+ output wire [ 3:0] m_axi_awid,
+ output wire [ 127: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 [ 255:0] m_axi_wdata,
+ output wire [ 31: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 [ 127: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 [ 255: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 (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 CHDR_W = 64;
- localparam MTU = 10;
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;
@@ -210,12 +228,12 @@ module rfnoc_image_core #(
.clk (rfnoc_chdr_clk),
.reset (rfnoc_chdr_rst),
.device_id (device_id),
- .s_axis_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_eth1_tdata, s_eth0_tdata}),
- .s_axis_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_eth1_tlast, s_eth0_tlast}),
+ .s_axis_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_eth1_tdata , s_eth0_tdata }),
+ .s_axis_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_eth1_tlast , s_eth0_tlast }),
.s_axis_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_eth1_tvalid, s_eth0_tvalid}),
.s_axis_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_eth1_tready, s_eth0_tready}),
- .m_axis_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_eth1_tdata, m_eth0_tdata}),
- .m_axis_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_eth1_tlast, m_eth0_tlast}),
+ .m_axis_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_eth1_tdata , m_eth0_tdata }),
+ .m_axis_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_eth1_tlast , m_eth0_tlast }),
.m_axis_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_eth1_tvalid, m_eth0_tvalid}),
.m_axis_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_eth1_tready, m_eth0_tready}),
.ext_rtcfg_stb (1'h0),
@@ -224,9 +242,18 @@ module rfnoc_image_core #(
.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 = 16384;
+ 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;
@@ -236,8 +263,8 @@ module rfnoc_image_core #(
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 [ 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;
@@ -250,23 +277,23 @@ module rfnoc_image_core #(
.NUM_DATA_O (1),
.INST_NUM (0),
.CTRL_XBAR_PORT (1),
- .INGRESS_BUFF_SIZE (14),
+ .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 ),
+ .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}),
@@ -275,20 +302,28 @@ module rfnoc_image_core #(
.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_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_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 )
+ .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 = 16384;
+ 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;
@@ -297,8 +332,8 @@ module rfnoc_image_core #(
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 [ 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;
@@ -311,23 +346,23 @@ module rfnoc_image_core #(
.NUM_DATA_O (1),
.INST_NUM (1),
.CTRL_XBAR_PORT (2),
- .INGRESS_BUFF_SIZE (14),
+ .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 ),
+ .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}),
@@ -336,20 +371,28 @@ module rfnoc_image_core #(
.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_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_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 )
+ .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 = 16384;
+ 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;
@@ -358,8 +401,8 @@ module rfnoc_image_core #(
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 [ 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;
@@ -372,23 +415,23 @@ module rfnoc_image_core #(
.NUM_DATA_O (1),
.INST_NUM (2),
.CTRL_XBAR_PORT (3),
- .INGRESS_BUFF_SIZE (14),
+ .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 ),
+ .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}),
@@ -397,20 +440,28 @@ module rfnoc_image_core #(
.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_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_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 )
+ .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 = 16384;
+ 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;
@@ -419,8 +470,8 @@ module rfnoc_image_core #(
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 [ 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;
@@ -433,23 +484,23 @@ module rfnoc_image_core #(
.NUM_DATA_O (1),
.INST_NUM (3),
.CTRL_XBAR_PORT (4),
- .INGRESS_BUFF_SIZE (14),
+ .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 ),
+ .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}),
@@ -458,20 +509,28 @@ module rfnoc_image_core #(
.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_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_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 )
+ .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 = 16384;
+ 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;
@@ -480,8 +539,8 @@ module rfnoc_image_core #(
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 [ 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;
@@ -494,23 +553,23 @@ module rfnoc_image_core #(
.NUM_DATA_O (1),
.INST_NUM (4),
.CTRL_XBAR_PORT (5),
- .INGRESS_BUFF_SIZE (14),
+ .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 ),
+ .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}),
@@ -519,20 +578,28 @@ module rfnoc_image_core #(
.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_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_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 )
+ .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 = 16384;
+ 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;
@@ -541,8 +608,8 @@ module rfnoc_image_core #(
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 [ 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;
@@ -555,23 +622,23 @@ module rfnoc_image_core #(
.NUM_DATA_O (1),
.INST_NUM (5),
.CTRL_XBAR_PORT (6),
- .INGRESS_BUFF_SIZE (14),
+ .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 ),
+ .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}),
@@ -580,42 +647,41 @@ module rfnoc_image_core #(
.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_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_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 )
+ .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_fifo0_ctrl_tdata , s_fifo0_ctrl_tdata ;
- wire m_fifo0_ctrl_tlast , s_fifo0_ctrl_tlast ;
- wire m_fifo0_ctrl_tvalid, s_fifo0_ctrl_tvalid;
- wire m_fifo0_ctrl_tready, s_fifo0_ctrl_tready;
+ //---------------------------------------------------------------------------
+
+ 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_fifo0_ctrl_tdata, s_fifo0_ctrl_tdata;
+ wire m_fifo0_ctrl_tlast, s_fifo0_ctrl_tlast;
+ wire m_fifo0_ctrl_tvalid, s_fifo0_ctrl_tvalid;
+ wire m_fifo0_ctrl_tready, s_fifo0_ctrl_tready;
axis_ctrl_crossbar_nxn #(
.WIDTH (32),
@@ -639,9 +705,11 @@ module rfnoc_image_core #(
.deadlock_detected()
);
- // ----------------------------------------------------
+
+ //---------------------------------------------------------------------------
// RFNoC Core Kernel
- // ----------------------------------------------------
+ //---------------------------------------------------------------------------
+
wire [(512*3)-1:0] rfnoc_core_config, rfnoc_core_status;
rfnoc_core_kernel #(
@@ -666,12 +734,12 @@ module rfnoc_image_core #(
.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_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_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),
@@ -679,13 +747,15 @@ module rfnoc_image_core #(
.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 ;
@@ -696,79 +766,77 @@ module rfnoc_image_core #(
wire m_radio0_out_1_tvalid, m_radio0_out_0_tvalid;
wire m_radio0_out_1_tready, m_radio0_out_0_tready;
- // ctrl_port
- wire [ 1-1:0] radio0_m_ctrlport_req_wr;
- wire [ 1-1:0] radio0_m_ctrlport_req_rd;
- wire [ 20-1:0] radio0_m_ctrlport_req_addr;
- wire [ 32-1:0] radio0_m_ctrlport_req_data;
- wire [ 4-1:0] radio0_m_ctrlport_req_byte_en;
- wire [ 1-1:0] radio0_m_ctrlport_req_has_time;
- wire [ 64-1:0] radio0_m_ctrlport_req_time;
- wire [ 1-1:0] radio0_m_ctrlport_resp_ack;
- wire [ 2-1:0] radio0_m_ctrlport_resp_status;
- wire [ 32-1:0] radio0_m_ctrlport_resp_data;
- // time_keeper
- wire [ 64-1:0] radio0_radio_time;
- // x300_radio
- wire [ 64-1:0] radio0_radio_rx_data;
- wire [ 2-1:0] radio0_radio_rx_stb;
- wire [ 2-1:0] radio0_radio_rx_running;
- wire [ 64-1:0] radio0_radio_tx_data;
- wire [ 2-1:0] radio0_radio_tx_stb;
- wire [ 2-1:0] radio0_radio_tx_running;
+ // ctrl_port
+ 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_keeper
+ wire [ 63:0] radio0_radio_time;
+ // x300_radio
+ wire [ 63:0] radio0_radio_rx_data;
+ wire [ 1:0] radio0_radio_rx_stb;
+ wire [ 1:0] radio0_radio_rx_running;
+ wire [ 63:0] radio0_radio_tx_data;
+ wire [ 1:0] radio0_radio_tx_stb;
+ wire [ 1:0] radio0_radio_tx_running;
rfnoc_block_radio #(
- .THIS_PORTID(2),
- .CHDR_W(CHDR_W),
- .NUM_PORTS(2),
- .MTU(MTU)
+ .THIS_PORTID (2),
+ .CHDR_W (CHDR_W),
+ .NUM_PORTS (2),
+ .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),
+ .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_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)
+ .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 ;
@@ -779,79 +847,77 @@ module rfnoc_image_core #(
wire m_radio1_out_1_tvalid, m_radio1_out_0_tvalid;
wire m_radio1_out_1_tready, m_radio1_out_0_tready;
- // ctrl_port
- wire [ 1-1:0] radio1_m_ctrlport_req_wr;
- wire [ 1-1:0] radio1_m_ctrlport_req_rd;
- wire [ 20-1:0] radio1_m_ctrlport_req_addr;
- wire [ 32-1:0] radio1_m_ctrlport_req_data;
- wire [ 4-1:0] radio1_m_ctrlport_req_byte_en;
- wire [ 1-1:0] radio1_m_ctrlport_req_has_time;
- wire [ 64-1:0] radio1_m_ctrlport_req_time;
- wire [ 1-1:0] radio1_m_ctrlport_resp_ack;
- wire [ 2-1:0] radio1_m_ctrlport_resp_status;
- wire [ 32-1:0] radio1_m_ctrlport_resp_data;
- // time_keeper
- wire [ 64-1:0] radio1_radio_time;
- // x300_radio
- wire [ 64-1:0] radio1_radio_rx_data;
- wire [ 2-1:0] radio1_radio_rx_stb;
- wire [ 2-1:0] radio1_radio_rx_running;
- wire [ 64-1:0] radio1_radio_tx_data;
- wire [ 2-1:0] radio1_radio_tx_stb;
- wire [ 2-1:0] radio1_radio_tx_running;
+ // ctrl_port
+ 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_keeper
+ wire [ 63:0] radio1_radio_time;
+ // x300_radio
+ wire [ 63:0] radio1_radio_rx_data;
+ wire [ 1:0] radio1_radio_rx_stb;
+ wire [ 1:0] radio1_radio_rx_running;
+ wire [ 63:0] radio1_radio_tx_data;
+ wire [ 1:0] radio1_radio_tx_stb;
+ wire [ 1:0] radio1_radio_tx_running;
rfnoc_block_radio #(
- .THIS_PORTID(3),
- .CHDR_W(CHDR_W),
- .NUM_PORTS(2),
- .MTU(MTU)
+ .THIS_PORTID (3),
+ .CHDR_W (CHDR_W),
+ .NUM_PORTS (2),
+ .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),
+ .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_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)
+ .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)
);
-
- // ----------------------------------------------------
+ //-----------------------------------
// fifo0
- // ----------------------------------------------------
+ //-----------------------------------
+
wire fifo0_mem_clk;
wire [CHDR_W-1:0] s_fifo0_in_3_tdata , s_fifo0_in_2_tdata , s_fifo0_in_1_tdata , s_fifo0_in_0_tdata ;
wire s_fifo0_in_3_tlast , s_fifo0_in_2_tlast , s_fifo0_in_1_tlast , s_fifo0_in_0_tlast ;
@@ -862,202 +928,201 @@ module rfnoc_image_core #(
wire m_fifo0_out_3_tvalid, m_fifo0_out_2_tvalid, m_fifo0_out_1_tvalid, m_fifo0_out_0_tvalid;
wire m_fifo0_out_3_tready, m_fifo0_out_2_tready, m_fifo0_out_1_tready, m_fifo0_out_0_tready;
- // axi_ram
- wire [ 1-1:0] fifo0_axi_rst;
- wire [ 4-1:0] fifo0_m_axi_awid;
- wire [128-1:0] fifo0_m_axi_awaddr;
- wire [ 32-1:0] fifo0_m_axi_awlen;
- wire [ 12-1:0] fifo0_m_axi_awsize;
- wire [ 8-1:0] fifo0_m_axi_awburst;
- wire [ 4-1:0] fifo0_m_axi_awlock;
- wire [ 16-1:0] fifo0_m_axi_awcache;
- wire [ 12-1:0] fifo0_m_axi_awprot;
- wire [ 16-1:0] fifo0_m_axi_awqos;
- wire [ 16-1:0] fifo0_m_axi_awregion;
- wire [ 4-1:0] fifo0_m_axi_awuser;
- wire [ 4-1:0] fifo0_m_axi_awvalid;
- wire [ 4-1:0] fifo0_m_axi_awready;
- wire [256-1:0] fifo0_m_axi_wdata;
- wire [ 32-1:0] fifo0_m_axi_wstrb;
- wire [ 4-1:0] fifo0_m_axi_wlast;
- wire [ 4-1:0] fifo0_m_axi_wuser;
- wire [ 4-1:0] fifo0_m_axi_wvalid;
- wire [ 4-1:0] fifo0_m_axi_wready;
- wire [ 4-1:0] fifo0_m_axi_bid;
- wire [ 8-1:0] fifo0_m_axi_bresp;
- wire [ 4-1:0] fifo0_m_axi_buser;
- wire [ 4-1:0] fifo0_m_axi_bvalid;
- wire [ 4-1:0] fifo0_m_axi_bready;
- wire [ 4-1:0] fifo0_m_axi_arid;
- wire [128-1:0] fifo0_m_axi_araddr;
- wire [ 32-1:0] fifo0_m_axi_arlen;
- wire [ 12-1:0] fifo0_m_axi_arsize;
- wire [ 8-1:0] fifo0_m_axi_arburst;
- wire [ 4-1:0] fifo0_m_axi_arlock;
- wire [ 16-1:0] fifo0_m_axi_arcache;
- wire [ 12-1:0] fifo0_m_axi_arprot;
- wire [ 16-1:0] fifo0_m_axi_arqos;
- wire [ 16-1:0] fifo0_m_axi_arregion;
- wire [ 4-1:0] fifo0_m_axi_aruser;
- wire [ 4-1:0] fifo0_m_axi_arvalid;
- wire [ 4-1:0] fifo0_m_axi_arready;
- wire [ 4-1:0] fifo0_m_axi_rid;
- wire [256-1:0] fifo0_m_axi_rdata;
- wire [ 8-1:0] fifo0_m_axi_rresp;
- wire [ 4-1:0] fifo0_m_axi_rlast;
- wire [ 4-1:0] fifo0_m_axi_ruser;
- wire [ 4-1:0] fifo0_m_axi_rvalid;
- wire [ 4-1:0] fifo0_m_axi_rready;
+ // axi_ram
+ wire [ 0:0] fifo0_axi_rst;
+ wire [ 3:0] fifo0_m_axi_awid;
+ wire [ 127:0] fifo0_m_axi_awaddr;
+ wire [ 31:0] fifo0_m_axi_awlen;
+ wire [ 11:0] fifo0_m_axi_awsize;
+ wire [ 7:0] fifo0_m_axi_awburst;
+ wire [ 3:0] fifo0_m_axi_awlock;
+ wire [ 15:0] fifo0_m_axi_awcache;
+ wire [ 11:0] fifo0_m_axi_awprot;
+ wire [ 15:0] fifo0_m_axi_awqos;
+ wire [ 15:0] fifo0_m_axi_awregion;
+ wire [ 3:0] fifo0_m_axi_awuser;
+ wire [ 3:0] fifo0_m_axi_awvalid;
+ wire [ 3:0] fifo0_m_axi_awready;
+ wire [ 255:0] fifo0_m_axi_wdata;
+ wire [ 31:0] fifo0_m_axi_wstrb;
+ wire [ 3:0] fifo0_m_axi_wlast;
+ wire [ 3:0] fifo0_m_axi_wuser;
+ wire [ 3:0] fifo0_m_axi_wvalid;
+ wire [ 3:0] fifo0_m_axi_wready;
+ wire [ 3:0] fifo0_m_axi_bid;
+ wire [ 7:0] fifo0_m_axi_bresp;
+ wire [ 3:0] fifo0_m_axi_buser;
+ wire [ 3:0] fifo0_m_axi_bvalid;
+ wire [ 3:0] fifo0_m_axi_bready;
+ wire [ 3:0] fifo0_m_axi_arid;
+ wire [ 127:0] fifo0_m_axi_araddr;
+ wire [ 31:0] fifo0_m_axi_arlen;
+ wire [ 11:0] fifo0_m_axi_arsize;
+ wire [ 7:0] fifo0_m_axi_arburst;
+ wire [ 3:0] fifo0_m_axi_arlock;
+ wire [ 15:0] fifo0_m_axi_arcache;
+ wire [ 11:0] fifo0_m_axi_arprot;
+ wire [ 15:0] fifo0_m_axi_arqos;
+ wire [ 15:0] fifo0_m_axi_arregion;
+ wire [ 3:0] fifo0_m_axi_aruser;
+ wire [ 3:0] fifo0_m_axi_arvalid;
+ wire [ 3:0] fifo0_m_axi_arready;
+ wire [ 3:0] fifo0_m_axi_rid;
+ wire [ 255:0] fifo0_m_axi_rdata;
+ wire [ 7:0] fifo0_m_axi_rresp;
+ wire [ 3:0] fifo0_m_axi_rlast;
+ wire [ 3:0] fifo0_m_axi_ruser;
+ wire [ 3:0] fifo0_m_axi_rvalid;
+ wire [ 3:0] fifo0_m_axi_rready;
rfnoc_block_axi_ram_fifo #(
- .THIS_PORTID(4),
- .CHDR_W(CHDR_W),
- .NUM_PORTS(4),
- .MEM_DATA_W(64),
- .MEM_ADDR_W(31),
- .FIFO_ADDR_BASE({30'h06000000, 30'h04000000, 30'h02000000, 30'h00000000}),
- .FIFO_ADDR_MASK({30'h01FFFFFF, 30'h01FFFFFF, 30'h01FFFFFF, 30'h01FFFFFF}),
- .MEM_CLK_RATE(303819444),
- .MTU(MTU)
+ .THIS_PORTID (4),
+ .CHDR_W (CHDR_W),
+ .NUM_PORTS (4),
+ .MEM_DATA_W (64),
+ .MEM_ADDR_W (31),
+ .FIFO_ADDR_BASE ({30'h06000000, 30'h04000000, 30'h02000000, 30'h00000000}),
+ .FIFO_ADDR_MASK ({30'h01FFFFFF, 30'h01FFFFFF, 30'h01FFFFFF, 30'h01FFFFFF}),
+ .MEM_CLK_RATE (303819444),
+ .MTU (MTU)
) b_fifo0_2 (
- .rfnoc_chdr_clk (rfnoc_chdr_clk),
- .rfnoc_ctrl_clk (rfnoc_ctrl_clk),
- .mem_clk(fifo0_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(fifo0_axi_rst),
- .m_axi_awid(fifo0_m_axi_awid),
- .m_axi_awaddr(fifo0_m_axi_awaddr),
- .m_axi_awlen(fifo0_m_axi_awlen),
- .m_axi_awsize(fifo0_m_axi_awsize),
- .m_axi_awburst(fifo0_m_axi_awburst),
- .m_axi_awlock(fifo0_m_axi_awlock),
- .m_axi_awcache(fifo0_m_axi_awcache),
- .m_axi_awprot(fifo0_m_axi_awprot),
- .m_axi_awqos(fifo0_m_axi_awqos),
- .m_axi_awregion(fifo0_m_axi_awregion),
- .m_axi_awuser(fifo0_m_axi_awuser),
- .m_axi_awvalid(fifo0_m_axi_awvalid),
- .m_axi_awready(fifo0_m_axi_awready),
- .m_axi_wdata(fifo0_m_axi_wdata),
- .m_axi_wstrb(fifo0_m_axi_wstrb),
- .m_axi_wlast(fifo0_m_axi_wlast),
- .m_axi_wuser(fifo0_m_axi_wuser),
- .m_axi_wvalid(fifo0_m_axi_wvalid),
- .m_axi_wready(fifo0_m_axi_wready),
- .m_axi_bid(fifo0_m_axi_bid),
- .m_axi_bresp(fifo0_m_axi_bresp),
- .m_axi_buser(fifo0_m_axi_buser),
- .m_axi_bvalid(fifo0_m_axi_bvalid),
- .m_axi_bready(fifo0_m_axi_bready),
- .m_axi_arid(fifo0_m_axi_arid),
- .m_axi_araddr(fifo0_m_axi_araddr),
- .m_axi_arlen(fifo0_m_axi_arlen),
- .m_axi_arsize(fifo0_m_axi_arsize),
- .m_axi_arburst(fifo0_m_axi_arburst),
- .m_axi_arlock(fifo0_m_axi_arlock),
- .m_axi_arcache(fifo0_m_axi_arcache),
- .m_axi_arprot(fifo0_m_axi_arprot),
- .m_axi_arqos(fifo0_m_axi_arqos),
- .m_axi_arregion(fifo0_m_axi_arregion),
- .m_axi_aruser(fifo0_m_axi_aruser),
- .m_axi_arvalid(fifo0_m_axi_arvalid),
- .m_axi_arready(fifo0_m_axi_arready),
- .m_axi_rid(fifo0_m_axi_rid),
- .m_axi_rdata(fifo0_m_axi_rdata),
- .m_axi_rresp(fifo0_m_axi_rresp),
- .m_axi_rlast(fifo0_m_axi_rlast),
- .m_axi_ruser(fifo0_m_axi_ruser),
- .m_axi_rvalid(fifo0_m_axi_rvalid),
- .m_axi_rready(fifo0_m_axi_rready),
-
- .s_rfnoc_chdr_tdata ({s_fifo0_in_3_tdata , s_fifo0_in_2_tdata , s_fifo0_in_1_tdata , s_fifo0_in_0_tdata }),
- .s_rfnoc_chdr_tlast ({s_fifo0_in_3_tlast , s_fifo0_in_2_tlast , s_fifo0_in_1_tlast , s_fifo0_in_0_tlast }),
- .s_rfnoc_chdr_tvalid({s_fifo0_in_3_tvalid, s_fifo0_in_2_tvalid, s_fifo0_in_1_tvalid, s_fifo0_in_0_tvalid}),
- .s_rfnoc_chdr_tready({s_fifo0_in_3_tready, s_fifo0_in_2_tready, s_fifo0_in_1_tready, s_fifo0_in_0_tready}),
- .m_rfnoc_chdr_tdata ({m_fifo0_out_3_tdata , m_fifo0_out_2_tdata , m_fifo0_out_1_tdata , m_fifo0_out_0_tdata }),
- .m_rfnoc_chdr_tlast ({m_fifo0_out_3_tlast , m_fifo0_out_2_tlast , m_fifo0_out_1_tlast , m_fifo0_out_0_tlast }),
- .m_rfnoc_chdr_tvalid({m_fifo0_out_3_tvalid, m_fifo0_out_2_tvalid, m_fifo0_out_1_tvalid, m_fifo0_out_0_tvalid}),
- .m_rfnoc_chdr_tready({m_fifo0_out_3_tready, m_fifo0_out_2_tready, m_fifo0_out_1_tready, m_fifo0_out_0_tready}),
- .s_rfnoc_ctrl_tdata (s_fifo0_ctrl_tdata ),
- .s_rfnoc_ctrl_tlast (s_fifo0_ctrl_tlast ),
- .s_rfnoc_ctrl_tvalid(s_fifo0_ctrl_tvalid),
- .s_rfnoc_ctrl_tready(s_fifo0_ctrl_tready),
- .m_rfnoc_ctrl_tdata (m_fifo0_ctrl_tdata ),
- .m_rfnoc_ctrl_tlast (m_fifo0_ctrl_tlast ),
- .m_rfnoc_ctrl_tvalid(m_fifo0_ctrl_tvalid),
- .m_rfnoc_ctrl_tready(m_fifo0_ctrl_tready)
+ .rfnoc_chdr_clk (rfnoc_chdr_clk),
+ .rfnoc_ctrl_clk (rfnoc_ctrl_clk),
+ .mem_clk (fifo0_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 (fifo0_axi_rst),
+ .m_axi_awid (fifo0_m_axi_awid),
+ .m_axi_awaddr (fifo0_m_axi_awaddr),
+ .m_axi_awlen (fifo0_m_axi_awlen),
+ .m_axi_awsize (fifo0_m_axi_awsize),
+ .m_axi_awburst (fifo0_m_axi_awburst),
+ .m_axi_awlock (fifo0_m_axi_awlock),
+ .m_axi_awcache (fifo0_m_axi_awcache),
+ .m_axi_awprot (fifo0_m_axi_awprot),
+ .m_axi_awqos (fifo0_m_axi_awqos),
+ .m_axi_awregion (fifo0_m_axi_awregion),
+ .m_axi_awuser (fifo0_m_axi_awuser),
+ .m_axi_awvalid (fifo0_m_axi_awvalid),
+ .m_axi_awready (fifo0_m_axi_awready),
+ .m_axi_wdata (fifo0_m_axi_wdata),
+ .m_axi_wstrb (fifo0_m_axi_wstrb),
+ .m_axi_wlast (fifo0_m_axi_wlast),
+ .m_axi_wuser (fifo0_m_axi_wuser),
+ .m_axi_wvalid (fifo0_m_axi_wvalid),
+ .m_axi_wready (fifo0_m_axi_wready),
+ .m_axi_bid (fifo0_m_axi_bid),
+ .m_axi_bresp (fifo0_m_axi_bresp),
+ .m_axi_buser (fifo0_m_axi_buser),
+ .m_axi_bvalid (fifo0_m_axi_bvalid),
+ .m_axi_bready (fifo0_m_axi_bready),
+ .m_axi_arid (fifo0_m_axi_arid),
+ .m_axi_araddr (fifo0_m_axi_araddr),
+ .m_axi_arlen (fifo0_m_axi_arlen),
+ .m_axi_arsize (fifo0_m_axi_arsize),
+ .m_axi_arburst (fifo0_m_axi_arburst),
+ .m_axi_arlock (fifo0_m_axi_arlock),
+ .m_axi_arcache (fifo0_m_axi_arcache),
+ .m_axi_arprot (fifo0_m_axi_arprot),
+ .m_axi_arqos (fifo0_m_axi_arqos),
+ .m_axi_arregion (fifo0_m_axi_arregion),
+ .m_axi_aruser (fifo0_m_axi_aruser),
+ .m_axi_arvalid (fifo0_m_axi_arvalid),
+ .m_axi_arready (fifo0_m_axi_arready),
+ .m_axi_rid (fifo0_m_axi_rid),
+ .m_axi_rdata (fifo0_m_axi_rdata),
+ .m_axi_rresp (fifo0_m_axi_rresp),
+ .m_axi_rlast (fifo0_m_axi_rlast),
+ .m_axi_ruser (fifo0_m_axi_ruser),
+ .m_axi_rvalid (fifo0_m_axi_rvalid),
+ .m_axi_rready (fifo0_m_axi_rready),
+ .s_rfnoc_chdr_tdata ({s_fifo0_in_3_tdata , s_fifo0_in_2_tdata , s_fifo0_in_1_tdata , s_fifo0_in_0_tdata }),
+ .s_rfnoc_chdr_tlast ({s_fifo0_in_3_tlast , s_fifo0_in_2_tlast , s_fifo0_in_1_tlast , s_fifo0_in_0_tlast }),
+ .s_rfnoc_chdr_tvalid ({s_fifo0_in_3_tvalid, s_fifo0_in_2_tvalid, s_fifo0_in_1_tvalid, s_fifo0_in_0_tvalid}),
+ .s_rfnoc_chdr_tready ({s_fifo0_in_3_tready, s_fifo0_in_2_tready, s_fifo0_in_1_tready, s_fifo0_in_0_tready}),
+ .m_rfnoc_chdr_tdata ({m_fifo0_out_3_tdata , m_fifo0_out_2_tdata , m_fifo0_out_1_tdata , m_fifo0_out_0_tdata }),
+ .m_rfnoc_chdr_tlast ({m_fifo0_out_3_tlast , m_fifo0_out_2_tlast , m_fifo0_out_1_tlast , m_fifo0_out_0_tlast }),
+ .m_rfnoc_chdr_tvalid ({m_fifo0_out_3_tvalid, m_fifo0_out_2_tvalid, m_fifo0_out_1_tvalid, m_fifo0_out_0_tvalid}),
+ .m_rfnoc_chdr_tready ({m_fifo0_out_3_tready, m_fifo0_out_2_tready, m_fifo0_out_1_tready, m_fifo0_out_0_tready}),
+ .s_rfnoc_ctrl_tdata (s_fifo0_ctrl_tdata),
+ .s_rfnoc_ctrl_tlast (s_fifo0_ctrl_tlast),
+ .s_rfnoc_ctrl_tvalid (s_fifo0_ctrl_tvalid),
+ .s_rfnoc_ctrl_tready (s_fifo0_ctrl_tready),
+ .m_rfnoc_ctrl_tdata (m_fifo0_ctrl_tdata),
+ .m_rfnoc_ctrl_tlast (m_fifo0_ctrl_tlast),
+ .m_rfnoc_ctrl_tvalid (m_fifo0_ctrl_tvalid),
+ .m_rfnoc_ctrl_tready (m_fifo0_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_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_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_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_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_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_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_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_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_fifo0_in_0_tdata = m_ep4_out0_tdata ;
- assign s_fifo0_in_0_tlast = m_ep4_out0_tlast ;
+ assign s_fifo0_in_0_tdata = m_ep4_out0_tdata;
+ assign s_fifo0_in_0_tlast = m_ep4_out0_tlast;
assign s_fifo0_in_0_tvalid = m_ep4_out0_tvalid;
assign m_ep4_out0_tready = s_fifo0_in_0_tready;
- assign s_ep4_in0_tdata = m_fifo0_out_0_tdata ;
- assign s_ep4_in0_tlast = m_fifo0_out_0_tlast ;
+ assign s_ep4_in0_tdata = m_fifo0_out_0_tdata;
+ assign s_ep4_in0_tlast = m_fifo0_out_0_tlast;
assign s_ep4_in0_tvalid = m_fifo0_out_0_tvalid;
assign m_fifo0_out_0_tready = s_ep4_in0_tready;
- assign s_fifo0_in_1_tdata = m_ep5_out0_tdata ;
- assign s_fifo0_in_1_tlast = m_ep5_out0_tlast ;
+ assign s_fifo0_in_1_tdata = m_ep5_out0_tdata;
+ assign s_fifo0_in_1_tlast = m_ep5_out0_tlast;
assign s_fifo0_in_1_tvalid = m_ep5_out0_tvalid;
assign m_ep5_out0_tready = s_fifo0_in_1_tready;
- assign s_ep5_in0_tdata = m_fifo0_out_1_tdata ;
- assign s_ep5_in0_tlast = m_fifo0_out_1_tlast ;
+ assign s_ep5_in0_tdata = m_fifo0_out_1_tdata;
+ assign s_ep5_in0_tlast = m_fifo0_out_1_tlast;
assign s_ep5_in0_tvalid = m_fifo0_out_1_tvalid;
assign m_fifo0_out_1_tready = s_ep5_in0_tready;
- // ----------------------------------------------------
+ //---------------------------------------------------------------------------
// Unused Ports
- // ----------------------------------------------------
+ //---------------------------------------------------------------------------
+
assign s_fifo0_in_2_tdata = {CHDR_W{1'b0}};
assign s_fifo0_in_2_tlast = 1'b0;
assign s_fifo0_in_2_tvalid = 1'b0;
@@ -1067,17 +1132,20 @@ module rfnoc_image_core #(
assign m_fifo0_out_2_tready = 1'b1;
assign m_fifo0_out_3_tready = 1'b1;
- // ----------------------------------------------------
+
+ //---------------------------------------------------------------------------
// Clock Domains
- // ----------------------------------------------------
+ //---------------------------------------------------------------------------
+
assign radio0_radio_clk = radio_clk;
assign radio1_radio_clk = radio_clk;
assign fifo0_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;
@@ -1167,3 +1235,6 @@ module rfnoc_image_core #(
assign radio1_radio_time = radio_time;
endmodule
+
+
+`default_nettype wire
diff --git a/fpga/usrp3/top/n3xx/n310_rfnoc_image_core.v b/fpga/usrp3/top/n3xx/n310_rfnoc_image_core.v
index 3ded945ac..63fdc6b70 100644
--- a/fpga/usrp3/top/n3xx/n310_rfnoc_image_core.v
+++ b/fpga/usrp3/top/n3xx/n310_rfnoc_image_core.v
@@ -1,19 +1,32 @@
//
-// Copyright 2020 Ettus Research, A National Instruments Brand
+// Copyright 2021 Ettus Research, A National Instruments Brand
//
// SPDX-License-Identifier: LGPL-3.0-or-later
//
-
// Module: rfnoc_image_core (for n310)
-// This file was autogenerated by UHD's image builder tool (rfnoc_image_builder)
-// Re-running that tool will overwrite this file!
-// File generated on: 2020-09-02T12:03:00.129190
-// Source: ./n310_rfnoc_image_core.yml
-// Source SHA256: 39427a6d2533bc5342e99d75d7eaff9368e89ab8ff639821d333143af5ace45b
+//
+// 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: 2021-05-03T08:51:09.232810
+// Source: n310_rfnoc_image_core.yml
+// Source SHA256: cc561a3de48fea9e224425413802738d125393f55f6dd46e196db8fdabe09284
+//
+
+`default_nettype none
+
module rfnoc_image_core #(
- parameter [15:0] PROTOVER = {8'd1, 8'd0}
-)(
+ parameter CHDR_W = 64,
+ parameter MTU = 10,
+ parameter [15:0] PROTOVER = {8'd1, 8'd0},
+ parameter RADIO_NIPC = 1
+) (
// Clocks
input wire chdr_aclk,
input wire ctrl_aclk,
@@ -21,131 +34,136 @@ module rfnoc_image_core #(
input wire radio_clk,
input wire dram_clk,
// Basic
- input wire [15:0] device_id,
-//// IO ports //////////////////////////////////
-// ctrlport_radio0
- output wire [ 1-1:0] m_ctrlport_radio0_req_wr,
- output wire [ 1-1:0] m_ctrlport_radio0_req_rd,
- output wire [ 20-1:0] m_ctrlport_radio0_req_addr,
- output wire [ 32-1:0] m_ctrlport_radio0_req_data,
- output wire [ 4-1:0] m_ctrlport_radio0_req_byte_en,
- output wire [ 1-1:0] m_ctrlport_radio0_req_has_time,
- output wire [ 64-1:0] m_ctrlport_radio0_req_time,
- input wire [ 1-1:0] m_ctrlport_radio0_resp_ack,
- input wire [ 2-1:0] m_ctrlport_radio0_resp_status,
- input wire [ 32-1:0] m_ctrlport_radio0_resp_data,
-// ctrlport_radio1
- output wire [ 1-1:0] m_ctrlport_radio1_req_wr,
- output wire [ 1-1:0] m_ctrlport_radio1_req_rd,
- output wire [ 20-1:0] m_ctrlport_radio1_req_addr,
- output wire [ 32-1:0] m_ctrlport_radio1_req_data,
- output wire [ 4-1:0] m_ctrlport_radio1_req_byte_en,
- output wire [ 1-1:0] m_ctrlport_radio1_req_has_time,
- output wire [ 64-1:0] m_ctrlport_radio1_req_time,
- input wire [ 1-1:0] m_ctrlport_radio1_resp_ack,
- input wire [ 2-1:0] m_ctrlport_radio1_resp_status,
- input wire [ 32-1:0] m_ctrlport_radio1_resp_data,
-// time_keeper
- input wire [ 64-1:0] radio_time,
-// x300_radio0
- input wire [ 64-1:0] radio_rx_data_radio0,
- input wire [ 2-1:0] radio_rx_stb_radio0,
- output wire [ 2-1:0] radio_rx_running_radio0,
- output wire [ 64-1:0] radio_tx_data_radio0,
- input wire [ 2-1:0] radio_tx_stb_radio0,
- output wire [ 2-1:0] radio_tx_running_radio0,
-// x300_radio1
- input wire [ 64-1:0] radio_rx_data_radio1,
- input wire [ 2-1:0] radio_rx_stb_radio1,
- output wire [ 2-1:0] radio_rx_running_radio1,
- output wire [ 64-1:0] radio_tx_data_radio1,
- input wire [ 2-1:0] radio_tx_stb_radio1,
- output wire [ 2-1:0] radio_tx_running_radio1,
-// dram
- input wire [ 1-1:0] axi_rst,
- output wire [ 4-1:0] m_axi_awid,
- output wire [128-1:0] m_axi_awaddr,
- output wire [ 32-1:0] m_axi_awlen,
- output wire [ 12-1:0] m_axi_awsize,
- output wire [ 8-1:0] m_axi_awburst,
- output wire [ 4-1:0] m_axi_awlock,
- output wire [ 16-1:0] m_axi_awcache,
- output wire [ 12-1:0] m_axi_awprot,
- output wire [ 16-1:0] m_axi_awqos,
- output wire [ 16-1:0] m_axi_awregion,
- output wire [ 4-1:0] m_axi_awuser,
- output wire [ 4-1:0] m_axi_awvalid,
- input wire [ 4-1:0] m_axi_awready,
- output wire [256-1:0] m_axi_wdata,
- output wire [ 32-1:0] m_axi_wstrb,
- output wire [ 4-1:0] m_axi_wlast,
- output wire [ 4-1:0] m_axi_wuser,
- output wire [ 4-1:0] m_axi_wvalid,
- input wire [ 4-1:0] m_axi_wready,
- input wire [ 4-1:0] m_axi_bid,
- input wire [ 8-1:0] m_axi_bresp,
- input wire [ 4-1:0] m_axi_buser,
- input wire [ 4-1:0] m_axi_bvalid,
- output wire [ 4-1:0] m_axi_bready,
- output wire [ 4-1:0] m_axi_arid,
- output wire [128-1:0] m_axi_araddr,
- output wire [ 32-1:0] m_axi_arlen,
- output wire [ 12-1:0] m_axi_arsize,
- output wire [ 8-1:0] m_axi_arburst,
- output wire [ 4-1:0] m_axi_arlock,
- output wire [ 16-1:0] m_axi_arcache,
- output wire [ 12-1:0] m_axi_arprot,
- output wire [ 16-1:0] m_axi_arqos,
- output wire [ 16-1:0] m_axi_arregion,
- output wire [ 4-1:0] m_axi_aruser,
- output wire [ 4-1:0] m_axi_arvalid,
- input wire [ 4-1:0] m_axi_arready,
- input wire [ 4-1:0] m_axi_rid,
- input wire [256-1:0] m_axi_rdata,
- input wire [ 8-1:0] m_axi_rresp,
- input wire [ 4-1:0] m_axi_rlast,
- input wire [ 4-1:0] m_axi_ruser,
- input wire [ 4-1:0] m_axi_rvalid,
- output wire [ 4-1:0] m_axi_rready,
- // Transport 0 (eth0 1G)
- input wire [64-1:0] s_eth0_tdata,
- input wire s_eth0_tlast,
- input wire s_eth0_tvalid,
- output wire s_eth0_tready,
- output wire [64-1:0] m_eth0_tdata,
- output wire m_eth0_tlast,
- output wire m_eth0_tvalid,
- input wire m_eth0_tready,
- // Transport 1 (eth1 10G)
- input wire [64-1:0] s_eth1_tdata,
- input wire s_eth1_tlast,
- input wire s_eth1_tvalid,
- output wire s_eth1_tready,
- output wire [64-1:0] m_eth1_tdata,
- output wire m_eth1_tlast,
- output wire m_eth1_tvalid,
- input wire m_eth1_tready,
- // Transport 2 (dma dma)
- input wire [64-1:0] s_dma_tdata,
- input wire s_dma_tlast,
- input wire s_dma_tvalid,
- output wire s_dma_tready,
- output wire [64-1:0] m_dma_tdata,
- output wire m_dma_tlast,
- output wire m_dma_tvalid,
- input wire m_dma_tready
+ 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_keeper
+ input wire [ 63:0] radio_time,
+ // x300_radio0
+ input wire [ 63:0] radio_rx_data_radio0,
+ input wire [ 1:0] radio_rx_stb_radio0,
+ output wire [ 1:0] radio_rx_running_radio0,
+ output wire [ 63:0] radio_tx_data_radio0,
+ input wire [ 1:0] radio_tx_stb_radio0,
+ output wire [ 1:0] radio_tx_running_radio0,
+ // x300_radio1
+ input wire [ 63:0] radio_rx_data_radio1,
+ input wire [ 1:0] radio_rx_stb_radio1,
+ output wire [ 1:0] radio_rx_running_radio1,
+ output wire [ 63:0] radio_tx_data_radio1,
+ input wire [ 1:0] radio_tx_stb_radio1,
+ output wire [ 1:0] radio_tx_running_radio1,
+ // dram
+ input wire [ 0:0] axi_rst,
+ output wire [ 3:0] m_axi_awid,
+ output wire [ 127: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 [ 255:0] m_axi_wdata,
+ output wire [ 31: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 [ 127: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 [ 255: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 (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 CHDR_W = 64;
- localparam MTU = 10;
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;
@@ -226,12 +244,12 @@ module rfnoc_image_core #(
.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_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_eth1_tlast, s_eth0_tlast}),
+ .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_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_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_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_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_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_eth1_tlast, m_eth0_tlast}),
+ .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_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_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_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_eth1_tready, m_eth0_tready}),
.ext_rtcfg_stb (1'h0),
@@ -240,9 +258,18 @@ module rfnoc_image_core #(
.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;
+ 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;
@@ -252,8 +279,8 @@ module rfnoc_image_core #(
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 [ 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;
@@ -266,23 +293,23 @@ module rfnoc_image_core #(
.NUM_DATA_O (1),
.INST_NUM (0),
.CTRL_XBAR_PORT (1),
- .INGRESS_BUFF_SIZE (15),
+ .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 ),
+ .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}),
@@ -291,20 +318,28 @@ module rfnoc_image_core #(
.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_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_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 )
+ .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;
+ 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;
@@ -313,8 +348,8 @@ module rfnoc_image_core #(
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 [ 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;
@@ -327,23 +362,23 @@ module rfnoc_image_core #(
.NUM_DATA_O (1),
.INST_NUM (1),
.CTRL_XBAR_PORT (2),
- .INGRESS_BUFF_SIZE (15),
+ .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 ),
+ .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}),
@@ -352,20 +387,28 @@ module rfnoc_image_core #(
.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_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_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 )
+ .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;
+ 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;
@@ -374,8 +417,8 @@ module rfnoc_image_core #(
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 [ 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;
@@ -388,23 +431,23 @@ module rfnoc_image_core #(
.NUM_DATA_O (1),
.INST_NUM (2),
.CTRL_XBAR_PORT (3),
- .INGRESS_BUFF_SIZE (15),
+ .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 ),
+ .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}),
@@ -413,20 +456,28 @@ module rfnoc_image_core #(
.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_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_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 )
+ .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;
+ 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;
@@ -435,8 +486,8 @@ module rfnoc_image_core #(
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 [ 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;
@@ -449,23 +500,23 @@ module rfnoc_image_core #(
.NUM_DATA_O (1),
.INST_NUM (3),
.CTRL_XBAR_PORT (4),
- .INGRESS_BUFF_SIZE (15),
+ .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 ),
+ .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}),
@@ -474,20 +525,28 @@ module rfnoc_image_core #(
.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_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_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 )
+ .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 = 4096;
+ 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;
@@ -496,8 +555,8 @@ module rfnoc_image_core #(
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 [ 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;
@@ -510,23 +569,23 @@ module rfnoc_image_core #(
.NUM_DATA_O (1),
.INST_NUM (4),
.CTRL_XBAR_PORT (5),
- .INGRESS_BUFF_SIZE (12),
+ .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 ),
+ .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}),
@@ -535,20 +594,28 @@ module rfnoc_image_core #(
.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_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_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 )
+ .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 = 4096;
+ 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;
@@ -557,8 +624,8 @@ module rfnoc_image_core #(
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 [ 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;
@@ -571,23 +638,23 @@ module rfnoc_image_core #(
.NUM_DATA_O (1),
.INST_NUM (5),
.CTRL_XBAR_PORT (6),
- .INGRESS_BUFF_SIZE (12),
+ .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 ),
+ .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}),
@@ -596,20 +663,28 @@ module rfnoc_image_core #(
.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_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_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 )
+ .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 = 4096;
+ 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;
@@ -618,8 +693,8 @@ module rfnoc_image_core #(
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 [ 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;
@@ -632,23 +707,23 @@ module rfnoc_image_core #(
.NUM_DATA_O (1),
.INST_NUM (6),
.CTRL_XBAR_PORT (7),
- .INGRESS_BUFF_SIZE (12),
+ .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 ),
+ .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}),
@@ -657,20 +732,28 @@ module rfnoc_image_core #(
.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_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_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 )
+ .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 = 4096;
+ 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;
@@ -679,8 +762,8 @@ module rfnoc_image_core #(
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 [ 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;
@@ -693,23 +776,23 @@ module rfnoc_image_core #(
.NUM_DATA_O (1),
.INST_NUM (7),
.CTRL_XBAR_PORT (8),
- .INGRESS_BUFF_SIZE (12),
+ .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 ),
+ .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}),
@@ -718,58 +801,57 @@ module rfnoc_image_core #(
.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_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_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 )
+ .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_duc0_ctrl_tdata , s_duc0_ctrl_tdata ;
- wire m_duc0_ctrl_tlast , s_duc0_ctrl_tlast ;
- wire m_duc0_ctrl_tvalid, s_duc0_ctrl_tvalid;
- wire m_duc0_ctrl_tready, s_duc0_ctrl_tready;
- wire [31:0] m_ddc0_ctrl_tdata , s_ddc0_ctrl_tdata ;
- wire m_ddc0_ctrl_tlast , s_ddc0_ctrl_tlast ;
- wire m_ddc0_ctrl_tvalid, s_ddc0_ctrl_tvalid;
- wire m_ddc0_ctrl_tready, s_ddc0_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_duc1_ctrl_tdata , s_duc1_ctrl_tdata ;
- wire m_duc1_ctrl_tlast , s_duc1_ctrl_tlast ;
- wire m_duc1_ctrl_tvalid, s_duc1_ctrl_tvalid;
- wire m_duc1_ctrl_tready, s_duc1_ctrl_tready;
- wire [31:0] m_ddc1_ctrl_tdata , s_ddc1_ctrl_tdata ;
- wire m_ddc1_ctrl_tlast , s_ddc1_ctrl_tlast ;
- wire m_ddc1_ctrl_tvalid, s_ddc1_ctrl_tvalid;
- wire m_ddc1_ctrl_tready, s_ddc1_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;
+ //---------------------------------------------------------------------------
+
+ 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_duc0_ctrl_tdata, s_duc0_ctrl_tdata;
+ wire m_duc0_ctrl_tlast, s_duc0_ctrl_tlast;
+ wire m_duc0_ctrl_tvalid, s_duc0_ctrl_tvalid;
+ wire m_duc0_ctrl_tready, s_duc0_ctrl_tready;
+ wire [31:0] m_ddc0_ctrl_tdata, s_ddc0_ctrl_tdata;
+ wire m_ddc0_ctrl_tlast, s_ddc0_ctrl_tlast;
+ wire m_ddc0_ctrl_tvalid, s_ddc0_ctrl_tvalid;
+ wire m_ddc0_ctrl_tready, s_ddc0_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_duc1_ctrl_tdata, s_duc1_ctrl_tdata;
+ wire m_duc1_ctrl_tlast, s_duc1_ctrl_tlast;
+ wire m_duc1_ctrl_tvalid, s_duc1_ctrl_tvalid;
+ wire m_duc1_ctrl_tready, s_duc1_ctrl_tready;
+ wire [31:0] m_ddc1_ctrl_tdata, s_ddc1_ctrl_tdata;
+ wire m_ddc1_ctrl_tlast, s_ddc1_ctrl_tlast;
+ wire m_ddc1_ctrl_tvalid, s_ddc1_ctrl_tvalid;
+ wire m_ddc1_ctrl_tready, s_ddc1_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),
@@ -793,9 +875,11 @@ module rfnoc_image_core #(
.deadlock_detected()
);
- // ----------------------------------------------------
+
+ //---------------------------------------------------------------------------
// RFNoC Core Kernel
- // ----------------------------------------------------
+ //---------------------------------------------------------------------------
+
wire [(512*7)-1:0] rfnoc_core_config, rfnoc_core_status;
rfnoc_core_kernel #(
@@ -820,12 +904,12 @@ module rfnoc_image_core #(
.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_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_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),
@@ -833,13 +917,15 @@ module rfnoc_image_core #(
.rfnoc_core_status (rfnoc_core_status)
);
- // ----------------------------------------------------
+
+ //---------------------------------------------------------------------------
// Blocks
- // ----------------------------------------------------
+ //---------------------------------------------------------------------------
- // ----------------------------------------------------
+ //-----------------------------------
// duc0
- // ----------------------------------------------------
+ //-----------------------------------
+
wire duc0_ce_clk;
wire [CHDR_W-1:0] s_duc0_in_1_tdata , s_duc0_in_0_tdata ;
wire s_duc0_in_1_tlast , s_duc0_in_0_tlast ;
@@ -850,44 +936,41 @@ module rfnoc_image_core #(
wire m_duc0_out_1_tvalid, m_duc0_out_0_tvalid;
wire m_duc0_out_1_tready, m_duc0_out_0_tready;
-
rfnoc_block_duc #(
- .THIS_PORTID(2),
- .CHDR_W(CHDR_W),
- .NUM_PORTS(2),
- .NUM_HB(3),
- .CIC_MAX_INTERP(255),
- .MTU(MTU)
+ .THIS_PORTID (2),
+ .CHDR_W (CHDR_W),
+ .NUM_PORTS (2),
+ .NUM_HB (3),
+ .CIC_MAX_INTERP (255),
+ .MTU (MTU)
) b_duc0_0 (
- .rfnoc_chdr_clk (rfnoc_chdr_clk),
- .rfnoc_ctrl_clk (rfnoc_ctrl_clk),
- .ce_clk(duc0_ce_clk),
- .rfnoc_core_config (rfnoc_core_config[512*1-1:512*0]),
- .rfnoc_core_status (rfnoc_core_status[512*1-1:512*0]),
-
-
- .s_rfnoc_chdr_tdata ({s_duc0_in_1_tdata , s_duc0_in_0_tdata }),
- .s_rfnoc_chdr_tlast ({s_duc0_in_1_tlast , s_duc0_in_0_tlast }),
- .s_rfnoc_chdr_tvalid({s_duc0_in_1_tvalid, s_duc0_in_0_tvalid}),
- .s_rfnoc_chdr_tready({s_duc0_in_1_tready, s_duc0_in_0_tready}),
- .m_rfnoc_chdr_tdata ({m_duc0_out_1_tdata , m_duc0_out_0_tdata }),
- .m_rfnoc_chdr_tlast ({m_duc0_out_1_tlast , m_duc0_out_0_tlast }),
- .m_rfnoc_chdr_tvalid({m_duc0_out_1_tvalid, m_duc0_out_0_tvalid}),
- .m_rfnoc_chdr_tready({m_duc0_out_1_tready, m_duc0_out_0_tready}),
- .s_rfnoc_ctrl_tdata (s_duc0_ctrl_tdata ),
- .s_rfnoc_ctrl_tlast (s_duc0_ctrl_tlast ),
- .s_rfnoc_ctrl_tvalid(s_duc0_ctrl_tvalid),
- .s_rfnoc_ctrl_tready(s_duc0_ctrl_tready),
- .m_rfnoc_ctrl_tdata (m_duc0_ctrl_tdata ),
- .m_rfnoc_ctrl_tlast (m_duc0_ctrl_tlast ),
- .m_rfnoc_ctrl_tvalid(m_duc0_ctrl_tvalid),
- .m_rfnoc_ctrl_tready(m_duc0_ctrl_tready)
+ .rfnoc_chdr_clk (rfnoc_chdr_clk),
+ .rfnoc_ctrl_clk (rfnoc_ctrl_clk),
+ .ce_clk (duc0_ce_clk),
+ .rfnoc_core_config (rfnoc_core_config[512*1-1:512*0]),
+ .rfnoc_core_status (rfnoc_core_status[512*1-1:512*0]),
+ .s_rfnoc_chdr_tdata ({s_duc0_in_1_tdata , s_duc0_in_0_tdata }),
+ .s_rfnoc_chdr_tlast ({s_duc0_in_1_tlast , s_duc0_in_0_tlast }),
+ .s_rfnoc_chdr_tvalid ({s_duc0_in_1_tvalid, s_duc0_in_0_tvalid}),
+ .s_rfnoc_chdr_tready ({s_duc0_in_1_tready, s_duc0_in_0_tready}),
+ .m_rfnoc_chdr_tdata ({m_duc0_out_1_tdata , m_duc0_out_0_tdata }),
+ .m_rfnoc_chdr_tlast ({m_duc0_out_1_tlast , m_duc0_out_0_tlast }),
+ .m_rfnoc_chdr_tvalid ({m_duc0_out_1_tvalid, m_duc0_out_0_tvalid}),
+ .m_rfnoc_chdr_tready ({m_duc0_out_1_tready, m_duc0_out_0_tready}),
+ .s_rfnoc_ctrl_tdata (s_duc0_ctrl_tdata),
+ .s_rfnoc_ctrl_tlast (s_duc0_ctrl_tlast),
+ .s_rfnoc_ctrl_tvalid (s_duc0_ctrl_tvalid),
+ .s_rfnoc_ctrl_tready (s_duc0_ctrl_tready),
+ .m_rfnoc_ctrl_tdata (m_duc0_ctrl_tdata),
+ .m_rfnoc_ctrl_tlast (m_duc0_ctrl_tlast),
+ .m_rfnoc_ctrl_tvalid (m_duc0_ctrl_tvalid),
+ .m_rfnoc_ctrl_tready (m_duc0_ctrl_tready)
);
-
- // ----------------------------------------------------
+ //-----------------------------------
// ddc0
- // ----------------------------------------------------
+ //-----------------------------------
+
wire ddc0_ce_clk;
wire [CHDR_W-1:0] s_ddc0_in_1_tdata , s_ddc0_in_0_tdata ;
wire s_ddc0_in_1_tlast , s_ddc0_in_0_tlast ;
@@ -898,44 +981,41 @@ module rfnoc_image_core #(
wire m_ddc0_out_1_tvalid, m_ddc0_out_0_tvalid;
wire m_ddc0_out_1_tready, m_ddc0_out_0_tready;
-
rfnoc_block_ddc #(
- .THIS_PORTID(3),
- .CHDR_W(CHDR_W),
- .NUM_PORTS(2),
- .NUM_HB(3),
- .CIC_MAX_DECIM(255),
- .MTU(MTU)
+ .THIS_PORTID (3),
+ .CHDR_W (CHDR_W),
+ .NUM_PORTS (2),
+ .NUM_HB (3),
+ .CIC_MAX_DECIM (255),
+ .MTU (MTU)
) b_ddc0_1 (
- .rfnoc_chdr_clk (rfnoc_chdr_clk),
- .rfnoc_ctrl_clk (rfnoc_ctrl_clk),
- .ce_clk(ddc0_ce_clk),
- .rfnoc_core_config (rfnoc_core_config[512*2-1:512*1]),
- .rfnoc_core_status (rfnoc_core_status[512*2-1:512*1]),
-
-
- .s_rfnoc_chdr_tdata ({s_ddc0_in_1_tdata , s_ddc0_in_0_tdata }),
- .s_rfnoc_chdr_tlast ({s_ddc0_in_1_tlast , s_ddc0_in_0_tlast }),
- .s_rfnoc_chdr_tvalid({s_ddc0_in_1_tvalid, s_ddc0_in_0_tvalid}),
- .s_rfnoc_chdr_tready({s_ddc0_in_1_tready, s_ddc0_in_0_tready}),
- .m_rfnoc_chdr_tdata ({m_ddc0_out_1_tdata , m_ddc0_out_0_tdata }),
- .m_rfnoc_chdr_tlast ({m_ddc0_out_1_tlast , m_ddc0_out_0_tlast }),
- .m_rfnoc_chdr_tvalid({m_ddc0_out_1_tvalid, m_ddc0_out_0_tvalid}),
- .m_rfnoc_chdr_tready({m_ddc0_out_1_tready, m_ddc0_out_0_tready}),
- .s_rfnoc_ctrl_tdata (s_ddc0_ctrl_tdata ),
- .s_rfnoc_ctrl_tlast (s_ddc0_ctrl_tlast ),
- .s_rfnoc_ctrl_tvalid(s_ddc0_ctrl_tvalid),
- .s_rfnoc_ctrl_tready(s_ddc0_ctrl_tready),
- .m_rfnoc_ctrl_tdata (m_ddc0_ctrl_tdata ),
- .m_rfnoc_ctrl_tlast (m_ddc0_ctrl_tlast ),
- .m_rfnoc_ctrl_tvalid(m_ddc0_ctrl_tvalid),
- .m_rfnoc_ctrl_tready(m_ddc0_ctrl_tready)
+ .rfnoc_chdr_clk (rfnoc_chdr_clk),
+ .rfnoc_ctrl_clk (rfnoc_ctrl_clk),
+ .ce_clk (ddc0_ce_clk),
+ .rfnoc_core_config (rfnoc_core_config[512*2-1:512*1]),
+ .rfnoc_core_status (rfnoc_core_status[512*2-1:512*1]),
+ .s_rfnoc_chdr_tdata ({s_ddc0_in_1_tdata , s_ddc0_in_0_tdata }),
+ .s_rfnoc_chdr_tlast ({s_ddc0_in_1_tlast , s_ddc0_in_0_tlast }),
+ .s_rfnoc_chdr_tvalid ({s_ddc0_in_1_tvalid, s_ddc0_in_0_tvalid}),
+ .s_rfnoc_chdr_tready ({s_ddc0_in_1_tready, s_ddc0_in_0_tready}),
+ .m_rfnoc_chdr_tdata ({m_ddc0_out_1_tdata , m_ddc0_out_0_tdata }),
+ .m_rfnoc_chdr_tlast ({m_ddc0_out_1_tlast , m_ddc0_out_0_tlast }),
+ .m_rfnoc_chdr_tvalid ({m_ddc0_out_1_tvalid, m_ddc0_out_0_tvalid}),
+ .m_rfnoc_chdr_tready ({m_ddc0_out_1_tready, m_ddc0_out_0_tready}),
+ .s_rfnoc_ctrl_tdata (s_ddc0_ctrl_tdata),
+ .s_rfnoc_ctrl_tlast (s_ddc0_ctrl_tlast),
+ .s_rfnoc_ctrl_tvalid (s_ddc0_ctrl_tvalid),
+ .s_rfnoc_ctrl_tready (s_ddc0_ctrl_tready),
+ .m_rfnoc_ctrl_tdata (m_ddc0_ctrl_tdata),
+ .m_rfnoc_ctrl_tlast (m_ddc0_ctrl_tlast),
+ .m_rfnoc_ctrl_tvalid (m_ddc0_ctrl_tvalid),
+ .m_rfnoc_ctrl_tready (m_ddc0_ctrl_tready)
);
-
- // ----------------------------------------------------
+ //-----------------------------------
// 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 ;
@@ -946,79 +1026,77 @@ module rfnoc_image_core #(
wire m_radio0_out_1_tvalid, m_radio0_out_0_tvalid;
wire m_radio0_out_1_tready, m_radio0_out_0_tready;
- // ctrl_port
- wire [ 1-1:0] radio0_m_ctrlport_req_wr;
- wire [ 1-1:0] radio0_m_ctrlport_req_rd;
- wire [ 20-1:0] radio0_m_ctrlport_req_addr;
- wire [ 32-1:0] radio0_m_ctrlport_req_data;
- wire [ 4-1:0] radio0_m_ctrlport_req_byte_en;
- wire [ 1-1:0] radio0_m_ctrlport_req_has_time;
- wire [ 64-1:0] radio0_m_ctrlport_req_time;
- wire [ 1-1:0] radio0_m_ctrlport_resp_ack;
- wire [ 2-1:0] radio0_m_ctrlport_resp_status;
- wire [ 32-1:0] radio0_m_ctrlport_resp_data;
- // time_keeper
- wire [ 64-1:0] radio0_radio_time;
- // x300_radio
- wire [ 64-1:0] radio0_radio_rx_data;
- wire [ 2-1:0] radio0_radio_rx_stb;
- wire [ 2-1:0] radio0_radio_rx_running;
- wire [ 64-1:0] radio0_radio_tx_data;
- wire [ 2-1:0] radio0_radio_tx_stb;
- wire [ 2-1:0] radio0_radio_tx_running;
+ // ctrl_port
+ 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_keeper
+ wire [ 63:0] radio0_radio_time;
+ // x300_radio
+ wire [ 63:0] radio0_radio_rx_data;
+ wire [ 1:0] radio0_radio_rx_stb;
+ wire [ 1:0] radio0_radio_rx_running;
+ wire [ 63:0] radio0_radio_tx_data;
+ wire [ 1:0] radio0_radio_tx_stb;
+ wire [ 1:0] radio0_radio_tx_running;
rfnoc_block_radio #(
- .THIS_PORTID(4),
- .CHDR_W(CHDR_W),
- .NUM_PORTS(2),
- .MTU(MTU)
+ .THIS_PORTID (4),
+ .CHDR_W (CHDR_W),
+ .NUM_PORTS (2),
+ .MTU (MTU)
) b_radio0_2 (
- .rfnoc_chdr_clk (rfnoc_chdr_clk),
- .rfnoc_ctrl_clk (rfnoc_ctrl_clk),
- .radio_clk(radio0_radio_clk),
- .rfnoc_core_config (rfnoc_core_config[512*3-1:512*2]),
- .rfnoc_core_status (rfnoc_core_status[512*3-1:512*2]),
-
- .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),
+ .rfnoc_chdr_clk (rfnoc_chdr_clk),
+ .rfnoc_ctrl_clk (rfnoc_ctrl_clk),
+ .radio_clk (radio0_radio_clk),
+ .rfnoc_core_config (rfnoc_core_config[512*3-1:512*2]),
+ .rfnoc_core_status (rfnoc_core_status[512*3-1:512*2]),
+ .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_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)
+ .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)
);
-
- // ----------------------------------------------------
+ //-----------------------------------
// duc1
- // ----------------------------------------------------
+ //-----------------------------------
+
wire duc1_ce_clk;
wire [CHDR_W-1:0] s_duc1_in_1_tdata , s_duc1_in_0_tdata ;
wire s_duc1_in_1_tlast , s_duc1_in_0_tlast ;
@@ -1029,44 +1107,41 @@ module rfnoc_image_core #(
wire m_duc1_out_1_tvalid, m_duc1_out_0_tvalid;
wire m_duc1_out_1_tready, m_duc1_out_0_tready;
-
rfnoc_block_duc #(
- .THIS_PORTID(5),
- .CHDR_W(CHDR_W),
- .NUM_PORTS(2),
- .NUM_HB(3),
- .CIC_MAX_INTERP(255),
- .MTU(MTU)
+ .THIS_PORTID (5),
+ .CHDR_W (CHDR_W),
+ .NUM_PORTS (2),
+ .NUM_HB (3),
+ .CIC_MAX_INTERP (255),
+ .MTU (MTU)
) b_duc1_3 (
- .rfnoc_chdr_clk (rfnoc_chdr_clk),
- .rfnoc_ctrl_clk (rfnoc_ctrl_clk),
- .ce_clk(duc1_ce_clk),
- .rfnoc_core_config (rfnoc_core_config[512*4-1:512*3]),
- .rfnoc_core_status (rfnoc_core_status[512*4-1:512*3]),
-
-
- .s_rfnoc_chdr_tdata ({s_duc1_in_1_tdata , s_duc1_in_0_tdata }),
- .s_rfnoc_chdr_tlast ({s_duc1_in_1_tlast , s_duc1_in_0_tlast }),
- .s_rfnoc_chdr_tvalid({s_duc1_in_1_tvalid, s_duc1_in_0_tvalid}),
- .s_rfnoc_chdr_tready({s_duc1_in_1_tready, s_duc1_in_0_tready}),
- .m_rfnoc_chdr_tdata ({m_duc1_out_1_tdata , m_duc1_out_0_tdata }),
- .m_rfnoc_chdr_tlast ({m_duc1_out_1_tlast , m_duc1_out_0_tlast }),
- .m_rfnoc_chdr_tvalid({m_duc1_out_1_tvalid, m_duc1_out_0_tvalid}),
- .m_rfnoc_chdr_tready({m_duc1_out_1_tready, m_duc1_out_0_tready}),
- .s_rfnoc_ctrl_tdata (s_duc1_ctrl_tdata ),
- .s_rfnoc_ctrl_tlast (s_duc1_ctrl_tlast ),
- .s_rfnoc_ctrl_tvalid(s_duc1_ctrl_tvalid),
- .s_rfnoc_ctrl_tready(s_duc1_ctrl_tready),
- .m_rfnoc_ctrl_tdata (m_duc1_ctrl_tdata ),
- .m_rfnoc_ctrl_tlast (m_duc1_ctrl_tlast ),
- .m_rfnoc_ctrl_tvalid(m_duc1_ctrl_tvalid),
- .m_rfnoc_ctrl_tready(m_duc1_ctrl_tready)
+ .rfnoc_chdr_clk (rfnoc_chdr_clk),
+ .rfnoc_ctrl_clk (rfnoc_ctrl_clk),
+ .ce_clk (duc1_ce_clk),
+ .rfnoc_core_config (rfnoc_core_config[512*4-1:512*3]),
+ .rfnoc_core_status (rfnoc_core_status[512*4-1:512*3]),
+ .s_rfnoc_chdr_tdata ({s_duc1_in_1_tdata , s_duc1_in_0_tdata }),
+ .s_rfnoc_chdr_tlast ({s_duc1_in_1_tlast , s_duc1_in_0_tlast }),
+ .s_rfnoc_chdr_tvalid ({s_duc1_in_1_tvalid, s_duc1_in_0_tvalid}),
+ .s_rfnoc_chdr_tready ({s_duc1_in_1_tready, s_duc1_in_0_tready}),
+ .m_rfnoc_chdr_tdata ({m_duc1_out_1_tdata , m_duc1_out_0_tdata }),
+ .m_rfnoc_chdr_tlast ({m_duc1_out_1_tlast , m_duc1_out_0_tlast }),
+ .m_rfnoc_chdr_tvalid ({m_duc1_out_1_tvalid, m_duc1_out_0_tvalid}),
+ .m_rfnoc_chdr_tready ({m_duc1_out_1_tready, m_duc1_out_0_tready}),
+ .s_rfnoc_ctrl_tdata (s_duc1_ctrl_tdata),
+ .s_rfnoc_ctrl_tlast (s_duc1_ctrl_tlast),
+ .s_rfnoc_ctrl_tvalid (s_duc1_ctrl_tvalid),
+ .s_rfnoc_ctrl_tready (s_duc1_ctrl_tready),
+ .m_rfnoc_ctrl_tdata (m_duc1_ctrl_tdata),
+ .m_rfnoc_ctrl_tlast (m_duc1_ctrl_tlast),
+ .m_rfnoc_ctrl_tvalid (m_duc1_ctrl_tvalid),
+ .m_rfnoc_ctrl_tready (m_duc1_ctrl_tready)
);
-
- // ----------------------------------------------------
+ //-----------------------------------
// ddc1
- // ----------------------------------------------------
+ //-----------------------------------
+
wire ddc1_ce_clk;
wire [CHDR_W-1:0] s_ddc1_in_1_tdata , s_ddc1_in_0_tdata ;
wire s_ddc1_in_1_tlast , s_ddc1_in_0_tlast ;
@@ -1077,44 +1152,41 @@ module rfnoc_image_core #(
wire m_ddc1_out_1_tvalid, m_ddc1_out_0_tvalid;
wire m_ddc1_out_1_tready, m_ddc1_out_0_tready;
-
rfnoc_block_ddc #(
- .THIS_PORTID(6),
- .CHDR_W(CHDR_W),
- .NUM_PORTS(2),
- .NUM_HB(3),
- .CIC_MAX_DECIM(255),
- .MTU(MTU)
+ .THIS_PORTID (6),
+ .CHDR_W (CHDR_W),
+ .NUM_PORTS (2),
+ .NUM_HB (3),
+ .CIC_MAX_DECIM (255),
+ .MTU (MTU)
) b_ddc1_4 (
- .rfnoc_chdr_clk (rfnoc_chdr_clk),
- .rfnoc_ctrl_clk (rfnoc_ctrl_clk),
- .ce_clk(ddc1_ce_clk),
- .rfnoc_core_config (rfnoc_core_config[512*5-1:512*4]),
- .rfnoc_core_status (rfnoc_core_status[512*5-1:512*4]),
-
-
- .s_rfnoc_chdr_tdata ({s_ddc1_in_1_tdata , s_ddc1_in_0_tdata }),
- .s_rfnoc_chdr_tlast ({s_ddc1_in_1_tlast , s_ddc1_in_0_tlast }),
- .s_rfnoc_chdr_tvalid({s_ddc1_in_1_tvalid, s_ddc1_in_0_tvalid}),
- .s_rfnoc_chdr_tready({s_ddc1_in_1_tready, s_ddc1_in_0_tready}),
- .m_rfnoc_chdr_tdata ({m_ddc1_out_1_tdata , m_ddc1_out_0_tdata }),
- .m_rfnoc_chdr_tlast ({m_ddc1_out_1_tlast , m_ddc1_out_0_tlast }),
- .m_rfnoc_chdr_tvalid({m_ddc1_out_1_tvalid, m_ddc1_out_0_tvalid}),
- .m_rfnoc_chdr_tready({m_ddc1_out_1_tready, m_ddc1_out_0_tready}),
- .s_rfnoc_ctrl_tdata (s_ddc1_ctrl_tdata ),
- .s_rfnoc_ctrl_tlast (s_ddc1_ctrl_tlast ),
- .s_rfnoc_ctrl_tvalid(s_ddc1_ctrl_tvalid),
- .s_rfnoc_ctrl_tready(s_ddc1_ctrl_tready),
- .m_rfnoc_ctrl_tdata (m_ddc1_ctrl_tdata ),
- .m_rfnoc_ctrl_tlast (m_ddc1_ctrl_tlast ),
- .m_rfnoc_ctrl_tvalid(m_ddc1_ctrl_tvalid),
- .m_rfnoc_ctrl_tready(m_ddc1_ctrl_tready)
+ .rfnoc_chdr_clk (rfnoc_chdr_clk),
+ .rfnoc_ctrl_clk (rfnoc_ctrl_clk),
+ .ce_clk (ddc1_ce_clk),
+ .rfnoc_core_config (rfnoc_core_config[512*5-1:512*4]),
+ .rfnoc_core_status (rfnoc_core_status[512*5-1:512*4]),
+ .s_rfnoc_chdr_tdata ({s_ddc1_in_1_tdata , s_ddc1_in_0_tdata }),
+ .s_rfnoc_chdr_tlast ({s_ddc1_in_1_tlast , s_ddc1_in_0_tlast }),
+ .s_rfnoc_chdr_tvalid ({s_ddc1_in_1_tvalid, s_ddc1_in_0_tvalid}),
+ .s_rfnoc_chdr_tready ({s_ddc1_in_1_tready, s_ddc1_in_0_tready}),
+ .m_rfnoc_chdr_tdata ({m_ddc1_out_1_tdata , m_ddc1_out_0_tdata }),
+ .m_rfnoc_chdr_tlast ({m_ddc1_out_1_tlast , m_ddc1_out_0_tlast }),
+ .m_rfnoc_chdr_tvalid ({m_ddc1_out_1_tvalid, m_ddc1_out_0_tvalid}),
+ .m_rfnoc_chdr_tready ({m_ddc1_out_1_tready, m_ddc1_out_0_tready}),
+ .s_rfnoc_ctrl_tdata (s_ddc1_ctrl_tdata),
+ .s_rfnoc_ctrl_tlast (s_ddc1_ctrl_tlast),
+ .s_rfnoc_ctrl_tvalid (s_ddc1_ctrl_tvalid),
+ .s_rfnoc_ctrl_tready (s_ddc1_ctrl_tready),
+ .m_rfnoc_ctrl_tdata (m_ddc1_ctrl_tdata),
+ .m_rfnoc_ctrl_tlast (m_ddc1_ctrl_tlast),
+ .m_rfnoc_ctrl_tvalid (m_ddc1_ctrl_tvalid),
+ .m_rfnoc_ctrl_tready (m_ddc1_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 ;
@@ -1125,79 +1197,77 @@ module rfnoc_image_core #(
wire m_radio1_out_1_tvalid, m_radio1_out_0_tvalid;
wire m_radio1_out_1_tready, m_radio1_out_0_tready;
- // ctrl_port
- wire [ 1-1:0] radio1_m_ctrlport_req_wr;
- wire [ 1-1:0] radio1_m_ctrlport_req_rd;
- wire [ 20-1:0] radio1_m_ctrlport_req_addr;
- wire [ 32-1:0] radio1_m_ctrlport_req_data;
- wire [ 4-1:0] radio1_m_ctrlport_req_byte_en;
- wire [ 1-1:0] radio1_m_ctrlport_req_has_time;
- wire [ 64-1:0] radio1_m_ctrlport_req_time;
- wire [ 1-1:0] radio1_m_ctrlport_resp_ack;
- wire [ 2-1:0] radio1_m_ctrlport_resp_status;
- wire [ 32-1:0] radio1_m_ctrlport_resp_data;
- // time_keeper
- wire [ 64-1:0] radio1_radio_time;
- // x300_radio
- wire [ 64-1:0] radio1_radio_rx_data;
- wire [ 2-1:0] radio1_radio_rx_stb;
- wire [ 2-1:0] radio1_radio_rx_running;
- wire [ 64-1:0] radio1_radio_tx_data;
- wire [ 2-1:0] radio1_radio_tx_stb;
- wire [ 2-1:0] radio1_radio_tx_running;
+ // ctrl_port
+ 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_keeper
+ wire [ 63:0] radio1_radio_time;
+ // x300_radio
+ wire [ 63:0] radio1_radio_rx_data;
+ wire [ 1:0] radio1_radio_rx_stb;
+ wire [ 1:0] radio1_radio_rx_running;
+ wire [ 63:0] radio1_radio_tx_data;
+ wire [ 1:0] radio1_radio_tx_stb;
+ wire [ 1:0] radio1_radio_tx_running;
rfnoc_block_radio #(
- .THIS_PORTID(7),
- .CHDR_W(CHDR_W),
- .NUM_PORTS(2),
- .MTU(MTU)
+ .THIS_PORTID (7),
+ .CHDR_W (CHDR_W),
+ .NUM_PORTS (2),
+ .MTU (MTU)
) b_radio1_5 (
- .rfnoc_chdr_clk (rfnoc_chdr_clk),
- .rfnoc_ctrl_clk (rfnoc_ctrl_clk),
- .radio_clk(radio1_radio_clk),
- .rfnoc_core_config (rfnoc_core_config[512*6-1:512*5]),
- .rfnoc_core_status (rfnoc_core_status[512*6-1:512*5]),
-
- .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),
+ .rfnoc_chdr_clk (rfnoc_chdr_clk),
+ .rfnoc_ctrl_clk (rfnoc_ctrl_clk),
+ .radio_clk (radio1_radio_clk),
+ .rfnoc_core_config (rfnoc_core_config[512*6-1:512*5]),
+ .rfnoc_core_status (rfnoc_core_status[512*6-1:512*5]),
+ .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_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)
+ .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 ;
@@ -1208,263 +1278,264 @@ module rfnoc_image_core #(
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 [ 1-1:0] replay0_axi_rst;
- wire [ 4-1:0] replay0_m_axi_awid;
- wire [128-1:0] replay0_m_axi_awaddr;
- wire [ 32-1:0] replay0_m_axi_awlen;
- wire [ 12-1:0] replay0_m_axi_awsize;
- wire [ 8-1:0] replay0_m_axi_awburst;
- wire [ 4-1:0] replay0_m_axi_awlock;
- wire [ 16-1:0] replay0_m_axi_awcache;
- wire [ 12-1:0] replay0_m_axi_awprot;
- wire [ 16-1:0] replay0_m_axi_awqos;
- wire [ 16-1:0] replay0_m_axi_awregion;
- wire [ 4-1:0] replay0_m_axi_awuser;
- wire [ 4-1:0] replay0_m_axi_awvalid;
- wire [ 4-1:0] replay0_m_axi_awready;
- wire [256-1:0] replay0_m_axi_wdata;
- wire [ 32-1:0] replay0_m_axi_wstrb;
- wire [ 4-1:0] replay0_m_axi_wlast;
- wire [ 4-1:0] replay0_m_axi_wuser;
- wire [ 4-1:0] replay0_m_axi_wvalid;
- wire [ 4-1:0] replay0_m_axi_wready;
- wire [ 4-1:0] replay0_m_axi_bid;
- wire [ 8-1:0] replay0_m_axi_bresp;
- wire [ 4-1:0] replay0_m_axi_buser;
- wire [ 4-1:0] replay0_m_axi_bvalid;
- wire [ 4-1:0] replay0_m_axi_bready;
- wire [ 4-1:0] replay0_m_axi_arid;
- wire [128-1:0] replay0_m_axi_araddr;
- wire [ 32-1:0] replay0_m_axi_arlen;
- wire [ 12-1:0] replay0_m_axi_arsize;
- wire [ 8-1:0] replay0_m_axi_arburst;
- wire [ 4-1:0] replay0_m_axi_arlock;
- wire [ 16-1:0] replay0_m_axi_arcache;
- wire [ 12-1:0] replay0_m_axi_arprot;
- wire [ 16-1:0] replay0_m_axi_arqos;
- wire [ 16-1:0] replay0_m_axi_arregion;
- wire [ 4-1:0] replay0_m_axi_aruser;
- wire [ 4-1:0] replay0_m_axi_arvalid;
- wire [ 4-1:0] replay0_m_axi_arready;
- wire [ 4-1:0] replay0_m_axi_rid;
- wire [256-1:0] replay0_m_axi_rdata;
- wire [ 8-1:0] replay0_m_axi_rresp;
- wire [ 4-1:0] replay0_m_axi_rlast;
- wire [ 4-1:0] replay0_m_axi_ruser;
- wire [ 4-1:0] replay0_m_axi_rvalid;
- wire [ 4-1:0] replay0_m_axi_rready;
+ // axi_ram
+ wire [ 0:0] replay0_axi_rst;
+ wire [ 3:0] replay0_m_axi_awid;
+ wire [ 127: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 [ 255:0] replay0_m_axi_wdata;
+ wire [ 31: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 [ 127: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 [ 255: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(8),
- .CHDR_W(CHDR_W),
- .NUM_PORTS(4),
- .MEM_ADDR_W(31),
- .MEM_DATA_W(64),
- .MTU(MTU)
+ .THIS_PORTID (8),
+ .CHDR_W (CHDR_W),
+ .NUM_PORTS (4),
+ .MEM_ADDR_W (31),
+ .MEM_DATA_W (64),
+ .MTU (MTU)
) b_replay0_6 (
- .rfnoc_chdr_clk (rfnoc_chdr_clk),
- .rfnoc_ctrl_clk (rfnoc_ctrl_clk),
- .mem_clk(replay0_mem_clk),
- .rfnoc_core_config (rfnoc_core_config[512*7-1:512*6]),
- .rfnoc_core_status (rfnoc_core_status[512*7-1:512*6]),
-
- .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)
+ .rfnoc_chdr_clk (rfnoc_chdr_clk),
+ .rfnoc_ctrl_clk (rfnoc_ctrl_clk),
+ .mem_clk (replay0_mem_clk),
+ .rfnoc_core_config (rfnoc_core_config[512*7-1:512*6]),
+ .rfnoc_core_status (rfnoc_core_status[512*7-1:512*6]),
+ .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_duc0_in_0_tdata = m_ep0_out0_tdata ;
- assign s_duc0_in_0_tlast = m_ep0_out0_tlast ;
+ //---------------------------------------------------------------------------
+
+ assign s_duc0_in_0_tdata = m_ep0_out0_tdata;
+ assign s_duc0_in_0_tlast = m_ep0_out0_tlast;
assign s_duc0_in_0_tvalid = m_ep0_out0_tvalid;
assign m_ep0_out0_tready = s_duc0_in_0_tready;
- assign s_radio0_in_0_tdata = m_duc0_out_0_tdata ;
- assign s_radio0_in_0_tlast = m_duc0_out_0_tlast ;
+ assign s_radio0_in_0_tdata = m_duc0_out_0_tdata;
+ assign s_radio0_in_0_tlast = m_duc0_out_0_tlast;
assign s_radio0_in_0_tvalid = m_duc0_out_0_tvalid;
assign m_duc0_out_0_tready = s_radio0_in_0_tready;
- assign s_ddc0_in_0_tdata = m_radio0_out_0_tdata ;
- assign s_ddc0_in_0_tlast = m_radio0_out_0_tlast ;
+ assign s_ddc0_in_0_tdata = m_radio0_out_0_tdata;
+ assign s_ddc0_in_0_tlast = m_radio0_out_0_tlast;
assign s_ddc0_in_0_tvalid = m_radio0_out_0_tvalid;
assign m_radio0_out_0_tready = s_ddc0_in_0_tready;
- assign s_ep0_in0_tdata = m_ddc0_out_0_tdata ;
- assign s_ep0_in0_tlast = m_ddc0_out_0_tlast ;
+ assign s_ep0_in0_tdata = m_ddc0_out_0_tdata;
+ assign s_ep0_in0_tlast = m_ddc0_out_0_tlast;
assign s_ep0_in0_tvalid = m_ddc0_out_0_tvalid;
assign m_ddc0_out_0_tready = s_ep0_in0_tready;
- assign s_duc0_in_1_tdata = m_ep1_out0_tdata ;
- assign s_duc0_in_1_tlast = m_ep1_out0_tlast ;
+ assign s_duc0_in_1_tdata = m_ep1_out0_tdata;
+ assign s_duc0_in_1_tlast = m_ep1_out0_tlast;
assign s_duc0_in_1_tvalid = m_ep1_out0_tvalid;
assign m_ep1_out0_tready = s_duc0_in_1_tready;
- assign s_radio0_in_1_tdata = m_duc0_out_1_tdata ;
- assign s_radio0_in_1_tlast = m_duc0_out_1_tlast ;
+ assign s_radio0_in_1_tdata = m_duc0_out_1_tdata;
+ assign s_radio0_in_1_tlast = m_duc0_out_1_tlast;
assign s_radio0_in_1_tvalid = m_duc0_out_1_tvalid;
assign m_duc0_out_1_tready = s_radio0_in_1_tready;
- assign s_ddc0_in_1_tdata = m_radio0_out_1_tdata ;
- assign s_ddc0_in_1_tlast = m_radio0_out_1_tlast ;
+ assign s_ddc0_in_1_tdata = m_radio0_out_1_tdata;
+ assign s_ddc0_in_1_tlast = m_radio0_out_1_tlast;
assign s_ddc0_in_1_tvalid = m_radio0_out_1_tvalid;
assign m_radio0_out_1_tready = s_ddc0_in_1_tready;
- assign s_ep1_in0_tdata = m_ddc0_out_1_tdata ;
- assign s_ep1_in0_tlast = m_ddc0_out_1_tlast ;
+ assign s_ep1_in0_tdata = m_ddc0_out_1_tdata;
+ assign s_ep1_in0_tlast = m_ddc0_out_1_tlast;
assign s_ep1_in0_tvalid = m_ddc0_out_1_tvalid;
assign m_ddc0_out_1_tready = s_ep1_in0_tready;
- assign s_duc1_in_0_tdata = m_ep2_out0_tdata ;
- assign s_duc1_in_0_tlast = m_ep2_out0_tlast ;
+ assign s_duc1_in_0_tdata = m_ep2_out0_tdata;
+ assign s_duc1_in_0_tlast = m_ep2_out0_tlast;
assign s_duc1_in_0_tvalid = m_ep2_out0_tvalid;
assign m_ep2_out0_tready = s_duc1_in_0_tready;
- assign s_radio1_in_0_tdata = m_duc1_out_0_tdata ;
- assign s_radio1_in_0_tlast = m_duc1_out_0_tlast ;
+ assign s_radio1_in_0_tdata = m_duc1_out_0_tdata;
+ assign s_radio1_in_0_tlast = m_duc1_out_0_tlast;
assign s_radio1_in_0_tvalid = m_duc1_out_0_tvalid;
assign m_duc1_out_0_tready = s_radio1_in_0_tready;
- assign s_ddc1_in_0_tdata = m_radio1_out_0_tdata ;
- assign s_ddc1_in_0_tlast = m_radio1_out_0_tlast ;
+ assign s_ddc1_in_0_tdata = m_radio1_out_0_tdata;
+ assign s_ddc1_in_0_tlast = m_radio1_out_0_tlast;
assign s_ddc1_in_0_tvalid = m_radio1_out_0_tvalid;
assign m_radio1_out_0_tready = s_ddc1_in_0_tready;
- assign s_ep2_in0_tdata = m_ddc1_out_0_tdata ;
- assign s_ep2_in0_tlast = m_ddc1_out_0_tlast ;
+ assign s_ep2_in0_tdata = m_ddc1_out_0_tdata;
+ assign s_ep2_in0_tlast = m_ddc1_out_0_tlast;
assign s_ep2_in0_tvalid = m_ddc1_out_0_tvalid;
assign m_ddc1_out_0_tready = s_ep2_in0_tready;
- assign s_duc1_in_1_tdata = m_ep3_out0_tdata ;
- assign s_duc1_in_1_tlast = m_ep3_out0_tlast ;
+ assign s_duc1_in_1_tdata = m_ep3_out0_tdata;
+ assign s_duc1_in_1_tlast = m_ep3_out0_tlast;
assign s_duc1_in_1_tvalid = m_ep3_out0_tvalid;
assign m_ep3_out0_tready = s_duc1_in_1_tready;
- assign s_radio1_in_1_tdata = m_duc1_out_1_tdata ;
- assign s_radio1_in_1_tlast = m_duc1_out_1_tlast ;
+ assign s_radio1_in_1_tdata = m_duc1_out_1_tdata;
+ assign s_radio1_in_1_tlast = m_duc1_out_1_tlast;
assign s_radio1_in_1_tvalid = m_duc1_out_1_tvalid;
assign m_duc1_out_1_tready = s_radio1_in_1_tready;
- assign s_ddc1_in_1_tdata = m_radio1_out_1_tdata ;
- assign s_ddc1_in_1_tlast = m_radio1_out_1_tlast ;
+ assign s_ddc1_in_1_tdata = m_radio1_out_1_tdata;
+ assign s_ddc1_in_1_tlast = m_radio1_out_1_tlast;
assign s_ddc1_in_1_tvalid = m_radio1_out_1_tvalid;
assign m_radio1_out_1_tready = s_ddc1_in_1_tready;
- assign s_ep3_in0_tdata = m_ddc1_out_1_tdata ;
- assign s_ep3_in0_tlast = m_ddc1_out_1_tlast ;
+ assign s_ep3_in0_tdata = m_ddc1_out_1_tdata;
+ assign s_ep3_in0_tlast = m_ddc1_out_1_tlast;
assign s_ep3_in0_tvalid = m_ddc1_out_1_tvalid;
assign m_ddc1_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_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_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_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_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_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_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_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_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 ddc0_ce_clk = rfnoc_chdr_clk;
assign duc0_ce_clk = rfnoc_chdr_clk;
@@ -1474,9 +1545,10 @@ module rfnoc_image_core #(
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;
@@ -1566,3 +1638,6 @@ module rfnoc_image_core #(
assign radio1_radio_time = radio_time;
endmodule
+
+
+`default_nettype wire
diff --git a/fpga/usrp3/top/n3xx/n310_rfnoc_image_core.vh b/fpga/usrp3/top/n3xx/n310_rfnoc_image_core.vh
new file mode 100644
index 000000000..9ea3cafc5
--- /dev/null
+++ b/fpga/usrp3/top/n3xx/n310_rfnoc_image_core.vh
@@ -0,0 +1,21 @@
+//
+// Copyright 2021 Ettus Research, A National Instruments Brand
+//
+// SPDX-License-Identifier: LGPL-3.0-or-later
+//
+// Header: rfnoc_image_core.vh (for n310)
+//
+// 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: 2021-05-03T08:51:09.279594
+// Source: n310_rfnoc_image_core.yml
+// Source SHA256: cc561a3de48fea9e224425413802738d125393f55f6dd46e196db8fdabe09284
+//
+
+`define CHDR_WIDTH 64
+`define RFNOC_PROTOVER { 8'd1, 8'd0 }
diff --git a/fpga/usrp3/top/n3xx/n320_bist_image_core.v b/fpga/usrp3/top/n3xx/n320_bist_image_core.v
index 4a080f2a8..142f46a09 100644
--- a/fpga/usrp3/top/n3xx/n320_bist_image_core.v
+++ b/fpga/usrp3/top/n3xx/n320_bist_image_core.v
@@ -1,19 +1,32 @@
//
-// Copyright 2020 Ettus Research, A National Instruments Brand
+// Copyright 2021 Ettus Research, A National Instruments Brand
//
// SPDX-License-Identifier: LGPL-3.0-or-later
//
-
// Module: rfnoc_image_core (for n320)
-// This file was autogenerated by UHD's image builder tool (rfnoc_image_builder)
-// Re-running that tool will overwrite this file!
-// File generated on: 2020-07-27T12:39:13.318449
+//
+// 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: 2021-05-03T08:51:06.226381
// Source: n320_bist_image_core.yml
-// Source SHA256: b5d9a0fb5302f7bfadf36c9d6cdcc70814aa1062f82396378a2976faba6ba010
+// Source SHA256: d384cf18372dd4b674466793e7cf30abeb4f3ef658d466be7007a9b7b8af7241
+//
+
+`default_nettype none
+
module rfnoc_image_core #(
- parameter [15:0] PROTOVER = {8'd1, 8'd0}
-)(
+ parameter CHDR_W = 64,
+ parameter MTU = 10,
+ parameter [15:0] PROTOVER = {8'd1, 8'd0},
+ parameter RADIO_NIPC = 1
+) (
// Clocks
input wire chdr_aclk,
input wire ctrl_aclk,
@@ -21,131 +34,136 @@ module rfnoc_image_core #(
input wire radio_clk,
input wire dram_clk,
// Basic
- input wire [15:0] device_id,
-//// IO ports //////////////////////////////////
-// ctrlport_radio0
- output wire [ 1-1:0] m_ctrlport_radio0_req_wr,
- output wire [ 1-1:0] m_ctrlport_radio0_req_rd,
- output wire [ 20-1:0] m_ctrlport_radio0_req_addr,
- output wire [ 32-1:0] m_ctrlport_radio0_req_data,
- output wire [ 4-1:0] m_ctrlport_radio0_req_byte_en,
- output wire [ 1-1:0] m_ctrlport_radio0_req_has_time,
- output wire [ 64-1:0] m_ctrlport_radio0_req_time,
- input wire [ 1-1:0] m_ctrlport_radio0_resp_ack,
- input wire [ 2-1:0] m_ctrlport_radio0_resp_status,
- input wire [ 32-1:0] m_ctrlport_radio0_resp_data,
-// ctrlport_radio1
- output wire [ 1-1:0] m_ctrlport_radio1_req_wr,
- output wire [ 1-1:0] m_ctrlport_radio1_req_rd,
- output wire [ 20-1:0] m_ctrlport_radio1_req_addr,
- output wire [ 32-1:0] m_ctrlport_radio1_req_data,
- output wire [ 4-1:0] m_ctrlport_radio1_req_byte_en,
- output wire [ 1-1:0] m_ctrlport_radio1_req_has_time,
- output wire [ 64-1:0] m_ctrlport_radio1_req_time,
- input wire [ 1-1:0] m_ctrlport_radio1_resp_ack,
- input wire [ 2-1:0] m_ctrlport_radio1_resp_status,
- input wire [ 32-1:0] m_ctrlport_radio1_resp_data,
-// time_keeper
- input wire [ 64-1:0] radio_time,
-// radio_ch0
- input wire [ 32-1:0] radio_rx_data_radio0,
- input wire [ 1-1:0] radio_rx_stb_radio0,
- output wire [ 1-1:0] radio_rx_running_radio0,
- output wire [ 32-1:0] radio_tx_data_radio0,
- input wire [ 1-1:0] radio_tx_stb_radio0,
- output wire [ 1-1:0] radio_tx_running_radio0,
-// radio_ch1
- input wire [ 32-1:0] radio_rx_data_radio1,
- input wire [ 1-1:0] radio_rx_stb_radio1,
- output wire [ 1-1:0] radio_rx_running_radio1,
- output wire [ 32-1:0] radio_tx_data_radio1,
- input wire [ 1-1:0] radio_tx_stb_radio1,
- output wire [ 1-1:0] radio_tx_running_radio1,
-// dram
- input wire [ 1-1:0] axi_rst,
- output wire [ 4-1:0] m_axi_awid,
- output wire [128-1:0] m_axi_awaddr,
- output wire [ 32-1:0] m_axi_awlen,
- output wire [ 12-1:0] m_axi_awsize,
- output wire [ 8-1:0] m_axi_awburst,
- output wire [ 4-1:0] m_axi_awlock,
- output wire [ 16-1:0] m_axi_awcache,
- output wire [ 12-1:0] m_axi_awprot,
- output wire [ 16-1:0] m_axi_awqos,
- output wire [ 16-1:0] m_axi_awregion,
- output wire [ 4-1:0] m_axi_awuser,
- output wire [ 4-1:0] m_axi_awvalid,
- input wire [ 4-1:0] m_axi_awready,
- output wire [256-1:0] m_axi_wdata,
- output wire [ 32-1:0] m_axi_wstrb,
- output wire [ 4-1:0] m_axi_wlast,
- output wire [ 4-1:0] m_axi_wuser,
- output wire [ 4-1:0] m_axi_wvalid,
- input wire [ 4-1:0] m_axi_wready,
- input wire [ 4-1:0] m_axi_bid,
- input wire [ 8-1:0] m_axi_bresp,
- input wire [ 4-1:0] m_axi_buser,
- input wire [ 4-1:0] m_axi_bvalid,
- output wire [ 4-1:0] m_axi_bready,
- output wire [ 4-1:0] m_axi_arid,
- output wire [128-1:0] m_axi_araddr,
- output wire [ 32-1:0] m_axi_arlen,
- output wire [ 12-1:0] m_axi_arsize,
- output wire [ 8-1:0] m_axi_arburst,
- output wire [ 4-1:0] m_axi_arlock,
- output wire [ 16-1:0] m_axi_arcache,
- output wire [ 12-1:0] m_axi_arprot,
- output wire [ 16-1:0] m_axi_arqos,
- output wire [ 16-1:0] m_axi_arregion,
- output wire [ 4-1:0] m_axi_aruser,
- output wire [ 4-1:0] m_axi_arvalid,
- input wire [ 4-1:0] m_axi_arready,
- input wire [ 4-1:0] m_axi_rid,
- input wire [256-1:0] m_axi_rdata,
- input wire [ 8-1:0] m_axi_rresp,
- input wire [ 4-1:0] m_axi_rlast,
- input wire [ 4-1:0] m_axi_ruser,
- input wire [ 4-1:0] m_axi_rvalid,
- output wire [ 4-1:0] m_axi_rready,
- // Transport 0 (eth0 1G)
- input wire [64-1:0] s_eth0_tdata,
- input wire s_eth0_tlast,
- input wire s_eth0_tvalid,
- output wire s_eth0_tready,
- output wire [64-1:0] m_eth0_tdata,
- output wire m_eth0_tlast,
- output wire m_eth0_tvalid,
- input wire m_eth0_tready,
- // Transport 1 (eth1 10G)
- input wire [64-1:0] s_eth1_tdata,
- input wire s_eth1_tlast,
- input wire s_eth1_tvalid,
- output wire s_eth1_tready,
- output wire [64-1:0] m_eth1_tdata,
- output wire m_eth1_tlast,
- output wire m_eth1_tvalid,
- input wire m_eth1_tready,
- // Transport 2 (dma dma)
- input wire [64-1:0] s_dma_tdata,
- input wire s_dma_tlast,
- input wire s_dma_tvalid,
- output wire s_dma_tready,
- output wire [64-1:0] m_dma_tdata,
- output wire m_dma_tlast,
- output wire m_dma_tvalid,
- input wire m_dma_tready
+ 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_keeper
+ input wire [ 63:0] radio_time,
+ // radio_ch0
+ input wire [ 31:0] radio_rx_data_radio0,
+ input wire [ 0:0] radio_rx_stb_radio0,
+ output wire [ 0:0] radio_rx_running_radio0,
+ output wire [ 31:0] radio_tx_data_radio0,
+ input wire [ 0:0] radio_tx_stb_radio0,
+ output wire [ 0:0] radio_tx_running_radio0,
+ // radio_ch1
+ input wire [ 31:0] radio_rx_data_radio1,
+ input wire [ 0:0] radio_rx_stb_radio1,
+ output wire [ 0:0] radio_rx_running_radio1,
+ output wire [ 31:0] radio_tx_data_radio1,
+ input wire [ 0:0] radio_tx_stb_radio1,
+ output wire [ 0:0] radio_tx_running_radio1,
+ // dram
+ input wire [ 0:0] axi_rst,
+ output wire [ 3:0] m_axi_awid,
+ output wire [ 127: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 [ 255:0] m_axi_wdata,
+ output wire [ 31: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 [ 127: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 [ 255: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 (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 CHDR_W = 64;
- localparam MTU = 10;
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;
@@ -194,12 +212,12 @@ module rfnoc_image_core #(
.clk (rfnoc_chdr_clk),
.reset (rfnoc_chdr_rst),
.device_id (device_id),
- .s_axis_tdata ({ep5_to_xb_tdata, ep4_to_xb_tdata, ep1_to_xb_tdata, ep0_to_xb_tdata, s_dma_tdata, s_eth1_tdata, s_eth0_tdata}),
- .s_axis_tlast ({ep5_to_xb_tlast, ep4_to_xb_tlast, ep1_to_xb_tlast, ep0_to_xb_tlast, s_dma_tlast, s_eth1_tlast, s_eth0_tlast}),
+ .s_axis_tdata ({ep5_to_xb_tdata , ep4_to_xb_tdata , ep1_to_xb_tdata , ep0_to_xb_tdata , s_dma_tdata , s_eth1_tdata , s_eth0_tdata }),
+ .s_axis_tlast ({ep5_to_xb_tlast , ep4_to_xb_tlast , ep1_to_xb_tlast , ep0_to_xb_tlast , s_dma_tlast , s_eth1_tlast , s_eth0_tlast }),
.s_axis_tvalid ({ep5_to_xb_tvalid, ep4_to_xb_tvalid, ep1_to_xb_tvalid, ep0_to_xb_tvalid, s_dma_tvalid, s_eth1_tvalid, s_eth0_tvalid}),
.s_axis_tready ({ep5_to_xb_tready, ep4_to_xb_tready, ep1_to_xb_tready, ep0_to_xb_tready, s_dma_tready, s_eth1_tready, s_eth0_tready}),
- .m_axis_tdata ({xb_to_ep5_tdata, xb_to_ep4_tdata, xb_to_ep1_tdata, xb_to_ep0_tdata, m_dma_tdata, m_eth1_tdata, m_eth0_tdata}),
- .m_axis_tlast ({xb_to_ep5_tlast, xb_to_ep4_tlast, xb_to_ep1_tlast, xb_to_ep0_tlast, m_dma_tlast, m_eth1_tlast, m_eth0_tlast}),
+ .m_axis_tdata ({xb_to_ep5_tdata , xb_to_ep4_tdata , xb_to_ep1_tdata , xb_to_ep0_tdata , m_dma_tdata , m_eth1_tdata , m_eth0_tdata }),
+ .m_axis_tlast ({xb_to_ep5_tlast , xb_to_ep4_tlast , xb_to_ep1_tlast , xb_to_ep0_tlast , m_dma_tlast , m_eth1_tlast , m_eth0_tlast }),
.m_axis_tvalid ({xb_to_ep5_tvalid, xb_to_ep4_tvalid, xb_to_ep1_tvalid, xb_to_ep0_tvalid, m_dma_tvalid, m_eth1_tvalid, m_eth0_tvalid}),
.m_axis_tready ({xb_to_ep5_tready, xb_to_ep4_tready, xb_to_ep1_tready, xb_to_ep0_tready, m_dma_tready, m_eth1_tready, m_eth0_tready}),
.ext_rtcfg_stb (1'h0),
@@ -208,9 +226,18 @@ module rfnoc_image_core #(
.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;
+ 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;
@@ -220,8 +247,8 @@ module rfnoc_image_core #(
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 [ 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;
@@ -234,23 +261,23 @@ module rfnoc_image_core #(
.NUM_DATA_O (1),
.INST_NUM (0),
.CTRL_XBAR_PORT (1),
- .INGRESS_BUFF_SIZE (15),
+ .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 ),
+ .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}),
@@ -259,20 +286,28 @@ module rfnoc_image_core #(
.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_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_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 )
+ .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;
+ 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;
@@ -281,8 +316,8 @@ module rfnoc_image_core #(
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 [ 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;
@@ -295,23 +330,23 @@ module rfnoc_image_core #(
.NUM_DATA_O (1),
.INST_NUM (1),
.CTRL_XBAR_PORT (2),
- .INGRESS_BUFF_SIZE (15),
+ .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 ),
+ .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}),
@@ -320,20 +355,28 @@ module rfnoc_image_core #(
.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_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_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 )
+ .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;
+ 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;
@@ -342,8 +385,8 @@ module rfnoc_image_core #(
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 [ 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;
@@ -356,23 +399,23 @@ module rfnoc_image_core #(
.NUM_DATA_O (1),
.INST_NUM (2),
.CTRL_XBAR_PORT (3),
- .INGRESS_BUFF_SIZE (15),
+ .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 ),
+ .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}),
@@ -381,20 +424,28 @@ module rfnoc_image_core #(
.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_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_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 )
+ .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;
+ 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;
@@ -403,8 +454,8 @@ module rfnoc_image_core #(
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 [ 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;
@@ -417,23 +468,23 @@ module rfnoc_image_core #(
.NUM_DATA_O (1),
.INST_NUM (3),
.CTRL_XBAR_PORT (4),
- .INGRESS_BUFF_SIZE (15),
+ .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 ),
+ .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}),
@@ -442,42 +493,41 @@ module rfnoc_image_core #(
.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_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_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 )
+ .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_fifo0_ctrl_tdata , s_fifo0_ctrl_tdata ;
- wire m_fifo0_ctrl_tlast , s_fifo0_ctrl_tlast ;
- wire m_fifo0_ctrl_tvalid, s_fifo0_ctrl_tvalid;
- wire m_fifo0_ctrl_tready, s_fifo0_ctrl_tready;
+ //---------------------------------------------------------------------------
+
+ 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_fifo0_ctrl_tdata, s_fifo0_ctrl_tdata;
+ wire m_fifo0_ctrl_tlast, s_fifo0_ctrl_tlast;
+ wire m_fifo0_ctrl_tvalid, s_fifo0_ctrl_tvalid;
+ wire m_fifo0_ctrl_tready, s_fifo0_ctrl_tready;
axis_ctrl_crossbar_nxn #(
.WIDTH (32),
@@ -501,9 +551,11 @@ module rfnoc_image_core #(
.deadlock_detected()
);
- // ----------------------------------------------------
+
+ //---------------------------------------------------------------------------
// RFNoC Core Kernel
- // ----------------------------------------------------
+ //---------------------------------------------------------------------------
+
wire [(512*3)-1:0] rfnoc_core_config, rfnoc_core_status;
rfnoc_core_kernel #(
@@ -528,12 +580,12 @@ module rfnoc_image_core #(
.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_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_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),
@@ -541,13 +593,15 @@ module rfnoc_image_core #(
.rfnoc_core_status (rfnoc_core_status)
);
- // ----------------------------------------------------
+
+ //---------------------------------------------------------------------------
// Blocks
- // ----------------------------------------------------
+ //---------------------------------------------------------------------------
- // ----------------------------------------------------
+ //-----------------------------------
// radio0
- // ----------------------------------------------------
+ //-----------------------------------
+
wire radio0_radio_clk;
wire [CHDR_W-1:0] s_radio0_in_0_tdata ;
wire s_radio0_in_0_tlast ;
@@ -558,79 +612,77 @@ module rfnoc_image_core #(
wire m_radio0_out_0_tvalid;
wire m_radio0_out_0_tready;
- // ctrl_port
- wire [ 1-1:0] radio0_m_ctrlport_req_wr;
- wire [ 1-1:0] radio0_m_ctrlport_req_rd;
- wire [ 20-1:0] radio0_m_ctrlport_req_addr;
- wire [ 32-1:0] radio0_m_ctrlport_req_data;
- wire [ 4-1:0] radio0_m_ctrlport_req_byte_en;
- wire [ 1-1:0] radio0_m_ctrlport_req_has_time;
- wire [ 64-1:0] radio0_m_ctrlport_req_time;
- wire [ 1-1:0] radio0_m_ctrlport_resp_ack;
- wire [ 2-1:0] radio0_m_ctrlport_resp_status;
- wire [ 32-1:0] radio0_m_ctrlport_resp_data;
- // time_keeper
- wire [ 64-1:0] radio0_radio_time;
- // radio_iface
- wire [ 32-1:0] radio0_radio_rx_data;
- wire [ 1-1:0] radio0_radio_rx_stb;
- wire [ 1-1:0] radio0_radio_rx_running;
- wire [ 32-1:0] radio0_radio_tx_data;
- wire [ 1-1:0] radio0_radio_tx_stb;
- wire [ 1-1:0] radio0_radio_tx_running;
+ // ctrl_port
+ 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_keeper
+ wire [ 63:0] radio0_radio_time;
+ // radio_iface
+ wire [ 31:0] radio0_radio_rx_data;
+ wire [ 0:0] radio0_radio_rx_stb;
+ wire [ 0:0] radio0_radio_rx_running;
+ wire [ 31:0] radio0_radio_tx_data;
+ wire [ 0:0] radio0_radio_tx_stb;
+ wire [ 0:0] radio0_radio_tx_running;
rfnoc_block_radio #(
- .THIS_PORTID(2),
- .CHDR_W(CHDR_W),
- .NUM_PORTS(1),
- .MTU(MTU)
+ .THIS_PORTID (2),
+ .CHDR_W (CHDR_W),
+ .NUM_PORTS (1),
+ .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),
+ .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_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_0_tdata }),
- .s_rfnoc_chdr_tlast ({s_radio0_in_0_tlast }),
- .s_rfnoc_chdr_tvalid({s_radio0_in_0_tvalid}),
- .s_rfnoc_chdr_tready({s_radio0_in_0_tready}),
- .m_rfnoc_chdr_tdata ({m_radio0_out_0_tdata }),
- .m_rfnoc_chdr_tlast ({m_radio0_out_0_tlast }),
- .m_rfnoc_chdr_tvalid({m_radio0_out_0_tvalid}),
- .m_rfnoc_chdr_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)
+ .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_0_tdata }),
+ .s_rfnoc_chdr_tlast ({s_radio0_in_0_tlast }),
+ .s_rfnoc_chdr_tvalid ({s_radio0_in_0_tvalid}),
+ .s_rfnoc_chdr_tready ({s_radio0_in_0_tready}),
+ .m_rfnoc_chdr_tdata ({m_radio0_out_0_tdata }),
+ .m_rfnoc_chdr_tlast ({m_radio0_out_0_tlast }),
+ .m_rfnoc_chdr_tvalid ({m_radio0_out_0_tvalid}),
+ .m_rfnoc_chdr_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_0_tdata ;
wire s_radio1_in_0_tlast ;
@@ -641,79 +693,77 @@ module rfnoc_image_core #(
wire m_radio1_out_0_tvalid;
wire m_radio1_out_0_tready;
- // ctrl_port
- wire [ 1-1:0] radio1_m_ctrlport_req_wr;
- wire [ 1-1:0] radio1_m_ctrlport_req_rd;
- wire [ 20-1:0] radio1_m_ctrlport_req_addr;
- wire [ 32-1:0] radio1_m_ctrlport_req_data;
- wire [ 4-1:0] radio1_m_ctrlport_req_byte_en;
- wire [ 1-1:0] radio1_m_ctrlport_req_has_time;
- wire [ 64-1:0] radio1_m_ctrlport_req_time;
- wire [ 1-1:0] radio1_m_ctrlport_resp_ack;
- wire [ 2-1:0] radio1_m_ctrlport_resp_status;
- wire [ 32-1:0] radio1_m_ctrlport_resp_data;
- // time_keeper
- wire [ 64-1:0] radio1_radio_time;
- // radio_iface
- wire [ 32-1:0] radio1_radio_rx_data;
- wire [ 1-1:0] radio1_radio_rx_stb;
- wire [ 1-1:0] radio1_radio_rx_running;
- wire [ 32-1:0] radio1_radio_tx_data;
- wire [ 1-1:0] radio1_radio_tx_stb;
- wire [ 1-1:0] radio1_radio_tx_running;
+ // ctrl_port
+ 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_keeper
+ wire [ 63:0] radio1_radio_time;
+ // radio_iface
+ wire [ 31:0] radio1_radio_rx_data;
+ wire [ 0:0] radio1_radio_rx_stb;
+ wire [ 0:0] radio1_radio_rx_running;
+ wire [ 31:0] radio1_radio_tx_data;
+ wire [ 0:0] radio1_radio_tx_stb;
+ wire [ 0:0] radio1_radio_tx_running;
rfnoc_block_radio #(
- .THIS_PORTID(3),
- .CHDR_W(CHDR_W),
- .NUM_PORTS(1),
- .MTU(MTU)
+ .THIS_PORTID (3),
+ .CHDR_W (CHDR_W),
+ .NUM_PORTS (1),
+ .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),
+ .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_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_0_tdata }),
- .s_rfnoc_chdr_tlast ({s_radio1_in_0_tlast }),
- .s_rfnoc_chdr_tvalid({s_radio1_in_0_tvalid}),
- .s_rfnoc_chdr_tready({s_radio1_in_0_tready}),
- .m_rfnoc_chdr_tdata ({m_radio1_out_0_tdata }),
- .m_rfnoc_chdr_tlast ({m_radio1_out_0_tlast }),
- .m_rfnoc_chdr_tvalid({m_radio1_out_0_tvalid}),
- .m_rfnoc_chdr_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)
+ .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_0_tdata }),
+ .s_rfnoc_chdr_tlast ({s_radio1_in_0_tlast }),
+ .s_rfnoc_chdr_tvalid ({s_radio1_in_0_tvalid}),
+ .s_rfnoc_chdr_tready ({s_radio1_in_0_tready}),
+ .m_rfnoc_chdr_tdata ({m_radio1_out_0_tdata }),
+ .m_rfnoc_chdr_tlast ({m_radio1_out_0_tlast }),
+ .m_rfnoc_chdr_tvalid ({m_radio1_out_0_tvalid}),
+ .m_rfnoc_chdr_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)
);
-
- // ----------------------------------------------------
+ //-----------------------------------
// fifo0
- // ----------------------------------------------------
+ //-----------------------------------
+
wire fifo0_mem_clk;
wire [CHDR_W-1:0] s_fifo0_in_3_tdata , s_fifo0_in_2_tdata , s_fifo0_in_1_tdata , s_fifo0_in_0_tdata ;
wire s_fifo0_in_3_tlast , s_fifo0_in_2_tlast , s_fifo0_in_1_tlast , s_fifo0_in_0_tlast ;
@@ -724,182 +774,181 @@ module rfnoc_image_core #(
wire m_fifo0_out_3_tvalid, m_fifo0_out_2_tvalid, m_fifo0_out_1_tvalid, m_fifo0_out_0_tvalid;
wire m_fifo0_out_3_tready, m_fifo0_out_2_tready, m_fifo0_out_1_tready, m_fifo0_out_0_tready;
- // axi_ram
- wire [ 1-1:0] fifo0_axi_rst;
- wire [ 4-1:0] fifo0_m_axi_awid;
- wire [128-1:0] fifo0_m_axi_awaddr;
- wire [ 32-1:0] fifo0_m_axi_awlen;
- wire [ 12-1:0] fifo0_m_axi_awsize;
- wire [ 8-1:0] fifo0_m_axi_awburst;
- wire [ 4-1:0] fifo0_m_axi_awlock;
- wire [ 16-1:0] fifo0_m_axi_awcache;
- wire [ 12-1:0] fifo0_m_axi_awprot;
- wire [ 16-1:0] fifo0_m_axi_awqos;
- wire [ 16-1:0] fifo0_m_axi_awregion;
- wire [ 4-1:0] fifo0_m_axi_awuser;
- wire [ 4-1:0] fifo0_m_axi_awvalid;
- wire [ 4-1:0] fifo0_m_axi_awready;
- wire [256-1:0] fifo0_m_axi_wdata;
- wire [ 32-1:0] fifo0_m_axi_wstrb;
- wire [ 4-1:0] fifo0_m_axi_wlast;
- wire [ 4-1:0] fifo0_m_axi_wuser;
- wire [ 4-1:0] fifo0_m_axi_wvalid;
- wire [ 4-1:0] fifo0_m_axi_wready;
- wire [ 4-1:0] fifo0_m_axi_bid;
- wire [ 8-1:0] fifo0_m_axi_bresp;
- wire [ 4-1:0] fifo0_m_axi_buser;
- wire [ 4-1:0] fifo0_m_axi_bvalid;
- wire [ 4-1:0] fifo0_m_axi_bready;
- wire [ 4-1:0] fifo0_m_axi_arid;
- wire [128-1:0] fifo0_m_axi_araddr;
- wire [ 32-1:0] fifo0_m_axi_arlen;
- wire [ 12-1:0] fifo0_m_axi_arsize;
- wire [ 8-1:0] fifo0_m_axi_arburst;
- wire [ 4-1:0] fifo0_m_axi_arlock;
- wire [ 16-1:0] fifo0_m_axi_arcache;
- wire [ 12-1:0] fifo0_m_axi_arprot;
- wire [ 16-1:0] fifo0_m_axi_arqos;
- wire [ 16-1:0] fifo0_m_axi_arregion;
- wire [ 4-1:0] fifo0_m_axi_aruser;
- wire [ 4-1:0] fifo0_m_axi_arvalid;
- wire [ 4-1:0] fifo0_m_axi_arready;
- wire [ 4-1:0] fifo0_m_axi_rid;
- wire [256-1:0] fifo0_m_axi_rdata;
- wire [ 8-1:0] fifo0_m_axi_rresp;
- wire [ 4-1:0] fifo0_m_axi_rlast;
- wire [ 4-1:0] fifo0_m_axi_ruser;
- wire [ 4-1:0] fifo0_m_axi_rvalid;
- wire [ 4-1:0] fifo0_m_axi_rready;
+ // axi_ram
+ wire [ 0:0] fifo0_axi_rst;
+ wire [ 3:0] fifo0_m_axi_awid;
+ wire [ 127:0] fifo0_m_axi_awaddr;
+ wire [ 31:0] fifo0_m_axi_awlen;
+ wire [ 11:0] fifo0_m_axi_awsize;
+ wire [ 7:0] fifo0_m_axi_awburst;
+ wire [ 3:0] fifo0_m_axi_awlock;
+ wire [ 15:0] fifo0_m_axi_awcache;
+ wire [ 11:0] fifo0_m_axi_awprot;
+ wire [ 15:0] fifo0_m_axi_awqos;
+ wire [ 15:0] fifo0_m_axi_awregion;
+ wire [ 3:0] fifo0_m_axi_awuser;
+ wire [ 3:0] fifo0_m_axi_awvalid;
+ wire [ 3:0] fifo0_m_axi_awready;
+ wire [ 255:0] fifo0_m_axi_wdata;
+ wire [ 31:0] fifo0_m_axi_wstrb;
+ wire [ 3:0] fifo0_m_axi_wlast;
+ wire [ 3:0] fifo0_m_axi_wuser;
+ wire [ 3:0] fifo0_m_axi_wvalid;
+ wire [ 3:0] fifo0_m_axi_wready;
+ wire [ 3:0] fifo0_m_axi_bid;
+ wire [ 7:0] fifo0_m_axi_bresp;
+ wire [ 3:0] fifo0_m_axi_buser;
+ wire [ 3:0] fifo0_m_axi_bvalid;
+ wire [ 3:0] fifo0_m_axi_bready;
+ wire [ 3:0] fifo0_m_axi_arid;
+ wire [ 127:0] fifo0_m_axi_araddr;
+ wire [ 31:0] fifo0_m_axi_arlen;
+ wire [ 11:0] fifo0_m_axi_arsize;
+ wire [ 7:0] fifo0_m_axi_arburst;
+ wire [ 3:0] fifo0_m_axi_arlock;
+ wire [ 15:0] fifo0_m_axi_arcache;
+ wire [ 11:0] fifo0_m_axi_arprot;
+ wire [ 15:0] fifo0_m_axi_arqos;
+ wire [ 15:0] fifo0_m_axi_arregion;
+ wire [ 3:0] fifo0_m_axi_aruser;
+ wire [ 3:0] fifo0_m_axi_arvalid;
+ wire [ 3:0] fifo0_m_axi_arready;
+ wire [ 3:0] fifo0_m_axi_rid;
+ wire [ 255:0] fifo0_m_axi_rdata;
+ wire [ 7:0] fifo0_m_axi_rresp;
+ wire [ 3:0] fifo0_m_axi_rlast;
+ wire [ 3:0] fifo0_m_axi_ruser;
+ wire [ 3:0] fifo0_m_axi_rvalid;
+ wire [ 3:0] fifo0_m_axi_rready;
rfnoc_block_axi_ram_fifo #(
- .THIS_PORTID(4),
- .CHDR_W(CHDR_W),
- .NUM_PORTS(4),
- .MEM_DATA_W(64),
- .MEM_ADDR_W(31),
- .FIFO_ADDR_BASE({30'h06000000, 30'h04000000, 30'h02000000, 30'h00000000}),
- .FIFO_ADDR_MASK({30'h01FFFFFF, 30'h01FFFFFF, 30'h01FFFFFF, 30'h01FFFFFF}),
- .MEM_CLK_RATE(303819444),
- .MTU(MTU)
+ .THIS_PORTID (4),
+ .CHDR_W (CHDR_W),
+ .NUM_PORTS (4),
+ .MEM_DATA_W (64),
+ .MEM_ADDR_W (31),
+ .FIFO_ADDR_BASE ({30'h06000000, 30'h04000000, 30'h02000000, 30'h00000000}),
+ .FIFO_ADDR_MASK ({30'h01FFFFFF, 30'h01FFFFFF, 30'h01FFFFFF, 30'h01FFFFFF}),
+ .MEM_CLK_RATE (303819444),
+ .MTU (MTU)
) b_fifo0_2 (
- .rfnoc_chdr_clk (rfnoc_chdr_clk),
- .rfnoc_ctrl_clk (rfnoc_ctrl_clk),
- .mem_clk(fifo0_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(fifo0_axi_rst),
- .m_axi_awid(fifo0_m_axi_awid),
- .m_axi_awaddr(fifo0_m_axi_awaddr),
- .m_axi_awlen(fifo0_m_axi_awlen),
- .m_axi_awsize(fifo0_m_axi_awsize),
- .m_axi_awburst(fifo0_m_axi_awburst),
- .m_axi_awlock(fifo0_m_axi_awlock),
- .m_axi_awcache(fifo0_m_axi_awcache),
- .m_axi_awprot(fifo0_m_axi_awprot),
- .m_axi_awqos(fifo0_m_axi_awqos),
- .m_axi_awregion(fifo0_m_axi_awregion),
- .m_axi_awuser(fifo0_m_axi_awuser),
- .m_axi_awvalid(fifo0_m_axi_awvalid),
- .m_axi_awready(fifo0_m_axi_awready),
- .m_axi_wdata(fifo0_m_axi_wdata),
- .m_axi_wstrb(fifo0_m_axi_wstrb),
- .m_axi_wlast(fifo0_m_axi_wlast),
- .m_axi_wuser(fifo0_m_axi_wuser),
- .m_axi_wvalid(fifo0_m_axi_wvalid),
- .m_axi_wready(fifo0_m_axi_wready),
- .m_axi_bid(fifo0_m_axi_bid),
- .m_axi_bresp(fifo0_m_axi_bresp),
- .m_axi_buser(fifo0_m_axi_buser),
- .m_axi_bvalid(fifo0_m_axi_bvalid),
- .m_axi_bready(fifo0_m_axi_bready),
- .m_axi_arid(fifo0_m_axi_arid),
- .m_axi_araddr(fifo0_m_axi_araddr),
- .m_axi_arlen(fifo0_m_axi_arlen),
- .m_axi_arsize(fifo0_m_axi_arsize),
- .m_axi_arburst(fifo0_m_axi_arburst),
- .m_axi_arlock(fifo0_m_axi_arlock),
- .m_axi_arcache(fifo0_m_axi_arcache),
- .m_axi_arprot(fifo0_m_axi_arprot),
- .m_axi_arqos(fifo0_m_axi_arqos),
- .m_axi_arregion(fifo0_m_axi_arregion),
- .m_axi_aruser(fifo0_m_axi_aruser),
- .m_axi_arvalid(fifo0_m_axi_arvalid),
- .m_axi_arready(fifo0_m_axi_arready),
- .m_axi_rid(fifo0_m_axi_rid),
- .m_axi_rdata(fifo0_m_axi_rdata),
- .m_axi_rresp(fifo0_m_axi_rresp),
- .m_axi_rlast(fifo0_m_axi_rlast),
- .m_axi_ruser(fifo0_m_axi_ruser),
- .m_axi_rvalid(fifo0_m_axi_rvalid),
- .m_axi_rready(fifo0_m_axi_rready),
-
- .s_rfnoc_chdr_tdata ({s_fifo0_in_3_tdata , s_fifo0_in_2_tdata , s_fifo0_in_1_tdata , s_fifo0_in_0_tdata }),
- .s_rfnoc_chdr_tlast ({s_fifo0_in_3_tlast , s_fifo0_in_2_tlast , s_fifo0_in_1_tlast , s_fifo0_in_0_tlast }),
- .s_rfnoc_chdr_tvalid({s_fifo0_in_3_tvalid, s_fifo0_in_2_tvalid, s_fifo0_in_1_tvalid, s_fifo0_in_0_tvalid}),
- .s_rfnoc_chdr_tready({s_fifo0_in_3_tready, s_fifo0_in_2_tready, s_fifo0_in_1_tready, s_fifo0_in_0_tready}),
- .m_rfnoc_chdr_tdata ({m_fifo0_out_3_tdata , m_fifo0_out_2_tdata , m_fifo0_out_1_tdata , m_fifo0_out_0_tdata }),
- .m_rfnoc_chdr_tlast ({m_fifo0_out_3_tlast , m_fifo0_out_2_tlast , m_fifo0_out_1_tlast , m_fifo0_out_0_tlast }),
- .m_rfnoc_chdr_tvalid({m_fifo0_out_3_tvalid, m_fifo0_out_2_tvalid, m_fifo0_out_1_tvalid, m_fifo0_out_0_tvalid}),
- .m_rfnoc_chdr_tready({m_fifo0_out_3_tready, m_fifo0_out_2_tready, m_fifo0_out_1_tready, m_fifo0_out_0_tready}),
- .s_rfnoc_ctrl_tdata (s_fifo0_ctrl_tdata ),
- .s_rfnoc_ctrl_tlast (s_fifo0_ctrl_tlast ),
- .s_rfnoc_ctrl_tvalid(s_fifo0_ctrl_tvalid),
- .s_rfnoc_ctrl_tready(s_fifo0_ctrl_tready),
- .m_rfnoc_ctrl_tdata (m_fifo0_ctrl_tdata ),
- .m_rfnoc_ctrl_tlast (m_fifo0_ctrl_tlast ),
- .m_rfnoc_ctrl_tvalid(m_fifo0_ctrl_tvalid),
- .m_rfnoc_ctrl_tready(m_fifo0_ctrl_tready)
+ .rfnoc_chdr_clk (rfnoc_chdr_clk),
+ .rfnoc_ctrl_clk (rfnoc_ctrl_clk),
+ .mem_clk (fifo0_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 (fifo0_axi_rst),
+ .m_axi_awid (fifo0_m_axi_awid),
+ .m_axi_awaddr (fifo0_m_axi_awaddr),
+ .m_axi_awlen (fifo0_m_axi_awlen),
+ .m_axi_awsize (fifo0_m_axi_awsize),
+ .m_axi_awburst (fifo0_m_axi_awburst),
+ .m_axi_awlock (fifo0_m_axi_awlock),
+ .m_axi_awcache (fifo0_m_axi_awcache),
+ .m_axi_awprot (fifo0_m_axi_awprot),
+ .m_axi_awqos (fifo0_m_axi_awqos),
+ .m_axi_awregion (fifo0_m_axi_awregion),
+ .m_axi_awuser (fifo0_m_axi_awuser),
+ .m_axi_awvalid (fifo0_m_axi_awvalid),
+ .m_axi_awready (fifo0_m_axi_awready),
+ .m_axi_wdata (fifo0_m_axi_wdata),
+ .m_axi_wstrb (fifo0_m_axi_wstrb),
+ .m_axi_wlast (fifo0_m_axi_wlast),
+ .m_axi_wuser (fifo0_m_axi_wuser),
+ .m_axi_wvalid (fifo0_m_axi_wvalid),
+ .m_axi_wready (fifo0_m_axi_wready),
+ .m_axi_bid (fifo0_m_axi_bid),
+ .m_axi_bresp (fifo0_m_axi_bresp),
+ .m_axi_buser (fifo0_m_axi_buser),
+ .m_axi_bvalid (fifo0_m_axi_bvalid),
+ .m_axi_bready (fifo0_m_axi_bready),
+ .m_axi_arid (fifo0_m_axi_arid),
+ .m_axi_araddr (fifo0_m_axi_araddr),
+ .m_axi_arlen (fifo0_m_axi_arlen),
+ .m_axi_arsize (fifo0_m_axi_arsize),
+ .m_axi_arburst (fifo0_m_axi_arburst),
+ .m_axi_arlock (fifo0_m_axi_arlock),
+ .m_axi_arcache (fifo0_m_axi_arcache),
+ .m_axi_arprot (fifo0_m_axi_arprot),
+ .m_axi_arqos (fifo0_m_axi_arqos),
+ .m_axi_arregion (fifo0_m_axi_arregion),
+ .m_axi_aruser (fifo0_m_axi_aruser),
+ .m_axi_arvalid (fifo0_m_axi_arvalid),
+ .m_axi_arready (fifo0_m_axi_arready),
+ .m_axi_rid (fifo0_m_axi_rid),
+ .m_axi_rdata (fifo0_m_axi_rdata),
+ .m_axi_rresp (fifo0_m_axi_rresp),
+ .m_axi_rlast (fifo0_m_axi_rlast),
+ .m_axi_ruser (fifo0_m_axi_ruser),
+ .m_axi_rvalid (fifo0_m_axi_rvalid),
+ .m_axi_rready (fifo0_m_axi_rready),
+ .s_rfnoc_chdr_tdata ({s_fifo0_in_3_tdata , s_fifo0_in_2_tdata , s_fifo0_in_1_tdata , s_fifo0_in_0_tdata }),
+ .s_rfnoc_chdr_tlast ({s_fifo0_in_3_tlast , s_fifo0_in_2_tlast , s_fifo0_in_1_tlast , s_fifo0_in_0_tlast }),
+ .s_rfnoc_chdr_tvalid ({s_fifo0_in_3_tvalid, s_fifo0_in_2_tvalid, s_fifo0_in_1_tvalid, s_fifo0_in_0_tvalid}),
+ .s_rfnoc_chdr_tready ({s_fifo0_in_3_tready, s_fifo0_in_2_tready, s_fifo0_in_1_tready, s_fifo0_in_0_tready}),
+ .m_rfnoc_chdr_tdata ({m_fifo0_out_3_tdata , m_fifo0_out_2_tdata , m_fifo0_out_1_tdata , m_fifo0_out_0_tdata }),
+ .m_rfnoc_chdr_tlast ({m_fifo0_out_3_tlast , m_fifo0_out_2_tlast , m_fifo0_out_1_tlast , m_fifo0_out_0_tlast }),
+ .m_rfnoc_chdr_tvalid ({m_fifo0_out_3_tvalid, m_fifo0_out_2_tvalid, m_fifo0_out_1_tvalid, m_fifo0_out_0_tvalid}),
+ .m_rfnoc_chdr_tready ({m_fifo0_out_3_tready, m_fifo0_out_2_tready, m_fifo0_out_1_tready, m_fifo0_out_0_tready}),
+ .s_rfnoc_ctrl_tdata (s_fifo0_ctrl_tdata),
+ .s_rfnoc_ctrl_tlast (s_fifo0_ctrl_tlast),
+ .s_rfnoc_ctrl_tvalid (s_fifo0_ctrl_tvalid),
+ .s_rfnoc_ctrl_tready (s_fifo0_ctrl_tready),
+ .m_rfnoc_ctrl_tdata (m_fifo0_ctrl_tdata),
+ .m_rfnoc_ctrl_tlast (m_fifo0_ctrl_tlast),
+ .m_rfnoc_ctrl_tvalid (m_fifo0_ctrl_tvalid),
+ .m_rfnoc_ctrl_tready (m_fifo0_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_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_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_radio1_in_0_tdata = m_ep1_out0_tdata ;
- assign s_radio1_in_0_tlast = m_ep1_out0_tlast ;
+ assign s_radio1_in_0_tdata = m_ep1_out0_tdata;
+ assign s_radio1_in_0_tlast = m_ep1_out0_tlast;
assign s_radio1_in_0_tvalid = m_ep1_out0_tvalid;
assign m_ep1_out0_tready = s_radio1_in_0_tready;
- assign s_ep1_in0_tdata = m_radio1_out_0_tdata ;
- assign s_ep1_in0_tlast = m_radio1_out_0_tlast ;
+ assign s_ep1_in0_tdata = m_radio1_out_0_tdata;
+ assign s_ep1_in0_tlast = m_radio1_out_0_tlast;
assign s_ep1_in0_tvalid = m_radio1_out_0_tvalid;
assign m_radio1_out_0_tready = s_ep1_in0_tready;
- assign s_fifo0_in_0_tdata = m_ep4_out0_tdata ;
- assign s_fifo0_in_0_tlast = m_ep4_out0_tlast ;
+ assign s_fifo0_in_0_tdata = m_ep4_out0_tdata;
+ assign s_fifo0_in_0_tlast = m_ep4_out0_tlast;
assign s_fifo0_in_0_tvalid = m_ep4_out0_tvalid;
assign m_ep4_out0_tready = s_fifo0_in_0_tready;
- assign s_ep4_in0_tdata = m_fifo0_out_0_tdata ;
- assign s_ep4_in0_tlast = m_fifo0_out_0_tlast ;
+ assign s_ep4_in0_tdata = m_fifo0_out_0_tdata;
+ assign s_ep4_in0_tlast = m_fifo0_out_0_tlast;
assign s_ep4_in0_tvalid = m_fifo0_out_0_tvalid;
assign m_fifo0_out_0_tready = s_ep4_in0_tready;
- assign s_fifo0_in_1_tdata = m_ep5_out0_tdata ;
- assign s_fifo0_in_1_tlast = m_ep5_out0_tlast ;
+ assign s_fifo0_in_1_tdata = m_ep5_out0_tdata;
+ assign s_fifo0_in_1_tlast = m_ep5_out0_tlast;
assign s_fifo0_in_1_tvalid = m_ep5_out0_tvalid;
assign m_ep5_out0_tready = s_fifo0_in_1_tready;
- assign s_ep5_in0_tdata = m_fifo0_out_1_tdata ;
- assign s_ep5_in0_tlast = m_fifo0_out_1_tlast ;
+ assign s_ep5_in0_tdata = m_fifo0_out_1_tdata;
+ assign s_ep5_in0_tlast = m_fifo0_out_1_tlast;
assign s_ep5_in0_tvalid = m_fifo0_out_1_tvalid;
assign m_fifo0_out_1_tready = s_ep5_in0_tready;
- // ----------------------------------------------------
+ //---------------------------------------------------------------------------
// Unused Ports
- // ----------------------------------------------------
+ //---------------------------------------------------------------------------
+
assign s_fifo0_in_2_tdata = {CHDR_W{1'b0}};
assign s_fifo0_in_2_tlast = 1'b0;
assign s_fifo0_in_2_tvalid = 1'b0;
@@ -909,17 +958,20 @@ module rfnoc_image_core #(
assign m_fifo0_out_2_tready = 1'b1;
assign m_fifo0_out_3_tready = 1'b1;
- // ----------------------------------------------------
+
+ //---------------------------------------------------------------------------
// Clock Domains
- // ----------------------------------------------------
+ //---------------------------------------------------------------------------
+
assign radio0_radio_clk = radio_clk;
assign radio1_radio_clk = radio_clk;
assign fifo0_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;
@@ -1009,3 +1061,6 @@ module rfnoc_image_core #(
assign radio1_radio_time = radio_time;
endmodule
+
+
+`default_nettype wire
diff --git a/fpga/usrp3/top/n3xx/n320_rfnoc_image_core.v b/fpga/usrp3/top/n3xx/n320_rfnoc_image_core.v
index 6196836eb..0ea15f6c3 100644
--- a/fpga/usrp3/top/n3xx/n320_rfnoc_image_core.v
+++ b/fpga/usrp3/top/n3xx/n320_rfnoc_image_core.v
@@ -1,19 +1,32 @@
//
-// Copyright 2020 Ettus Research, A National Instruments Brand
+// Copyright 2021 Ettus Research, A National Instruments Brand
//
// SPDX-License-Identifier: LGPL-3.0-or-later
//
-
// Module: rfnoc_image_core (for n320)
-// This file was autogenerated by UHD's image builder tool (rfnoc_image_builder)
-// Re-running that tool will overwrite this file!
-// File generated on: 2020-09-02T12:03:04.264797
-// Source: ./n320_rfnoc_image_core.yml
-// Source SHA256: a059eb9043ce1c034abc0a0db7daad88a5e584207994c53030a98b3bea1bce39
+//
+// 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: 2021-05-03T08:51:09.950905
+// Source: n320_rfnoc_image_core.yml
+// Source SHA256: 3c3a33be8bc2e3b3a7268ba3e07001c6dc6c21af4c9027309a787ac8404e5e8f
+//
+
+`default_nettype none
+
module rfnoc_image_core #(
- parameter [15:0] PROTOVER = {8'd1, 8'd0}
-)(
+ parameter CHDR_W = 64,
+ parameter MTU = 10,
+ parameter [15:0] PROTOVER = {8'd1, 8'd0},
+ parameter RADIO_NIPC = 1
+) (
// Clocks
input wire chdr_aclk,
input wire ctrl_aclk,
@@ -21,131 +34,136 @@ module rfnoc_image_core #(
input wire radio_clk,
input wire dram_clk,
// Basic
- input wire [15:0] device_id,
-//// IO ports //////////////////////////////////
-// ctrlport_radio0
- output wire [ 1-1:0] m_ctrlport_radio0_req_wr,
- output wire [ 1-1:0] m_ctrlport_radio0_req_rd,
- output wire [ 20-1:0] m_ctrlport_radio0_req_addr,
- output wire [ 32-1:0] m_ctrlport_radio0_req_data,
- output wire [ 4-1:0] m_ctrlport_radio0_req_byte_en,
- output wire [ 1-1:0] m_ctrlport_radio0_req_has_time,
- output wire [ 64-1:0] m_ctrlport_radio0_req_time,
- input wire [ 1-1:0] m_ctrlport_radio0_resp_ack,
- input wire [ 2-1:0] m_ctrlport_radio0_resp_status,
- input wire [ 32-1:0] m_ctrlport_radio0_resp_data,
-// ctrlport_radio1
- output wire [ 1-1:0] m_ctrlport_radio1_req_wr,
- output wire [ 1-1:0] m_ctrlport_radio1_req_rd,
- output wire [ 20-1:0] m_ctrlport_radio1_req_addr,
- output wire [ 32-1:0] m_ctrlport_radio1_req_data,
- output wire [ 4-1:0] m_ctrlport_radio1_req_byte_en,
- output wire [ 1-1:0] m_ctrlport_radio1_req_has_time,
- output wire [ 64-1:0] m_ctrlport_radio1_req_time,
- input wire [ 1-1:0] m_ctrlport_radio1_resp_ack,
- input wire [ 2-1:0] m_ctrlport_radio1_resp_status,
- input wire [ 32-1:0] m_ctrlport_radio1_resp_data,
-// time_keeper
- input wire [ 64-1:0] radio_time,
-// radio_ch0
- input wire [ 32-1:0] radio_rx_data_radio0,
- input wire [ 1-1:0] radio_rx_stb_radio0,
- output wire [ 1-1:0] radio_rx_running_radio0,
- output wire [ 32-1:0] radio_tx_data_radio0,
- input wire [ 1-1:0] radio_tx_stb_radio0,
- output wire [ 1-1:0] radio_tx_running_radio0,
-// radio_ch1
- input wire [ 32-1:0] radio_rx_data_radio1,
- input wire [ 1-1:0] radio_rx_stb_radio1,
- output wire [ 1-1:0] radio_rx_running_radio1,
- output wire [ 32-1:0] radio_tx_data_radio1,
- input wire [ 1-1:0] radio_tx_stb_radio1,
- output wire [ 1-1:0] radio_tx_running_radio1,
-// dram
- input wire [ 1-1:0] axi_rst,
- output wire [ 4-1:0] m_axi_awid,
- output wire [128-1:0] m_axi_awaddr,
- output wire [ 32-1:0] m_axi_awlen,
- output wire [ 12-1:0] m_axi_awsize,
- output wire [ 8-1:0] m_axi_awburst,
- output wire [ 4-1:0] m_axi_awlock,
- output wire [ 16-1:0] m_axi_awcache,
- output wire [ 12-1:0] m_axi_awprot,
- output wire [ 16-1:0] m_axi_awqos,
- output wire [ 16-1:0] m_axi_awregion,
- output wire [ 4-1:0] m_axi_awuser,
- output wire [ 4-1:0] m_axi_awvalid,
- input wire [ 4-1:0] m_axi_awready,
- output wire [256-1:0] m_axi_wdata,
- output wire [ 32-1:0] m_axi_wstrb,
- output wire [ 4-1:0] m_axi_wlast,
- output wire [ 4-1:0] m_axi_wuser,
- output wire [ 4-1:0] m_axi_wvalid,
- input wire [ 4-1:0] m_axi_wready,
- input wire [ 4-1:0] m_axi_bid,
- input wire [ 8-1:0] m_axi_bresp,
- input wire [ 4-1:0] m_axi_buser,
- input wire [ 4-1:0] m_axi_bvalid,
- output wire [ 4-1:0] m_axi_bready,
- output wire [ 4-1:0] m_axi_arid,
- output wire [128-1:0] m_axi_araddr,
- output wire [ 32-1:0] m_axi_arlen,
- output wire [ 12-1:0] m_axi_arsize,
- output wire [ 8-1:0] m_axi_arburst,
- output wire [ 4-1:0] m_axi_arlock,
- output wire [ 16-1:0] m_axi_arcache,
- output wire [ 12-1:0] m_axi_arprot,
- output wire [ 16-1:0] m_axi_arqos,
- output wire [ 16-1:0] m_axi_arregion,
- output wire [ 4-1:0] m_axi_aruser,
- output wire [ 4-1:0] m_axi_arvalid,
- input wire [ 4-1:0] m_axi_arready,
- input wire [ 4-1:0] m_axi_rid,
- input wire [256-1:0] m_axi_rdata,
- input wire [ 8-1:0] m_axi_rresp,
- input wire [ 4-1:0] m_axi_rlast,
- input wire [ 4-1:0] m_axi_ruser,
- input wire [ 4-1:0] m_axi_rvalid,
- output wire [ 4-1:0] m_axi_rready,
- // Transport 0 (eth0 1G)
- input wire [64-1:0] s_eth0_tdata,
- input wire s_eth0_tlast,
- input wire s_eth0_tvalid,
- output wire s_eth0_tready,
- output wire [64-1:0] m_eth0_tdata,
- output wire m_eth0_tlast,
- output wire m_eth0_tvalid,
- input wire m_eth0_tready,
- // Transport 1 (eth1 10G)
- input wire [64-1:0] s_eth1_tdata,
- input wire s_eth1_tlast,
- input wire s_eth1_tvalid,
- output wire s_eth1_tready,
- output wire [64-1:0] m_eth1_tdata,
- output wire m_eth1_tlast,
- output wire m_eth1_tvalid,
- input wire m_eth1_tready,
- // Transport 2 (dma dma)
- input wire [64-1:0] s_dma_tdata,
- input wire s_dma_tlast,
- input wire s_dma_tvalid,
- output wire s_dma_tready,
- output wire [64-1:0] m_dma_tdata,
- output wire m_dma_tlast,
- output wire m_dma_tvalid,
- input wire m_dma_tready
+ 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_keeper
+ input wire [ 63:0] radio_time,
+ // radio_ch0
+ input wire [ 31:0] radio_rx_data_radio0,
+ input wire [ 0:0] radio_rx_stb_radio0,
+ output wire [ 0:0] radio_rx_running_radio0,
+ output wire [ 31:0] radio_tx_data_radio0,
+ input wire [ 0:0] radio_tx_stb_radio0,
+ output wire [ 0:0] radio_tx_running_radio0,
+ // radio_ch1
+ input wire [ 31:0] radio_rx_data_radio1,
+ input wire [ 0:0] radio_rx_stb_radio1,
+ output wire [ 0:0] radio_rx_running_radio1,
+ output wire [ 31:0] radio_tx_data_radio1,
+ input wire [ 0:0] radio_tx_stb_radio1,
+ output wire [ 0:0] radio_tx_running_radio1,
+ // dram
+ input wire [ 0:0] axi_rst,
+ output wire [ 3:0] m_axi_awid,
+ output wire [ 127: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 [ 255:0] m_axi_wdata,
+ output wire [ 31: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 [ 127: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 [ 255: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 (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 CHDR_W = 64;
- localparam MTU = 10;
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;
@@ -194,12 +212,12 @@ module rfnoc_image_core #(
.clk (rfnoc_chdr_clk),
.reset (rfnoc_chdr_rst),
.device_id (device_id),
- .s_axis_tdata ({ep3_to_xb_tdata, ep2_to_xb_tdata, ep1_to_xb_tdata, ep0_to_xb_tdata, s_dma_tdata, s_eth1_tdata, s_eth0_tdata}),
- .s_axis_tlast ({ep3_to_xb_tlast, ep2_to_xb_tlast, ep1_to_xb_tlast, ep0_to_xb_tlast, s_dma_tlast, s_eth1_tlast, s_eth0_tlast}),
+ .s_axis_tdata ({ep3_to_xb_tdata , ep2_to_xb_tdata , ep1_to_xb_tdata , ep0_to_xb_tdata , s_dma_tdata , s_eth1_tdata , s_eth0_tdata }),
+ .s_axis_tlast ({ep3_to_xb_tlast , ep2_to_xb_tlast , ep1_to_xb_tlast , ep0_to_xb_tlast , s_dma_tlast , s_eth1_tlast , s_eth0_tlast }),
.s_axis_tvalid ({ep3_to_xb_tvalid, ep2_to_xb_tvalid, ep1_to_xb_tvalid, ep0_to_xb_tvalid, s_dma_tvalid, s_eth1_tvalid, s_eth0_tvalid}),
.s_axis_tready ({ep3_to_xb_tready, ep2_to_xb_tready, ep1_to_xb_tready, ep0_to_xb_tready, s_dma_tready, s_eth1_tready, s_eth0_tready}),
- .m_axis_tdata ({xb_to_ep3_tdata, xb_to_ep2_tdata, xb_to_ep1_tdata, xb_to_ep0_tdata, m_dma_tdata, m_eth1_tdata, m_eth0_tdata}),
- .m_axis_tlast ({xb_to_ep3_tlast, xb_to_ep2_tlast, xb_to_ep1_tlast, xb_to_ep0_tlast, m_dma_tlast, m_eth1_tlast, m_eth0_tlast}),
+ .m_axis_tdata ({xb_to_ep3_tdata , xb_to_ep2_tdata , xb_to_ep1_tdata , xb_to_ep0_tdata , m_dma_tdata , m_eth1_tdata , m_eth0_tdata }),
+ .m_axis_tlast ({xb_to_ep3_tlast , xb_to_ep2_tlast , xb_to_ep1_tlast , xb_to_ep0_tlast , m_dma_tlast , m_eth1_tlast , m_eth0_tlast }),
.m_axis_tvalid ({xb_to_ep3_tvalid, xb_to_ep2_tvalid, xb_to_ep1_tvalid, xb_to_ep0_tvalid, m_dma_tvalid, m_eth1_tvalid, m_eth0_tvalid}),
.m_axis_tready ({xb_to_ep3_tready, xb_to_ep2_tready, xb_to_ep1_tready, xb_to_ep0_tready, m_dma_tready, m_eth1_tready, m_eth0_tready}),
.ext_rtcfg_stb (1'h0),
@@ -208,9 +226,18 @@ module rfnoc_image_core #(
.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 = 65536;
+ 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;
@@ -220,8 +247,8 @@ module rfnoc_image_core #(
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 [ 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;
@@ -234,23 +261,23 @@ module rfnoc_image_core #(
.NUM_DATA_O (1),
.INST_NUM (0),
.CTRL_XBAR_PORT (1),
- .INGRESS_BUFF_SIZE (16),
+ .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 ),
+ .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}),
@@ -259,20 +286,28 @@ module rfnoc_image_core #(
.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_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_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 )
+ .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 = 65536;
+ 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;
@@ -281,8 +316,8 @@ module rfnoc_image_core #(
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 [ 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;
@@ -295,23 +330,23 @@ module rfnoc_image_core #(
.NUM_DATA_O (1),
.INST_NUM (1),
.CTRL_XBAR_PORT (2),
- .INGRESS_BUFF_SIZE (16),
+ .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 ),
+ .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}),
@@ -320,20 +355,28 @@ module rfnoc_image_core #(
.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_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_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 )
+ .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 = 4096;
+ 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;
@@ -342,8 +385,8 @@ module rfnoc_image_core #(
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 [ 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;
@@ -356,23 +399,23 @@ module rfnoc_image_core #(
.NUM_DATA_O (1),
.INST_NUM (2),
.CTRL_XBAR_PORT (3),
- .INGRESS_BUFF_SIZE (12),
+ .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 ),
+ .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}),
@@ -381,20 +424,28 @@ module rfnoc_image_core #(
.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_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_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 )
+ .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 = 4096;
+ 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;
@@ -403,8 +454,8 @@ module rfnoc_image_core #(
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 [ 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;
@@ -417,23 +468,23 @@ module rfnoc_image_core #(
.NUM_DATA_O (1),
.INST_NUM (3),
.CTRL_XBAR_PORT (4),
- .INGRESS_BUFF_SIZE (12),
+ .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 ),
+ .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}),
@@ -442,58 +493,57 @@ module rfnoc_image_core #(
.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_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_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 )
+ .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_duc0_ctrl_tdata , s_duc0_ctrl_tdata ;
- wire m_duc0_ctrl_tlast , s_duc0_ctrl_tlast ;
- wire m_duc0_ctrl_tvalid, s_duc0_ctrl_tvalid;
- wire m_duc0_ctrl_tready, s_duc0_ctrl_tready;
- wire [31:0] m_ddc0_ctrl_tdata , s_ddc0_ctrl_tdata ;
- wire m_ddc0_ctrl_tlast , s_ddc0_ctrl_tlast ;
- wire m_ddc0_ctrl_tvalid, s_ddc0_ctrl_tvalid;
- wire m_ddc0_ctrl_tready, s_ddc0_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_duc1_ctrl_tdata , s_duc1_ctrl_tdata ;
- wire m_duc1_ctrl_tlast , s_duc1_ctrl_tlast ;
- wire m_duc1_ctrl_tvalid, s_duc1_ctrl_tvalid;
- wire m_duc1_ctrl_tready, s_duc1_ctrl_tready;
- wire [31:0] m_ddc1_ctrl_tdata , s_ddc1_ctrl_tdata ;
- wire m_ddc1_ctrl_tlast , s_ddc1_ctrl_tlast ;
- wire m_ddc1_ctrl_tvalid, s_ddc1_ctrl_tvalid;
- wire m_ddc1_ctrl_tready, s_ddc1_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;
+ //---------------------------------------------------------------------------
+
+ 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_duc0_ctrl_tdata, s_duc0_ctrl_tdata;
+ wire m_duc0_ctrl_tlast, s_duc0_ctrl_tlast;
+ wire m_duc0_ctrl_tvalid, s_duc0_ctrl_tvalid;
+ wire m_duc0_ctrl_tready, s_duc0_ctrl_tready;
+ wire [31:0] m_ddc0_ctrl_tdata, s_ddc0_ctrl_tdata;
+ wire m_ddc0_ctrl_tlast, s_ddc0_ctrl_tlast;
+ wire m_ddc0_ctrl_tvalid, s_ddc0_ctrl_tvalid;
+ wire m_ddc0_ctrl_tready, s_ddc0_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_duc1_ctrl_tdata, s_duc1_ctrl_tdata;
+ wire m_duc1_ctrl_tlast, s_duc1_ctrl_tlast;
+ wire m_duc1_ctrl_tvalid, s_duc1_ctrl_tvalid;
+ wire m_duc1_ctrl_tready, s_duc1_ctrl_tready;
+ wire [31:0] m_ddc1_ctrl_tdata, s_ddc1_ctrl_tdata;
+ wire m_ddc1_ctrl_tlast, s_ddc1_ctrl_tlast;
+ wire m_ddc1_ctrl_tvalid, s_ddc1_ctrl_tvalid;
+ wire m_ddc1_ctrl_tready, s_ddc1_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),
@@ -517,9 +567,11 @@ module rfnoc_image_core #(
.deadlock_detected()
);
- // ----------------------------------------------------
+
+ //---------------------------------------------------------------------------
// RFNoC Core Kernel
- // ----------------------------------------------------
+ //---------------------------------------------------------------------------
+
wire [(512*7)-1:0] rfnoc_core_config, rfnoc_core_status;
rfnoc_core_kernel #(
@@ -544,12 +596,12 @@ module rfnoc_image_core #(
.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_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_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),
@@ -557,13 +609,15 @@ module rfnoc_image_core #(
.rfnoc_core_status (rfnoc_core_status)
);
- // ----------------------------------------------------
+
+ //---------------------------------------------------------------------------
// Blocks
- // ----------------------------------------------------
+ //---------------------------------------------------------------------------
- // ----------------------------------------------------
+ //-----------------------------------
// duc0
- // ----------------------------------------------------
+ //-----------------------------------
+
wire duc0_ce_clk;
wire [CHDR_W-1:0] s_duc0_in_0_tdata ;
wire s_duc0_in_0_tlast ;
@@ -574,44 +628,41 @@ module rfnoc_image_core #(
wire m_duc0_out_0_tvalid;
wire m_duc0_out_0_tready;
-
rfnoc_block_duc #(
- .THIS_PORTID(2),
- .CHDR_W(CHDR_W),
- .NUM_PORTS(1),
- .NUM_HB(3),
- .CIC_MAX_INTERP(255),
- .MTU(MTU)
+ .THIS_PORTID (2),
+ .CHDR_W (CHDR_W),
+ .NUM_PORTS (1),
+ .NUM_HB (3),
+ .CIC_MAX_INTERP (255),
+ .MTU (MTU)
) b_duc0_0 (
- .rfnoc_chdr_clk (rfnoc_chdr_clk),
- .rfnoc_ctrl_clk (rfnoc_ctrl_clk),
- .ce_clk(duc0_ce_clk),
- .rfnoc_core_config (rfnoc_core_config[512*1-1:512*0]),
- .rfnoc_core_status (rfnoc_core_status[512*1-1:512*0]),
-
-
- .s_rfnoc_chdr_tdata ({s_duc0_in_0_tdata }),
- .s_rfnoc_chdr_tlast ({s_duc0_in_0_tlast }),
- .s_rfnoc_chdr_tvalid({s_duc0_in_0_tvalid}),
- .s_rfnoc_chdr_tready({s_duc0_in_0_tready}),
- .m_rfnoc_chdr_tdata ({m_duc0_out_0_tdata }),
- .m_rfnoc_chdr_tlast ({m_duc0_out_0_tlast }),
- .m_rfnoc_chdr_tvalid({m_duc0_out_0_tvalid}),
- .m_rfnoc_chdr_tready({m_duc0_out_0_tready}),
- .s_rfnoc_ctrl_tdata (s_duc0_ctrl_tdata ),
- .s_rfnoc_ctrl_tlast (s_duc0_ctrl_tlast ),
- .s_rfnoc_ctrl_tvalid(s_duc0_ctrl_tvalid),
- .s_rfnoc_ctrl_tready(s_duc0_ctrl_tready),
- .m_rfnoc_ctrl_tdata (m_duc0_ctrl_tdata ),
- .m_rfnoc_ctrl_tlast (m_duc0_ctrl_tlast ),
- .m_rfnoc_ctrl_tvalid(m_duc0_ctrl_tvalid),
- .m_rfnoc_ctrl_tready(m_duc0_ctrl_tready)
+ .rfnoc_chdr_clk (rfnoc_chdr_clk),
+ .rfnoc_ctrl_clk (rfnoc_ctrl_clk),
+ .ce_clk (duc0_ce_clk),
+ .rfnoc_core_config (rfnoc_core_config[512*1-1:512*0]),
+ .rfnoc_core_status (rfnoc_core_status[512*1-1:512*0]),
+ .s_rfnoc_chdr_tdata ({s_duc0_in_0_tdata }),
+ .s_rfnoc_chdr_tlast ({s_duc0_in_0_tlast }),
+ .s_rfnoc_chdr_tvalid ({s_duc0_in_0_tvalid}),
+ .s_rfnoc_chdr_tready ({s_duc0_in_0_tready}),
+ .m_rfnoc_chdr_tdata ({m_duc0_out_0_tdata }),
+ .m_rfnoc_chdr_tlast ({m_duc0_out_0_tlast }),
+ .m_rfnoc_chdr_tvalid ({m_duc0_out_0_tvalid}),
+ .m_rfnoc_chdr_tready ({m_duc0_out_0_tready}),
+ .s_rfnoc_ctrl_tdata (s_duc0_ctrl_tdata),
+ .s_rfnoc_ctrl_tlast (s_duc0_ctrl_tlast),
+ .s_rfnoc_ctrl_tvalid (s_duc0_ctrl_tvalid),
+ .s_rfnoc_ctrl_tready (s_duc0_ctrl_tready),
+ .m_rfnoc_ctrl_tdata (m_duc0_ctrl_tdata),
+ .m_rfnoc_ctrl_tlast (m_duc0_ctrl_tlast),
+ .m_rfnoc_ctrl_tvalid (m_duc0_ctrl_tvalid),
+ .m_rfnoc_ctrl_tready (m_duc0_ctrl_tready)
);
-
- // ----------------------------------------------------
+ //-----------------------------------
// ddc0
- // ----------------------------------------------------
+ //-----------------------------------
+
wire ddc0_ce_clk;
wire [CHDR_W-1:0] s_ddc0_in_0_tdata ;
wire s_ddc0_in_0_tlast ;
@@ -622,44 +673,41 @@ module rfnoc_image_core #(
wire m_ddc0_out_0_tvalid;
wire m_ddc0_out_0_tready;
-
rfnoc_block_ddc #(
- .THIS_PORTID(3),
- .CHDR_W(CHDR_W),
- .NUM_PORTS(1),
- .NUM_HB(3),
- .CIC_MAX_DECIM(255),
- .MTU(MTU)
+ .THIS_PORTID (3),
+ .CHDR_W (CHDR_W),
+ .NUM_PORTS (1),
+ .NUM_HB (3),
+ .CIC_MAX_DECIM (255),
+ .MTU (MTU)
) b_ddc0_1 (
- .rfnoc_chdr_clk (rfnoc_chdr_clk),
- .rfnoc_ctrl_clk (rfnoc_ctrl_clk),
- .ce_clk(ddc0_ce_clk),
- .rfnoc_core_config (rfnoc_core_config[512*2-1:512*1]),
- .rfnoc_core_status (rfnoc_core_status[512*2-1:512*1]),
-
-
- .s_rfnoc_chdr_tdata ({s_ddc0_in_0_tdata }),
- .s_rfnoc_chdr_tlast ({s_ddc0_in_0_tlast }),
- .s_rfnoc_chdr_tvalid({s_ddc0_in_0_tvalid}),
- .s_rfnoc_chdr_tready({s_ddc0_in_0_tready}),
- .m_rfnoc_chdr_tdata ({m_ddc0_out_0_tdata }),
- .m_rfnoc_chdr_tlast ({m_ddc0_out_0_tlast }),
- .m_rfnoc_chdr_tvalid({m_ddc0_out_0_tvalid}),
- .m_rfnoc_chdr_tready({m_ddc0_out_0_tready}),
- .s_rfnoc_ctrl_tdata (s_ddc0_ctrl_tdata ),
- .s_rfnoc_ctrl_tlast (s_ddc0_ctrl_tlast ),
- .s_rfnoc_ctrl_tvalid(s_ddc0_ctrl_tvalid),
- .s_rfnoc_ctrl_tready(s_ddc0_ctrl_tready),
- .m_rfnoc_ctrl_tdata (m_ddc0_ctrl_tdata ),
- .m_rfnoc_ctrl_tlast (m_ddc0_ctrl_tlast ),
- .m_rfnoc_ctrl_tvalid(m_ddc0_ctrl_tvalid),
- .m_rfnoc_ctrl_tready(m_ddc0_ctrl_tready)
+ .rfnoc_chdr_clk (rfnoc_chdr_clk),
+ .rfnoc_ctrl_clk (rfnoc_ctrl_clk),
+ .ce_clk (ddc0_ce_clk),
+ .rfnoc_core_config (rfnoc_core_config[512*2-1:512*1]),
+ .rfnoc_core_status (rfnoc_core_status[512*2-1:512*1]),
+ .s_rfnoc_chdr_tdata ({s_ddc0_in_0_tdata }),
+ .s_rfnoc_chdr_tlast ({s_ddc0_in_0_tlast }),
+ .s_rfnoc_chdr_tvalid ({s_ddc0_in_0_tvalid}),
+ .s_rfnoc_chdr_tready ({s_ddc0_in_0_tready}),
+ .m_rfnoc_chdr_tdata ({m_ddc0_out_0_tdata }),
+ .m_rfnoc_chdr_tlast ({m_ddc0_out_0_tlast }),
+ .m_rfnoc_chdr_tvalid ({m_ddc0_out_0_tvalid}),
+ .m_rfnoc_chdr_tready ({m_ddc0_out_0_tready}),
+ .s_rfnoc_ctrl_tdata (s_ddc0_ctrl_tdata),
+ .s_rfnoc_ctrl_tlast (s_ddc0_ctrl_tlast),
+ .s_rfnoc_ctrl_tvalid (s_ddc0_ctrl_tvalid),
+ .s_rfnoc_ctrl_tready (s_ddc0_ctrl_tready),
+ .m_rfnoc_ctrl_tdata (m_ddc0_ctrl_tdata),
+ .m_rfnoc_ctrl_tlast (m_ddc0_ctrl_tlast),
+ .m_rfnoc_ctrl_tvalid (m_ddc0_ctrl_tvalid),
+ .m_rfnoc_ctrl_tready (m_ddc0_ctrl_tready)
);
-
- // ----------------------------------------------------
+ //-----------------------------------
// radio0
- // ----------------------------------------------------
+ //-----------------------------------
+
wire radio0_radio_clk;
wire [CHDR_W-1:0] s_radio0_in_0_tdata ;
wire s_radio0_in_0_tlast ;
@@ -670,79 +718,77 @@ module rfnoc_image_core #(
wire m_radio0_out_0_tvalid;
wire m_radio0_out_0_tready;
- // ctrl_port
- wire [ 1-1:0] radio0_m_ctrlport_req_wr;
- wire [ 1-1:0] radio0_m_ctrlport_req_rd;
- wire [ 20-1:0] radio0_m_ctrlport_req_addr;
- wire [ 32-1:0] radio0_m_ctrlport_req_data;
- wire [ 4-1:0] radio0_m_ctrlport_req_byte_en;
- wire [ 1-1:0] radio0_m_ctrlport_req_has_time;
- wire [ 64-1:0] radio0_m_ctrlport_req_time;
- wire [ 1-1:0] radio0_m_ctrlport_resp_ack;
- wire [ 2-1:0] radio0_m_ctrlport_resp_status;
- wire [ 32-1:0] radio0_m_ctrlport_resp_data;
- // time_keeper
- wire [ 64-1:0] radio0_radio_time;
- // radio_iface
- wire [ 32-1:0] radio0_radio_rx_data;
- wire [ 1-1:0] radio0_radio_rx_stb;
- wire [ 1-1:0] radio0_radio_rx_running;
- wire [ 32-1:0] radio0_radio_tx_data;
- wire [ 1-1:0] radio0_radio_tx_stb;
- wire [ 1-1:0] radio0_radio_tx_running;
+ // ctrl_port
+ 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_keeper
+ wire [ 63:0] radio0_radio_time;
+ // radio_iface
+ wire [ 31:0] radio0_radio_rx_data;
+ wire [ 0:0] radio0_radio_rx_stb;
+ wire [ 0:0] radio0_radio_rx_running;
+ wire [ 31:0] radio0_radio_tx_data;
+ wire [ 0:0] radio0_radio_tx_stb;
+ wire [ 0:0] radio0_radio_tx_running;
rfnoc_block_radio #(
- .THIS_PORTID(4),
- .CHDR_W(CHDR_W),
- .NUM_PORTS(1),
- .MTU(MTU)
+ .THIS_PORTID (4),
+ .CHDR_W (CHDR_W),
+ .NUM_PORTS (1),
+ .MTU (MTU)
) b_radio0_2 (
- .rfnoc_chdr_clk (rfnoc_chdr_clk),
- .rfnoc_ctrl_clk (rfnoc_ctrl_clk),
- .radio_clk(radio0_radio_clk),
- .rfnoc_core_config (rfnoc_core_config[512*3-1:512*2]),
- .rfnoc_core_status (rfnoc_core_status[512*3-1:512*2]),
-
- .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),
+ .rfnoc_chdr_clk (rfnoc_chdr_clk),
+ .rfnoc_ctrl_clk (rfnoc_ctrl_clk),
+ .radio_clk (radio0_radio_clk),
+ .rfnoc_core_config (rfnoc_core_config[512*3-1:512*2]),
+ .rfnoc_core_status (rfnoc_core_status[512*3-1:512*2]),
+ .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_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_0_tdata }),
- .s_rfnoc_chdr_tlast ({s_radio0_in_0_tlast }),
- .s_rfnoc_chdr_tvalid({s_radio0_in_0_tvalid}),
- .s_rfnoc_chdr_tready({s_radio0_in_0_tready}),
- .m_rfnoc_chdr_tdata ({m_radio0_out_0_tdata }),
- .m_rfnoc_chdr_tlast ({m_radio0_out_0_tlast }),
- .m_rfnoc_chdr_tvalid({m_radio0_out_0_tvalid}),
- .m_rfnoc_chdr_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)
+ .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_0_tdata }),
+ .s_rfnoc_chdr_tlast ({s_radio0_in_0_tlast }),
+ .s_rfnoc_chdr_tvalid ({s_radio0_in_0_tvalid}),
+ .s_rfnoc_chdr_tready ({s_radio0_in_0_tready}),
+ .m_rfnoc_chdr_tdata ({m_radio0_out_0_tdata }),
+ .m_rfnoc_chdr_tlast ({m_radio0_out_0_tlast }),
+ .m_rfnoc_chdr_tvalid ({m_radio0_out_0_tvalid}),
+ .m_rfnoc_chdr_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)
);
-
- // ----------------------------------------------------
+ //-----------------------------------
// duc1
- // ----------------------------------------------------
+ //-----------------------------------
+
wire duc1_ce_clk;
wire [CHDR_W-1:0] s_duc1_in_0_tdata ;
wire s_duc1_in_0_tlast ;
@@ -753,44 +799,41 @@ module rfnoc_image_core #(
wire m_duc1_out_0_tvalid;
wire m_duc1_out_0_tready;
-
rfnoc_block_duc #(
- .THIS_PORTID(5),
- .CHDR_W(CHDR_W),
- .NUM_PORTS(1),
- .NUM_HB(3),
- .CIC_MAX_INTERP(255),
- .MTU(MTU)
+ .THIS_PORTID (5),
+ .CHDR_W (CHDR_W),
+ .NUM_PORTS (1),
+ .NUM_HB (3),
+ .CIC_MAX_INTERP (255),
+ .MTU (MTU)
) b_duc1_3 (
- .rfnoc_chdr_clk (rfnoc_chdr_clk),
- .rfnoc_ctrl_clk (rfnoc_ctrl_clk),
- .ce_clk(duc1_ce_clk),
- .rfnoc_core_config (rfnoc_core_config[512*4-1:512*3]),
- .rfnoc_core_status (rfnoc_core_status[512*4-1:512*3]),
-
-
- .s_rfnoc_chdr_tdata ({s_duc1_in_0_tdata }),
- .s_rfnoc_chdr_tlast ({s_duc1_in_0_tlast }),
- .s_rfnoc_chdr_tvalid({s_duc1_in_0_tvalid}),
- .s_rfnoc_chdr_tready({s_duc1_in_0_tready}),
- .m_rfnoc_chdr_tdata ({m_duc1_out_0_tdata }),
- .m_rfnoc_chdr_tlast ({m_duc1_out_0_tlast }),
- .m_rfnoc_chdr_tvalid({m_duc1_out_0_tvalid}),
- .m_rfnoc_chdr_tready({m_duc1_out_0_tready}),
- .s_rfnoc_ctrl_tdata (s_duc1_ctrl_tdata ),
- .s_rfnoc_ctrl_tlast (s_duc1_ctrl_tlast ),
- .s_rfnoc_ctrl_tvalid(s_duc1_ctrl_tvalid),
- .s_rfnoc_ctrl_tready(s_duc1_ctrl_tready),
- .m_rfnoc_ctrl_tdata (m_duc1_ctrl_tdata ),
- .m_rfnoc_ctrl_tlast (m_duc1_ctrl_tlast ),
- .m_rfnoc_ctrl_tvalid(m_duc1_ctrl_tvalid),
- .m_rfnoc_ctrl_tready(m_duc1_ctrl_tready)
+ .rfnoc_chdr_clk (rfnoc_chdr_clk),
+ .rfnoc_ctrl_clk (rfnoc_ctrl_clk),
+ .ce_clk (duc1_ce_clk),
+ .rfnoc_core_config (rfnoc_core_config[512*4-1:512*3]),
+ .rfnoc_core_status (rfnoc_core_status[512*4-1:512*3]),
+ .s_rfnoc_chdr_tdata ({s_duc1_in_0_tdata }),
+ .s_rfnoc_chdr_tlast ({s_duc1_in_0_tlast }),
+ .s_rfnoc_chdr_tvalid ({s_duc1_in_0_tvalid}),
+ .s_rfnoc_chdr_tready ({s_duc1_in_0_tready}),
+ .m_rfnoc_chdr_tdata ({m_duc1_out_0_tdata }),
+ .m_rfnoc_chdr_tlast ({m_duc1_out_0_tlast }),
+ .m_rfnoc_chdr_tvalid ({m_duc1_out_0_tvalid}),
+ .m_rfnoc_chdr_tready ({m_duc1_out_0_tready}),
+ .s_rfnoc_ctrl_tdata (s_duc1_ctrl_tdata),
+ .s_rfnoc_ctrl_tlast (s_duc1_ctrl_tlast),
+ .s_rfnoc_ctrl_tvalid (s_duc1_ctrl_tvalid),
+ .s_rfnoc_ctrl_tready (s_duc1_ctrl_tready),
+ .m_rfnoc_ctrl_tdata (m_duc1_ctrl_tdata),
+ .m_rfnoc_ctrl_tlast (m_duc1_ctrl_tlast),
+ .m_rfnoc_ctrl_tvalid (m_duc1_ctrl_tvalid),
+ .m_rfnoc_ctrl_tready (m_duc1_ctrl_tready)
);
-
- // ----------------------------------------------------
+ //-----------------------------------
// ddc1
- // ----------------------------------------------------
+ //-----------------------------------
+
wire ddc1_ce_clk;
wire [CHDR_W-1:0] s_ddc1_in_0_tdata ;
wire s_ddc1_in_0_tlast ;
@@ -801,44 +844,41 @@ module rfnoc_image_core #(
wire m_ddc1_out_0_tvalid;
wire m_ddc1_out_0_tready;
-
rfnoc_block_ddc #(
- .THIS_PORTID(6),
- .CHDR_W(CHDR_W),
- .NUM_PORTS(1),
- .NUM_HB(3),
- .CIC_MAX_DECIM(255),
- .MTU(MTU)
+ .THIS_PORTID (6),
+ .CHDR_W (CHDR_W),
+ .NUM_PORTS (1),
+ .NUM_HB (3),
+ .CIC_MAX_DECIM (255),
+ .MTU (MTU)
) b_ddc1_4 (
- .rfnoc_chdr_clk (rfnoc_chdr_clk),
- .rfnoc_ctrl_clk (rfnoc_ctrl_clk),
- .ce_clk(ddc1_ce_clk),
- .rfnoc_core_config (rfnoc_core_config[512*5-1:512*4]),
- .rfnoc_core_status (rfnoc_core_status[512*5-1:512*4]),
-
-
- .s_rfnoc_chdr_tdata ({s_ddc1_in_0_tdata }),
- .s_rfnoc_chdr_tlast ({s_ddc1_in_0_tlast }),
- .s_rfnoc_chdr_tvalid({s_ddc1_in_0_tvalid}),
- .s_rfnoc_chdr_tready({s_ddc1_in_0_tready}),
- .m_rfnoc_chdr_tdata ({m_ddc1_out_0_tdata }),
- .m_rfnoc_chdr_tlast ({m_ddc1_out_0_tlast }),
- .m_rfnoc_chdr_tvalid({m_ddc1_out_0_tvalid}),
- .m_rfnoc_chdr_tready({m_ddc1_out_0_tready}),
- .s_rfnoc_ctrl_tdata (s_ddc1_ctrl_tdata ),
- .s_rfnoc_ctrl_tlast (s_ddc1_ctrl_tlast ),
- .s_rfnoc_ctrl_tvalid(s_ddc1_ctrl_tvalid),
- .s_rfnoc_ctrl_tready(s_ddc1_ctrl_tready),
- .m_rfnoc_ctrl_tdata (m_ddc1_ctrl_tdata ),
- .m_rfnoc_ctrl_tlast (m_ddc1_ctrl_tlast ),
- .m_rfnoc_ctrl_tvalid(m_ddc1_ctrl_tvalid),
- .m_rfnoc_ctrl_tready(m_ddc1_ctrl_tready)
+ .rfnoc_chdr_clk (rfnoc_chdr_clk),
+ .rfnoc_ctrl_clk (rfnoc_ctrl_clk),
+ .ce_clk (ddc1_ce_clk),
+ .rfnoc_core_config (rfnoc_core_config[512*5-1:512*4]),
+ .rfnoc_core_status (rfnoc_core_status[512*5-1:512*4]),
+ .s_rfnoc_chdr_tdata ({s_ddc1_in_0_tdata }),
+ .s_rfnoc_chdr_tlast ({s_ddc1_in_0_tlast }),
+ .s_rfnoc_chdr_tvalid ({s_ddc1_in_0_tvalid}),
+ .s_rfnoc_chdr_tready ({s_ddc1_in_0_tready}),
+ .m_rfnoc_chdr_tdata ({m_ddc1_out_0_tdata }),
+ .m_rfnoc_chdr_tlast ({m_ddc1_out_0_tlast }),
+ .m_rfnoc_chdr_tvalid ({m_ddc1_out_0_tvalid}),
+ .m_rfnoc_chdr_tready ({m_ddc1_out_0_tready}),
+ .s_rfnoc_ctrl_tdata (s_ddc1_ctrl_tdata),
+ .s_rfnoc_ctrl_tlast (s_ddc1_ctrl_tlast),
+ .s_rfnoc_ctrl_tvalid (s_ddc1_ctrl_tvalid),
+ .s_rfnoc_ctrl_tready (s_ddc1_ctrl_tready),
+ .m_rfnoc_ctrl_tdata (m_ddc1_ctrl_tdata),
+ .m_rfnoc_ctrl_tlast (m_ddc1_ctrl_tlast),
+ .m_rfnoc_ctrl_tvalid (m_ddc1_ctrl_tvalid),
+ .m_rfnoc_ctrl_tready (m_ddc1_ctrl_tready)
);
-
- // ----------------------------------------------------
+ //-----------------------------------
// radio1
- // ----------------------------------------------------
+ //-----------------------------------
+
wire radio1_radio_clk;
wire [CHDR_W-1:0] s_radio1_in_0_tdata ;
wire s_radio1_in_0_tlast ;
@@ -849,79 +889,77 @@ module rfnoc_image_core #(
wire m_radio1_out_0_tvalid;
wire m_radio1_out_0_tready;
- // ctrl_port
- wire [ 1-1:0] radio1_m_ctrlport_req_wr;
- wire [ 1-1:0] radio1_m_ctrlport_req_rd;
- wire [ 20-1:0] radio1_m_ctrlport_req_addr;
- wire [ 32-1:0] radio1_m_ctrlport_req_data;
- wire [ 4-1:0] radio1_m_ctrlport_req_byte_en;
- wire [ 1-1:0] radio1_m_ctrlport_req_has_time;
- wire [ 64-1:0] radio1_m_ctrlport_req_time;
- wire [ 1-1:0] radio1_m_ctrlport_resp_ack;
- wire [ 2-1:0] radio1_m_ctrlport_resp_status;
- wire [ 32-1:0] radio1_m_ctrlport_resp_data;
- // time_keeper
- wire [ 64-1:0] radio1_radio_time;
- // radio_iface
- wire [ 32-1:0] radio1_radio_rx_data;
- wire [ 1-1:0] radio1_radio_rx_stb;
- wire [ 1-1:0] radio1_radio_rx_running;
- wire [ 32-1:0] radio1_radio_tx_data;
- wire [ 1-1:0] radio1_radio_tx_stb;
- wire [ 1-1:0] radio1_radio_tx_running;
+ // ctrl_port
+ 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_keeper
+ wire [ 63:0] radio1_radio_time;
+ // radio_iface
+ wire [ 31:0] radio1_radio_rx_data;
+ wire [ 0:0] radio1_radio_rx_stb;
+ wire [ 0:0] radio1_radio_rx_running;
+ wire [ 31:0] radio1_radio_tx_data;
+ wire [ 0:0] radio1_radio_tx_stb;
+ wire [ 0:0] radio1_radio_tx_running;
rfnoc_block_radio #(
- .THIS_PORTID(7),
- .CHDR_W(CHDR_W),
- .NUM_PORTS(1),
- .MTU(MTU)
+ .THIS_PORTID (7),
+ .CHDR_W (CHDR_W),
+ .NUM_PORTS (1),
+ .MTU (MTU)
) b_radio1_5 (
- .rfnoc_chdr_clk (rfnoc_chdr_clk),
- .rfnoc_ctrl_clk (rfnoc_ctrl_clk),
- .radio_clk(radio1_radio_clk),
- .rfnoc_core_config (rfnoc_core_config[512*6-1:512*5]),
- .rfnoc_core_status (rfnoc_core_status[512*6-1:512*5]),
-
- .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),
+ .rfnoc_chdr_clk (rfnoc_chdr_clk),
+ .rfnoc_ctrl_clk (rfnoc_ctrl_clk),
+ .radio_clk (radio1_radio_clk),
+ .rfnoc_core_config (rfnoc_core_config[512*6-1:512*5]),
+ .rfnoc_core_status (rfnoc_core_status[512*6-1:512*5]),
+ .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_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_0_tdata }),
- .s_rfnoc_chdr_tlast ({s_radio1_in_0_tlast }),
- .s_rfnoc_chdr_tvalid({s_radio1_in_0_tvalid}),
- .s_rfnoc_chdr_tready({s_radio1_in_0_tready}),
- .m_rfnoc_chdr_tdata ({m_radio1_out_0_tdata }),
- .m_rfnoc_chdr_tlast ({m_radio1_out_0_tlast }),
- .m_rfnoc_chdr_tvalid({m_radio1_out_0_tvalid}),
- .m_rfnoc_chdr_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)
+ .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_0_tdata }),
+ .s_rfnoc_chdr_tlast ({s_radio1_in_0_tlast }),
+ .s_rfnoc_chdr_tvalid ({s_radio1_in_0_tvalid}),
+ .s_rfnoc_chdr_tready ({s_radio1_in_0_tready}),
+ .m_rfnoc_chdr_tdata ({m_radio1_out_0_tdata }),
+ .m_rfnoc_chdr_tlast ({m_radio1_out_0_tlast }),
+ .m_rfnoc_chdr_tvalid ({m_radio1_out_0_tvalid}),
+ .m_rfnoc_chdr_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_1_tdata , s_replay0_in_0_tdata ;
wire s_replay0_in_1_tlast , s_replay0_in_0_tlast ;
@@ -932,203 +970,204 @@ module rfnoc_image_core #(
wire m_replay0_out_1_tvalid, m_replay0_out_0_tvalid;
wire m_replay0_out_1_tready, m_replay0_out_0_tready;
- // axi_ram
- wire [ 1-1:0] replay0_axi_rst;
- wire [ 4-1:0] replay0_m_axi_awid;
- wire [128-1:0] replay0_m_axi_awaddr;
- wire [ 32-1:0] replay0_m_axi_awlen;
- wire [ 12-1:0] replay0_m_axi_awsize;
- wire [ 8-1:0] replay0_m_axi_awburst;
- wire [ 4-1:0] replay0_m_axi_awlock;
- wire [ 16-1:0] replay0_m_axi_awcache;
- wire [ 12-1:0] replay0_m_axi_awprot;
- wire [ 16-1:0] replay0_m_axi_awqos;
- wire [ 16-1:0] replay0_m_axi_awregion;
- wire [ 4-1:0] replay0_m_axi_awuser;
- wire [ 4-1:0] replay0_m_axi_awvalid;
- wire [ 4-1:0] replay0_m_axi_awready;
- wire [256-1:0] replay0_m_axi_wdata;
- wire [ 32-1:0] replay0_m_axi_wstrb;
- wire [ 4-1:0] replay0_m_axi_wlast;
- wire [ 4-1:0] replay0_m_axi_wuser;
- wire [ 4-1:0] replay0_m_axi_wvalid;
- wire [ 4-1:0] replay0_m_axi_wready;
- wire [ 4-1:0] replay0_m_axi_bid;
- wire [ 8-1:0] replay0_m_axi_bresp;
- wire [ 4-1:0] replay0_m_axi_buser;
- wire [ 4-1:0] replay0_m_axi_bvalid;
- wire [ 4-1:0] replay0_m_axi_bready;
- wire [ 4-1:0] replay0_m_axi_arid;
- wire [128-1:0] replay0_m_axi_araddr;
- wire [ 32-1:0] replay0_m_axi_arlen;
- wire [ 12-1:0] replay0_m_axi_arsize;
- wire [ 8-1:0] replay0_m_axi_arburst;
- wire [ 4-1:0] replay0_m_axi_arlock;
- wire [ 16-1:0] replay0_m_axi_arcache;
- wire [ 12-1:0] replay0_m_axi_arprot;
- wire [ 16-1:0] replay0_m_axi_arqos;
- wire [ 16-1:0] replay0_m_axi_arregion;
- wire [ 4-1:0] replay0_m_axi_aruser;
- wire [ 4-1:0] replay0_m_axi_arvalid;
- wire [ 4-1:0] replay0_m_axi_arready;
- wire [ 4-1:0] replay0_m_axi_rid;
- wire [256-1:0] replay0_m_axi_rdata;
- wire [ 8-1:0] replay0_m_axi_rresp;
- wire [ 4-1:0] replay0_m_axi_rlast;
- wire [ 4-1:0] replay0_m_axi_ruser;
- wire [ 4-1:0] replay0_m_axi_rvalid;
- wire [ 4-1:0] replay0_m_axi_rready;
+ // axi_ram
+ wire [ 0:0] replay0_axi_rst;
+ wire [ 3:0] replay0_m_axi_awid;
+ wire [ 127: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 [ 255:0] replay0_m_axi_wdata;
+ wire [ 31: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 [ 127: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 [ 255: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(8),
- .CHDR_W(CHDR_W),
- .NUM_PORTS(2),
- .MEM_ADDR_W(31),
- .MEM_DATA_W(64),
- .MTU(MTU)
+ .THIS_PORTID (8),
+ .CHDR_W (CHDR_W),
+ .NUM_PORTS (2),
+ .MEM_ADDR_W (31),
+ .MEM_DATA_W (64),
+ .MTU (MTU)
) b_replay0_6 (
- .rfnoc_chdr_clk (rfnoc_chdr_clk),
- .rfnoc_ctrl_clk (rfnoc_ctrl_clk),
- .mem_clk(replay0_mem_clk),
- .rfnoc_core_config (rfnoc_core_config[512*7-1:512*6]),
- .rfnoc_core_status (rfnoc_core_status[512*7-1:512*6]),
-
- .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_1_tdata , s_replay0_in_0_tdata }),
- .s_rfnoc_chdr_tlast ({s_replay0_in_1_tlast , s_replay0_in_0_tlast }),
- .s_rfnoc_chdr_tvalid({s_replay0_in_1_tvalid, s_replay0_in_0_tvalid}),
- .s_rfnoc_chdr_tready({s_replay0_in_1_tready, s_replay0_in_0_tready}),
- .m_rfnoc_chdr_tdata ({m_replay0_out_1_tdata , m_replay0_out_0_tdata }),
- .m_rfnoc_chdr_tlast ({m_replay0_out_1_tlast , m_replay0_out_0_tlast }),
- .m_rfnoc_chdr_tvalid({m_replay0_out_1_tvalid, m_replay0_out_0_tvalid}),
- .m_rfnoc_chdr_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)
+ .rfnoc_chdr_clk (rfnoc_chdr_clk),
+ .rfnoc_ctrl_clk (rfnoc_ctrl_clk),
+ .mem_clk (replay0_mem_clk),
+ .rfnoc_core_config (rfnoc_core_config[512*7-1:512*6]),
+ .rfnoc_core_status (rfnoc_core_status[512*7-1:512*6]),
+ .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_1_tdata , s_replay0_in_0_tdata }),
+ .s_rfnoc_chdr_tlast ({s_replay0_in_1_tlast , s_replay0_in_0_tlast }),
+ .s_rfnoc_chdr_tvalid ({s_replay0_in_1_tvalid, s_replay0_in_0_tvalid}),
+ .s_rfnoc_chdr_tready ({s_replay0_in_1_tready, s_replay0_in_0_tready}),
+ .m_rfnoc_chdr_tdata ({m_replay0_out_1_tdata , m_replay0_out_0_tdata }),
+ .m_rfnoc_chdr_tlast ({m_replay0_out_1_tlast , m_replay0_out_0_tlast }),
+ .m_rfnoc_chdr_tvalid ({m_replay0_out_1_tvalid, m_replay0_out_0_tvalid}),
+ .m_rfnoc_chdr_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_duc0_in_0_tdata = m_ep0_out0_tdata ;
- assign s_duc0_in_0_tlast = m_ep0_out0_tlast ;
+ //---------------------------------------------------------------------------
+
+ assign s_duc0_in_0_tdata = m_ep0_out0_tdata;
+ assign s_duc0_in_0_tlast = m_ep0_out0_tlast;
assign s_duc0_in_0_tvalid = m_ep0_out0_tvalid;
assign m_ep0_out0_tready = s_duc0_in_0_tready;
- assign s_radio0_in_0_tdata = m_duc0_out_0_tdata ;
- assign s_radio0_in_0_tlast = m_duc0_out_0_tlast ;
+ assign s_radio0_in_0_tdata = m_duc0_out_0_tdata;
+ assign s_radio0_in_0_tlast = m_duc0_out_0_tlast;
assign s_radio0_in_0_tvalid = m_duc0_out_0_tvalid;
assign m_duc0_out_0_tready = s_radio0_in_0_tready;
- assign s_ddc0_in_0_tdata = m_radio0_out_0_tdata ;
- assign s_ddc0_in_0_tlast = m_radio0_out_0_tlast ;
+ assign s_ddc0_in_0_tdata = m_radio0_out_0_tdata;
+ assign s_ddc0_in_0_tlast = m_radio0_out_0_tlast;
assign s_ddc0_in_0_tvalid = m_radio0_out_0_tvalid;
assign m_radio0_out_0_tready = s_ddc0_in_0_tready;
- assign s_ep0_in0_tdata = m_ddc0_out_0_tdata ;
- assign s_ep0_in0_tlast = m_ddc0_out_0_tlast ;
+ assign s_ep0_in0_tdata = m_ddc0_out_0_tdata;
+ assign s_ep0_in0_tlast = m_ddc0_out_0_tlast;
assign s_ep0_in0_tvalid = m_ddc0_out_0_tvalid;
assign m_ddc0_out_0_tready = s_ep0_in0_tready;
- assign s_duc1_in_0_tdata = m_ep1_out0_tdata ;
- assign s_duc1_in_0_tlast = m_ep1_out0_tlast ;
+ assign s_duc1_in_0_tdata = m_ep1_out0_tdata;
+ assign s_duc1_in_0_tlast = m_ep1_out0_tlast;
assign s_duc1_in_0_tvalid = m_ep1_out0_tvalid;
assign m_ep1_out0_tready = s_duc1_in_0_tready;
- assign s_radio1_in_0_tdata = m_duc1_out_0_tdata ;
- assign s_radio1_in_0_tlast = m_duc1_out_0_tlast ;
+ assign s_radio1_in_0_tdata = m_duc1_out_0_tdata;
+ assign s_radio1_in_0_tlast = m_duc1_out_0_tlast;
assign s_radio1_in_0_tvalid = m_duc1_out_0_tvalid;
assign m_duc1_out_0_tready = s_radio1_in_0_tready;
- assign s_ddc1_in_0_tdata = m_radio1_out_0_tdata ;
- assign s_ddc1_in_0_tlast = m_radio1_out_0_tlast ;
+ assign s_ddc1_in_0_tdata = m_radio1_out_0_tdata;
+ assign s_ddc1_in_0_tlast = m_radio1_out_0_tlast;
assign s_ddc1_in_0_tvalid = m_radio1_out_0_tvalid;
assign m_radio1_out_0_tready = s_ddc1_in_0_tready;
- assign s_ep1_in0_tdata = m_ddc1_out_0_tdata ;
- assign s_ep1_in0_tlast = m_ddc1_out_0_tlast ;
+ assign s_ep1_in0_tdata = m_ddc1_out_0_tdata;
+ assign s_ep1_in0_tlast = m_ddc1_out_0_tlast;
assign s_ep1_in0_tvalid = m_ddc1_out_0_tvalid;
assign m_ddc1_out_0_tready = s_ep1_in0_tready;
- assign s_replay0_in_0_tdata = m_ep2_out0_tdata ;
- assign s_replay0_in_0_tlast = m_ep2_out0_tlast ;
+ assign s_replay0_in_0_tdata = m_ep2_out0_tdata;
+ assign s_replay0_in_0_tlast = m_ep2_out0_tlast;
assign s_replay0_in_0_tvalid = m_ep2_out0_tvalid;
assign m_ep2_out0_tready = s_replay0_in_0_tready;
- assign s_ep2_in0_tdata = m_replay0_out_0_tdata ;
- assign s_ep2_in0_tlast = m_replay0_out_0_tlast ;
+ assign s_ep2_in0_tdata = m_replay0_out_0_tdata;
+ assign s_ep2_in0_tlast = m_replay0_out_0_tlast;
assign s_ep2_in0_tvalid = m_replay0_out_0_tvalid;
assign m_replay0_out_0_tready = s_ep2_in0_tready;
- assign s_replay0_in_1_tdata = m_ep3_out0_tdata ;
- assign s_replay0_in_1_tlast = m_ep3_out0_tlast ;
+ assign s_replay0_in_1_tdata = m_ep3_out0_tdata;
+ assign s_replay0_in_1_tlast = m_ep3_out0_tlast;
assign s_replay0_in_1_tvalid = m_ep3_out0_tvalid;
assign m_ep3_out0_tready = s_replay0_in_1_tready;
- assign s_ep3_in0_tdata = m_replay0_out_1_tdata ;
- assign s_ep3_in0_tlast = m_replay0_out_1_tlast ;
+ assign s_ep3_in0_tdata = m_replay0_out_1_tdata;
+ assign s_ep3_in0_tlast = m_replay0_out_1_tlast;
assign s_ep3_in0_tvalid = m_replay0_out_1_tvalid;
assign m_replay0_out_1_tready = s_ep3_in0_tready;
- // ----------------------------------------------------
+ //---------------------------------------------------------------------------
// Unused Ports
- // ----------------------------------------------------
+ //---------------------------------------------------------------------------
+
+
- // ----------------------------------------------------
+ //---------------------------------------------------------------------------
// Clock Domains
- // ----------------------------------------------------
+ //---------------------------------------------------------------------------
+
assign radio0_radio_clk = radio_clk;
assign ddc0_ce_clk = radio_clk;
assign duc0_ce_clk = radio_clk;
@@ -1138,9 +1177,10 @@ module rfnoc_image_core #(
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;
@@ -1230,3 +1270,6 @@ module rfnoc_image_core #(
assign radio1_radio_time = radio_time;
endmodule
+
+
+`default_nettype wire
diff --git a/fpga/usrp3/top/n3xx/n320_rfnoc_image_core.vh b/fpga/usrp3/top/n3xx/n320_rfnoc_image_core.vh
new file mode 100644
index 000000000..82cf70236
--- /dev/null
+++ b/fpga/usrp3/top/n3xx/n320_rfnoc_image_core.vh
@@ -0,0 +1,21 @@
+//
+// Copyright 2021 Ettus Research, A National Instruments Brand
+//
+// SPDX-License-Identifier: LGPL-3.0-or-later
+//
+// Header: rfnoc_image_core.vh (for n320)
+//
+// 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: 2021-05-03T08:51:09.997079
+// Source: n320_rfnoc_image_core.yml
+// Source SHA256: 3c3a33be8bc2e3b3a7268ba3e07001c6dc6c21af4c9027309a787ac8404e5e8f
+//
+
+`define CHDR_WIDTH 64
+`define RFNOC_PROTOVER { 8'd1, 8'd0 }
diff --git a/fpga/usrp3/top/x300/x300_rfnoc_image_core.v b/fpga/usrp3/top/x300/x300_rfnoc_image_core.v
index dc6fc4708..dced3c4cb 100644
--- a/fpga/usrp3/top/x300/x300_rfnoc_image_core.v
+++ b/fpga/usrp3/top/x300/x300_rfnoc_image_core.v
@@ -1,19 +1,32 @@
//
-// Copyright 2020 Ettus Research, A National Instruments Brand
+// Copyright 2021 Ettus Research, A National Instruments Brand
//
// SPDX-License-Identifier: LGPL-3.0-or-later
//
-
// Module: rfnoc_image_core (for x300)
-// This file was autogenerated by UHD's image builder tool (rfnoc_image_builder)
-// Re-running that tool will overwrite this file!
-// File generated on: 2020-09-02T12:02:29.163114
-// Source: ./x300_rfnoc_image_core.yml
-// Source SHA256: f64f8b03f805ae93e92c29cbdf8874c497d7ad93d546947e26fa8da501df6e18
+//
+// 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: 2021-05-03T08:51:06.967425
+// Source: x300_rfnoc_image_core.yml
+// Source SHA256: 32a28be8a0bcbe6bb9a5df0058b3c813741fa80c1faafd11270d8b500d7d9b85
+//
+
+`default_nettype none
+
module rfnoc_image_core #(
- parameter [15:0] PROTOVER = {8'd1, 8'd0}
-)(
+ parameter CHDR_W = 64,
+ parameter MTU = 10,
+ parameter [15:0] PROTOVER = {8'd1, 8'd0},
+ parameter RADIO_NIPC = 1
+) (
// Clocks
input wire chdr_aclk,
input wire ctrl_aclk,
@@ -22,131 +35,136 @@ module rfnoc_image_core #(
input wire ce_clk,
input wire dram_clk,
// Basic
- input wire [15:0] device_id,
-//// IO ports //////////////////////////////////
-// ctrlport_radio0
- output wire [ 1-1:0] m_ctrlport_radio0_req_wr,
- output wire [ 1-1:0] m_ctrlport_radio0_req_rd,
- output wire [ 20-1:0] m_ctrlport_radio0_req_addr,
- output wire [ 32-1:0] m_ctrlport_radio0_req_data,
- output wire [ 4-1:0] m_ctrlport_radio0_req_byte_en,
- output wire [ 1-1:0] m_ctrlport_radio0_req_has_time,
- output wire [ 64-1:0] m_ctrlport_radio0_req_time,
- input wire [ 1-1:0] m_ctrlport_radio0_resp_ack,
- input wire [ 2-1:0] m_ctrlport_radio0_resp_status,
- input wire [ 32-1:0] m_ctrlport_radio0_resp_data,
-// ctrlport_radio1
- output wire [ 1-1:0] m_ctrlport_radio1_req_wr,
- output wire [ 1-1:0] m_ctrlport_radio1_req_rd,
- output wire [ 20-1:0] m_ctrlport_radio1_req_addr,
- output wire [ 32-1:0] m_ctrlport_radio1_req_data,
- output wire [ 4-1:0] m_ctrlport_radio1_req_byte_en,
- output wire [ 1-1:0] m_ctrlport_radio1_req_has_time,
- output wire [ 64-1:0] m_ctrlport_radio1_req_time,
- input wire [ 1-1:0] m_ctrlport_radio1_resp_ack,
- input wire [ 2-1:0] m_ctrlport_radio1_resp_status,
- input wire [ 32-1:0] m_ctrlport_radio1_resp_data,
-// time_keeper
- input wire [ 64-1:0] radio_time,
-// x300_radio0
- input wire [ 64-1:0] radio_rx_data_radio0,
- input wire [ 2-1:0] radio_rx_stb_radio0,
- output wire [ 2-1:0] radio_rx_running_radio0,
- output wire [ 64-1:0] radio_tx_data_radio0,
- input wire [ 2-1:0] radio_tx_stb_radio0,
- output wire [ 2-1:0] radio_tx_running_radio0,
-// x300_radio1
- input wire [ 64-1:0] radio_rx_data_radio1,
- input wire [ 2-1:0] radio_rx_stb_radio1,
- output wire [ 2-1:0] radio_rx_running_radio1,
- output wire [ 64-1:0] radio_tx_data_radio1,
- input wire [ 2-1:0] radio_tx_stb_radio1,
- output wire [ 2-1:0] radio_tx_running_radio1,
-// dram
- input wire [ 1-1:0] axi_rst,
- output wire [ 4-1:0] m_axi_awid,
- output wire [128-1:0] m_axi_awaddr,
- output wire [ 32-1:0] m_axi_awlen,
- output wire [ 12-1:0] m_axi_awsize,
- output wire [ 8-1:0] m_axi_awburst,
- output wire [ 4-1:0] m_axi_awlock,
- output wire [ 16-1:0] m_axi_awcache,
- output wire [ 12-1:0] m_axi_awprot,
- output wire [ 16-1:0] m_axi_awqos,
- output wire [ 16-1:0] m_axi_awregion,
- output wire [ 4-1:0] m_axi_awuser,
- output wire [ 4-1:0] m_axi_awvalid,
- input wire [ 4-1:0] m_axi_awready,
- output wire [256-1:0] m_axi_wdata,
- output wire [ 32-1:0] m_axi_wstrb,
- output wire [ 4-1:0] m_axi_wlast,
- output wire [ 4-1:0] m_axi_wuser,
- output wire [ 4-1:0] m_axi_wvalid,
- input wire [ 4-1:0] m_axi_wready,
- input wire [ 4-1:0] m_axi_bid,
- input wire [ 8-1:0] m_axi_bresp,
- input wire [ 4-1:0] m_axi_buser,
- input wire [ 4-1:0] m_axi_bvalid,
- output wire [ 4-1:0] m_axi_bready,
- output wire [ 4-1:0] m_axi_arid,
- output wire [128-1:0] m_axi_araddr,
- output wire [ 32-1:0] m_axi_arlen,
- output wire [ 12-1:0] m_axi_arsize,
- output wire [ 8-1:0] m_axi_arburst,
- output wire [ 4-1:0] m_axi_arlock,
- output wire [ 16-1:0] m_axi_arcache,
- output wire [ 12-1:0] m_axi_arprot,
- output wire [ 16-1:0] m_axi_arqos,
- output wire [ 16-1:0] m_axi_arregion,
- output wire [ 4-1:0] m_axi_aruser,
- output wire [ 4-1:0] m_axi_arvalid,
- input wire [ 4-1:0] m_axi_arready,
- input wire [ 4-1:0] m_axi_rid,
- input wire [256-1:0] m_axi_rdata,
- input wire [ 8-1:0] m_axi_rresp,
- input wire [ 4-1:0] m_axi_rlast,
- input wire [ 4-1:0] m_axi_ruser,
- input wire [ 4-1:0] m_axi_rvalid,
- output wire [ 4-1:0] m_axi_rready,
- // Transport 0 (eth0 10G)
- input wire [64-1:0] s_eth0_tdata,
- input wire s_eth0_tlast,
- input wire s_eth0_tvalid,
- output wire s_eth0_tready,
- output wire [64-1:0] m_eth0_tdata,
- output wire m_eth0_tlast,
- output wire m_eth0_tvalid,
- input wire m_eth0_tready,
- // Transport 1 (eth1 1G)
- input wire [64-1:0] s_eth1_tdata,
- input wire s_eth1_tlast,
- input wire s_eth1_tvalid,
- output wire s_eth1_tready,
- output wire [64-1:0] m_eth1_tdata,
- output wire m_eth1_tlast,
- output wire m_eth1_tvalid,
- input wire m_eth1_tready,
- // Transport 2 (pcie PCIe)
- input wire [64-1:0] s_pcie_tdata,
- input wire s_pcie_tlast,
- input wire s_pcie_tvalid,
- output wire s_pcie_tready,
- output wire [64-1:0] m_pcie_tdata,
- output wire m_pcie_tlast,
- output wire m_pcie_tvalid,
- input wire m_pcie_tready
+ 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_keeper
+ input wire [ 63:0] radio_time,
+ // x300_radio0
+ input wire [ 63:0] radio_rx_data_radio0,
+ input wire [ 1:0] radio_rx_stb_radio0,
+ output wire [ 1:0] radio_rx_running_radio0,
+ output wire [ 63:0] radio_tx_data_radio0,
+ input wire [ 1:0] radio_tx_stb_radio0,
+ output wire [ 1:0] radio_tx_running_radio0,
+ // x300_radio1
+ input wire [ 63:0] radio_rx_data_radio1,
+ input wire [ 1:0] radio_rx_stb_radio1,
+ output wire [ 1:0] radio_rx_running_radio1,
+ output wire [ 63:0] radio_tx_data_radio1,
+ input wire [ 1:0] radio_tx_stb_radio1,
+ output wire [ 1:0] radio_tx_running_radio1,
+ // dram
+ input wire [ 0:0] axi_rst,
+ output wire [ 3:0] m_axi_awid,
+ output wire [ 127: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 [ 255:0] m_axi_wdata,
+ output wire [ 31: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 [ 127: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 [ 255: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 (pcie)
+ input wire [CHDR_W-1:0] s_pcie_tdata,
+ input wire s_pcie_tlast,
+ input wire s_pcie_tvalid,
+ output wire s_pcie_tready,
+ output wire [CHDR_W-1:0] m_pcie_tdata,
+ output wire m_pcie_tlast,
+ output wire m_pcie_tvalid,
+ input wire m_pcie_tready
);
- localparam CHDR_W = 64;
- localparam MTU = 10;
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;
@@ -211,12 +229,12 @@ module rfnoc_image_core #(
.clk (rfnoc_chdr_clk),
.reset (rfnoc_chdr_rst),
.device_id (device_id),
- .s_axis_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_pcie_tdata, s_eth1_tdata, s_eth0_tdata}),
- .s_axis_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_pcie_tlast, s_eth1_tlast, s_eth0_tlast}),
+ .s_axis_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_pcie_tdata , s_eth1_tdata , s_eth0_tdata }),
+ .s_axis_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_pcie_tlast , s_eth1_tlast , s_eth0_tlast }),
.s_axis_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_pcie_tvalid, s_eth1_tvalid, s_eth0_tvalid}),
.s_axis_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_pcie_tready, s_eth1_tready, s_eth0_tready}),
- .m_axis_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_pcie_tdata, m_eth1_tdata, m_eth0_tdata}),
- .m_axis_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_pcie_tlast, m_eth1_tlast, m_eth0_tlast}),
+ .m_axis_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_pcie_tdata , m_eth1_tdata , m_eth0_tdata }),
+ .m_axis_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_pcie_tlast , m_eth1_tlast , m_eth0_tlast }),
.m_axis_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_pcie_tvalid, m_eth1_tvalid, m_eth0_tvalid}),
.m_axis_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_pcie_tready, m_eth1_tready, m_eth0_tready}),
.ext_rtcfg_stb (1'h0),
@@ -225,9 +243,18 @@ module rfnoc_image_core #(
.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;
+ 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;
@@ -237,8 +264,8 @@ module rfnoc_image_core #(
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 [ 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;
@@ -251,23 +278,23 @@ module rfnoc_image_core #(
.NUM_DATA_O (1),
.INST_NUM (0),
.CTRL_XBAR_PORT (1),
- .INGRESS_BUFF_SIZE (15),
+ .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 ),
+ .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}),
@@ -276,20 +303,28 @@ module rfnoc_image_core #(
.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_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_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 )
+ .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 = 0;
+ 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;
@@ -298,8 +333,8 @@ module rfnoc_image_core #(
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 [ 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;
@@ -312,23 +347,23 @@ module rfnoc_image_core #(
.NUM_DATA_O (1),
.INST_NUM (1),
.CTRL_XBAR_PORT (2),
- .INGRESS_BUFF_SIZE (5),
+ .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 ),
+ .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}),
@@ -337,20 +372,28 @@ module rfnoc_image_core #(
.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_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_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 )
+ .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;
+ 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;
@@ -359,8 +402,8 @@ module rfnoc_image_core #(
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 [ 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;
@@ -373,23 +416,23 @@ module rfnoc_image_core #(
.NUM_DATA_O (1),
.INST_NUM (2),
.CTRL_XBAR_PORT (3),
- .INGRESS_BUFF_SIZE (15),
+ .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 ),
+ .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}),
@@ -398,20 +441,28 @@ module rfnoc_image_core #(
.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_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_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 )
+ .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 = 0;
+ 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;
@@ -420,8 +471,8 @@ module rfnoc_image_core #(
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 [ 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;
@@ -434,23 +485,23 @@ module rfnoc_image_core #(
.NUM_DATA_O (1),
.INST_NUM (3),
.CTRL_XBAR_PORT (4),
- .INGRESS_BUFF_SIZE (5),
+ .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 ),
+ .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}),
@@ -459,20 +510,28 @@ module rfnoc_image_core #(
.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_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_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 )
+ .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 = 4096;
+ 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;
@@ -481,8 +540,8 @@ module rfnoc_image_core #(
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 [ 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;
@@ -495,23 +554,23 @@ module rfnoc_image_core #(
.NUM_DATA_O (1),
.INST_NUM (4),
.CTRL_XBAR_PORT (5),
- .INGRESS_BUFF_SIZE (12),
+ .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 ),
+ .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}),
@@ -520,20 +579,28 @@ module rfnoc_image_core #(
.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_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_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 )
+ .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 = 4096;
+ 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;
@@ -542,8 +609,8 @@ module rfnoc_image_core #(
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 [ 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;
@@ -556,23 +623,23 @@ module rfnoc_image_core #(
.NUM_DATA_O (1),
.INST_NUM (5),
.CTRL_XBAR_PORT (6),
- .INGRESS_BUFF_SIZE (12),
+ .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 ),
+ .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}),
@@ -581,58 +648,57 @@ module rfnoc_image_core #(
.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_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_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 )
+ .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_duc0_ctrl_tdata , s_duc0_ctrl_tdata ;
- wire m_duc0_ctrl_tlast , s_duc0_ctrl_tlast ;
- wire m_duc0_ctrl_tvalid, s_duc0_ctrl_tvalid;
- wire m_duc0_ctrl_tready, s_duc0_ctrl_tready;
- wire [31:0] m_ddc0_ctrl_tdata , s_ddc0_ctrl_tdata ;
- wire m_ddc0_ctrl_tlast , s_ddc0_ctrl_tlast ;
- wire m_ddc0_ctrl_tvalid, s_ddc0_ctrl_tvalid;
- wire m_ddc0_ctrl_tready, s_ddc0_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_duc1_ctrl_tdata , s_duc1_ctrl_tdata ;
- wire m_duc1_ctrl_tlast , s_duc1_ctrl_tlast ;
- wire m_duc1_ctrl_tvalid, s_duc1_ctrl_tvalid;
- wire m_duc1_ctrl_tready, s_duc1_ctrl_tready;
- wire [31:0] m_ddc1_ctrl_tdata , s_ddc1_ctrl_tdata ;
- wire m_ddc1_ctrl_tlast , s_ddc1_ctrl_tlast ;
- wire m_ddc1_ctrl_tvalid, s_ddc1_ctrl_tvalid;
- wire m_ddc1_ctrl_tready, s_ddc1_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;
+ //---------------------------------------------------------------------------
+
+ 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_duc0_ctrl_tdata, s_duc0_ctrl_tdata;
+ wire m_duc0_ctrl_tlast, s_duc0_ctrl_tlast;
+ wire m_duc0_ctrl_tvalid, s_duc0_ctrl_tvalid;
+ wire m_duc0_ctrl_tready, s_duc0_ctrl_tready;
+ wire [31:0] m_ddc0_ctrl_tdata, s_ddc0_ctrl_tdata;
+ wire m_ddc0_ctrl_tlast, s_ddc0_ctrl_tlast;
+ wire m_ddc0_ctrl_tvalid, s_ddc0_ctrl_tvalid;
+ wire m_ddc0_ctrl_tready, s_ddc0_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_duc1_ctrl_tdata, s_duc1_ctrl_tdata;
+ wire m_duc1_ctrl_tlast, s_duc1_ctrl_tlast;
+ wire m_duc1_ctrl_tvalid, s_duc1_ctrl_tvalid;
+ wire m_duc1_ctrl_tready, s_duc1_ctrl_tready;
+ wire [31:0] m_ddc1_ctrl_tdata, s_ddc1_ctrl_tdata;
+ wire m_ddc1_ctrl_tlast, s_ddc1_ctrl_tlast;
+ wire m_ddc1_ctrl_tvalid, s_ddc1_ctrl_tvalid;
+ wire m_ddc1_ctrl_tready, s_ddc1_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),
@@ -656,9 +722,11 @@ module rfnoc_image_core #(
.deadlock_detected()
);
- // ----------------------------------------------------
+
+ //---------------------------------------------------------------------------
// RFNoC Core Kernel
- // ----------------------------------------------------
+ //---------------------------------------------------------------------------
+
wire [(512*7)-1:0] rfnoc_core_config, rfnoc_core_status;
rfnoc_core_kernel #(
@@ -683,12 +751,12 @@ module rfnoc_image_core #(
.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_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_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),
@@ -696,13 +764,15 @@ module rfnoc_image_core #(
.rfnoc_core_status (rfnoc_core_status)
);
- // ----------------------------------------------------
+
+ //---------------------------------------------------------------------------
// Blocks
- // ----------------------------------------------------
+ //---------------------------------------------------------------------------
- // ----------------------------------------------------
+ //-----------------------------------
// duc0
- // ----------------------------------------------------
+ //-----------------------------------
+
wire duc0_ce_clk;
wire [CHDR_W-1:0] s_duc0_in_0_tdata ;
wire s_duc0_in_0_tlast ;
@@ -713,44 +783,41 @@ module rfnoc_image_core #(
wire m_duc0_out_0_tvalid;
wire m_duc0_out_0_tready;
-
rfnoc_block_duc #(
- .THIS_PORTID(2),
- .CHDR_W(CHDR_W),
- .NUM_PORTS(1),
- .NUM_HB(3),
- .CIC_MAX_INTERP(255),
- .MTU(MTU)
+ .THIS_PORTID (2),
+ .CHDR_W (CHDR_W),
+ .NUM_PORTS (1),
+ .NUM_HB (3),
+ .CIC_MAX_INTERP (255),
+ .MTU (MTU)
) b_duc0_0 (
- .rfnoc_chdr_clk (rfnoc_chdr_clk),
- .rfnoc_ctrl_clk (rfnoc_ctrl_clk),
- .ce_clk(duc0_ce_clk),
- .rfnoc_core_config (rfnoc_core_config[512*1-1:512*0]),
- .rfnoc_core_status (rfnoc_core_status[512*1-1:512*0]),
-
-
- .s_rfnoc_chdr_tdata ({s_duc0_in_0_tdata }),
- .s_rfnoc_chdr_tlast ({s_duc0_in_0_tlast }),
- .s_rfnoc_chdr_tvalid({s_duc0_in_0_tvalid}),
- .s_rfnoc_chdr_tready({s_duc0_in_0_tready}),
- .m_rfnoc_chdr_tdata ({m_duc0_out_0_tdata }),
- .m_rfnoc_chdr_tlast ({m_duc0_out_0_tlast }),
- .m_rfnoc_chdr_tvalid({m_duc0_out_0_tvalid}),
- .m_rfnoc_chdr_tready({m_duc0_out_0_tready}),
- .s_rfnoc_ctrl_tdata (s_duc0_ctrl_tdata ),
- .s_rfnoc_ctrl_tlast (s_duc0_ctrl_tlast ),
- .s_rfnoc_ctrl_tvalid(s_duc0_ctrl_tvalid),
- .s_rfnoc_ctrl_tready(s_duc0_ctrl_tready),
- .m_rfnoc_ctrl_tdata (m_duc0_ctrl_tdata ),
- .m_rfnoc_ctrl_tlast (m_duc0_ctrl_tlast ),
- .m_rfnoc_ctrl_tvalid(m_duc0_ctrl_tvalid),
- .m_rfnoc_ctrl_tready(m_duc0_ctrl_tready)
+ .rfnoc_chdr_clk (rfnoc_chdr_clk),
+ .rfnoc_ctrl_clk (rfnoc_ctrl_clk),
+ .ce_clk (duc0_ce_clk),
+ .rfnoc_core_config (rfnoc_core_config[512*1-1:512*0]),
+ .rfnoc_core_status (rfnoc_core_status[512*1-1:512*0]),
+ .s_rfnoc_chdr_tdata ({s_duc0_in_0_tdata }),
+ .s_rfnoc_chdr_tlast ({s_duc0_in_0_tlast }),
+ .s_rfnoc_chdr_tvalid ({s_duc0_in_0_tvalid}),
+ .s_rfnoc_chdr_tready ({s_duc0_in_0_tready}),
+ .m_rfnoc_chdr_tdata ({m_duc0_out_0_tdata }),
+ .m_rfnoc_chdr_tlast ({m_duc0_out_0_tlast }),
+ .m_rfnoc_chdr_tvalid ({m_duc0_out_0_tvalid}),
+ .m_rfnoc_chdr_tready ({m_duc0_out_0_tready}),
+ .s_rfnoc_ctrl_tdata (s_duc0_ctrl_tdata),
+ .s_rfnoc_ctrl_tlast (s_duc0_ctrl_tlast),
+ .s_rfnoc_ctrl_tvalid (s_duc0_ctrl_tvalid),
+ .s_rfnoc_ctrl_tready (s_duc0_ctrl_tready),
+ .m_rfnoc_ctrl_tdata (m_duc0_ctrl_tdata),
+ .m_rfnoc_ctrl_tlast (m_duc0_ctrl_tlast),
+ .m_rfnoc_ctrl_tvalid (m_duc0_ctrl_tvalid),
+ .m_rfnoc_ctrl_tready (m_duc0_ctrl_tready)
);
-
- // ----------------------------------------------------
+ //-----------------------------------
// ddc0
- // ----------------------------------------------------
+ //-----------------------------------
+
wire ddc0_ce_clk;
wire [CHDR_W-1:0] s_ddc0_in_1_tdata , s_ddc0_in_0_tdata ;
wire s_ddc0_in_1_tlast , s_ddc0_in_0_tlast ;
@@ -761,44 +828,41 @@ module rfnoc_image_core #(
wire m_ddc0_out_1_tvalid, m_ddc0_out_0_tvalid;
wire m_ddc0_out_1_tready, m_ddc0_out_0_tready;
-
rfnoc_block_ddc #(
- .THIS_PORTID(3),
- .CHDR_W(CHDR_W),
- .NUM_PORTS(2),
- .NUM_HB(3),
- .CIC_MAX_DECIM(255),
- .MTU(MTU)
+ .THIS_PORTID (3),
+ .CHDR_W (CHDR_W),
+ .NUM_PORTS (2),
+ .NUM_HB (3),
+ .CIC_MAX_DECIM (255),
+ .MTU (MTU)
) b_ddc0_1 (
- .rfnoc_chdr_clk (rfnoc_chdr_clk),
- .rfnoc_ctrl_clk (rfnoc_ctrl_clk),
- .ce_clk(ddc0_ce_clk),
- .rfnoc_core_config (rfnoc_core_config[512*2-1:512*1]),
- .rfnoc_core_status (rfnoc_core_status[512*2-1:512*1]),
-
-
- .s_rfnoc_chdr_tdata ({s_ddc0_in_1_tdata , s_ddc0_in_0_tdata }),
- .s_rfnoc_chdr_tlast ({s_ddc0_in_1_tlast , s_ddc0_in_0_tlast }),
- .s_rfnoc_chdr_tvalid({s_ddc0_in_1_tvalid, s_ddc0_in_0_tvalid}),
- .s_rfnoc_chdr_tready({s_ddc0_in_1_tready, s_ddc0_in_0_tready}),
- .m_rfnoc_chdr_tdata ({m_ddc0_out_1_tdata , m_ddc0_out_0_tdata }),
- .m_rfnoc_chdr_tlast ({m_ddc0_out_1_tlast , m_ddc0_out_0_tlast }),
- .m_rfnoc_chdr_tvalid({m_ddc0_out_1_tvalid, m_ddc0_out_0_tvalid}),
- .m_rfnoc_chdr_tready({m_ddc0_out_1_tready, m_ddc0_out_0_tready}),
- .s_rfnoc_ctrl_tdata (s_ddc0_ctrl_tdata ),
- .s_rfnoc_ctrl_tlast (s_ddc0_ctrl_tlast ),
- .s_rfnoc_ctrl_tvalid(s_ddc0_ctrl_tvalid),
- .s_rfnoc_ctrl_tready(s_ddc0_ctrl_tready),
- .m_rfnoc_ctrl_tdata (m_ddc0_ctrl_tdata ),
- .m_rfnoc_ctrl_tlast (m_ddc0_ctrl_tlast ),
- .m_rfnoc_ctrl_tvalid(m_ddc0_ctrl_tvalid),
- .m_rfnoc_ctrl_tready(m_ddc0_ctrl_tready)
+ .rfnoc_chdr_clk (rfnoc_chdr_clk),
+ .rfnoc_ctrl_clk (rfnoc_ctrl_clk),
+ .ce_clk (ddc0_ce_clk),
+ .rfnoc_core_config (rfnoc_core_config[512*2-1:512*1]),
+ .rfnoc_core_status (rfnoc_core_status[512*2-1:512*1]),
+ .s_rfnoc_chdr_tdata ({s_ddc0_in_1_tdata , s_ddc0_in_0_tdata }),
+ .s_rfnoc_chdr_tlast ({s_ddc0_in_1_tlast , s_ddc0_in_0_tlast }),
+ .s_rfnoc_chdr_tvalid ({s_ddc0_in_1_tvalid, s_ddc0_in_0_tvalid}),
+ .s_rfnoc_chdr_tready ({s_ddc0_in_1_tready, s_ddc0_in_0_tready}),
+ .m_rfnoc_chdr_tdata ({m_ddc0_out_1_tdata , m_ddc0_out_0_tdata }),
+ .m_rfnoc_chdr_tlast ({m_ddc0_out_1_tlast , m_ddc0_out_0_tlast }),
+ .m_rfnoc_chdr_tvalid ({m_ddc0_out_1_tvalid, m_ddc0_out_0_tvalid}),
+ .m_rfnoc_chdr_tready ({m_ddc0_out_1_tready, m_ddc0_out_0_tready}),
+ .s_rfnoc_ctrl_tdata (s_ddc0_ctrl_tdata),
+ .s_rfnoc_ctrl_tlast (s_ddc0_ctrl_tlast),
+ .s_rfnoc_ctrl_tvalid (s_ddc0_ctrl_tvalid),
+ .s_rfnoc_ctrl_tready (s_ddc0_ctrl_tready),
+ .m_rfnoc_ctrl_tdata (m_ddc0_ctrl_tdata),
+ .m_rfnoc_ctrl_tlast (m_ddc0_ctrl_tlast),
+ .m_rfnoc_ctrl_tvalid (m_ddc0_ctrl_tvalid),
+ .m_rfnoc_ctrl_tready (m_ddc0_ctrl_tready)
);
-
- // ----------------------------------------------------
+ //-----------------------------------
// 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 ;
@@ -809,79 +873,77 @@ module rfnoc_image_core #(
wire m_radio0_out_1_tvalid, m_radio0_out_0_tvalid;
wire m_radio0_out_1_tready, m_radio0_out_0_tready;
- // ctrl_port
- wire [ 1-1:0] radio0_m_ctrlport_req_wr;
- wire [ 1-1:0] radio0_m_ctrlport_req_rd;
- wire [ 20-1:0] radio0_m_ctrlport_req_addr;
- wire [ 32-1:0] radio0_m_ctrlport_req_data;
- wire [ 4-1:0] radio0_m_ctrlport_req_byte_en;
- wire [ 1-1:0] radio0_m_ctrlport_req_has_time;
- wire [ 64-1:0] radio0_m_ctrlport_req_time;
- wire [ 1-1:0] radio0_m_ctrlport_resp_ack;
- wire [ 2-1:0] radio0_m_ctrlport_resp_status;
- wire [ 32-1:0] radio0_m_ctrlport_resp_data;
- // time_keeper
- wire [ 64-1:0] radio0_radio_time;
- // x300_radio
- wire [ 64-1:0] radio0_radio_rx_data;
- wire [ 2-1:0] radio0_radio_rx_stb;
- wire [ 2-1:0] radio0_radio_rx_running;
- wire [ 64-1:0] radio0_radio_tx_data;
- wire [ 2-1:0] radio0_radio_tx_stb;
- wire [ 2-1:0] radio0_radio_tx_running;
+ // ctrl_port
+ 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_keeper
+ wire [ 63:0] radio0_radio_time;
+ // x300_radio
+ wire [ 63:0] radio0_radio_rx_data;
+ wire [ 1:0] radio0_radio_rx_stb;
+ wire [ 1:0] radio0_radio_rx_running;
+ wire [ 63:0] radio0_radio_tx_data;
+ wire [ 1:0] radio0_radio_tx_stb;
+ wire [ 1:0] radio0_radio_tx_running;
rfnoc_block_radio #(
- .THIS_PORTID(4),
- .CHDR_W(CHDR_W),
- .NUM_PORTS(2),
- .MTU(MTU)
+ .THIS_PORTID (4),
+ .CHDR_W (CHDR_W),
+ .NUM_PORTS (2),
+ .MTU (MTU)
) b_radio0_2 (
- .rfnoc_chdr_clk (rfnoc_chdr_clk),
- .rfnoc_ctrl_clk (rfnoc_ctrl_clk),
- .radio_clk(radio0_radio_clk),
- .rfnoc_core_config (rfnoc_core_config[512*3-1:512*2]),
- .rfnoc_core_status (rfnoc_core_status[512*3-1:512*2]),
-
- .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),
+ .rfnoc_chdr_clk (rfnoc_chdr_clk),
+ .rfnoc_ctrl_clk (rfnoc_ctrl_clk),
+ .radio_clk (radio0_radio_clk),
+ .rfnoc_core_config (rfnoc_core_config[512*3-1:512*2]),
+ .rfnoc_core_status (rfnoc_core_status[512*3-1:512*2]),
+ .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_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)
+ .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)
);
-
- // ----------------------------------------------------
+ //-----------------------------------
// duc1
- // ----------------------------------------------------
+ //-----------------------------------
+
wire duc1_ce_clk;
wire [CHDR_W-1:0] s_duc1_in_0_tdata ;
wire s_duc1_in_0_tlast ;
@@ -892,44 +954,41 @@ module rfnoc_image_core #(
wire m_duc1_out_0_tvalid;
wire m_duc1_out_0_tready;
-
rfnoc_block_duc #(
- .THIS_PORTID(5),
- .CHDR_W(CHDR_W),
- .NUM_PORTS(1),
- .NUM_HB(3),
- .CIC_MAX_INTERP(255),
- .MTU(MTU)
+ .THIS_PORTID (5),
+ .CHDR_W (CHDR_W),
+ .NUM_PORTS (1),
+ .NUM_HB (3),
+ .CIC_MAX_INTERP (255),
+ .MTU (MTU)
) b_duc1_3 (
- .rfnoc_chdr_clk (rfnoc_chdr_clk),
- .rfnoc_ctrl_clk (rfnoc_ctrl_clk),
- .ce_clk(duc1_ce_clk),
- .rfnoc_core_config (rfnoc_core_config[512*4-1:512*3]),
- .rfnoc_core_status (rfnoc_core_status[512*4-1:512*3]),
-
-
- .s_rfnoc_chdr_tdata ({s_duc1_in_0_tdata }),
- .s_rfnoc_chdr_tlast ({s_duc1_in_0_tlast }),
- .s_rfnoc_chdr_tvalid({s_duc1_in_0_tvalid}),
- .s_rfnoc_chdr_tready({s_duc1_in_0_tready}),
- .m_rfnoc_chdr_tdata ({m_duc1_out_0_tdata }),
- .m_rfnoc_chdr_tlast ({m_duc1_out_0_tlast }),
- .m_rfnoc_chdr_tvalid({m_duc1_out_0_tvalid}),
- .m_rfnoc_chdr_tready({m_duc1_out_0_tready}),
- .s_rfnoc_ctrl_tdata (s_duc1_ctrl_tdata ),
- .s_rfnoc_ctrl_tlast (s_duc1_ctrl_tlast ),
- .s_rfnoc_ctrl_tvalid(s_duc1_ctrl_tvalid),
- .s_rfnoc_ctrl_tready(s_duc1_ctrl_tready),
- .m_rfnoc_ctrl_tdata (m_duc1_ctrl_tdata ),
- .m_rfnoc_ctrl_tlast (m_duc1_ctrl_tlast ),
- .m_rfnoc_ctrl_tvalid(m_duc1_ctrl_tvalid),
- .m_rfnoc_ctrl_tready(m_duc1_ctrl_tready)
+ .rfnoc_chdr_clk (rfnoc_chdr_clk),
+ .rfnoc_ctrl_clk (rfnoc_ctrl_clk),
+ .ce_clk (duc1_ce_clk),
+ .rfnoc_core_config (rfnoc_core_config[512*4-1:512*3]),
+ .rfnoc_core_status (rfnoc_core_status[512*4-1:512*3]),
+ .s_rfnoc_chdr_tdata ({s_duc1_in_0_tdata }),
+ .s_rfnoc_chdr_tlast ({s_duc1_in_0_tlast }),
+ .s_rfnoc_chdr_tvalid ({s_duc1_in_0_tvalid}),
+ .s_rfnoc_chdr_tready ({s_duc1_in_0_tready}),
+ .m_rfnoc_chdr_tdata ({m_duc1_out_0_tdata }),
+ .m_rfnoc_chdr_tlast ({m_duc1_out_0_tlast }),
+ .m_rfnoc_chdr_tvalid ({m_duc1_out_0_tvalid}),
+ .m_rfnoc_chdr_tready ({m_duc1_out_0_tready}),
+ .s_rfnoc_ctrl_tdata (s_duc1_ctrl_tdata),
+ .s_rfnoc_ctrl_tlast (s_duc1_ctrl_tlast),
+ .s_rfnoc_ctrl_tvalid (s_duc1_ctrl_tvalid),
+ .s_rfnoc_ctrl_tready (s_duc1_ctrl_tready),
+ .m_rfnoc_ctrl_tdata (m_duc1_ctrl_tdata),
+ .m_rfnoc_ctrl_tlast (m_duc1_ctrl_tlast),
+ .m_rfnoc_ctrl_tvalid (m_duc1_ctrl_tvalid),
+ .m_rfnoc_ctrl_tready (m_duc1_ctrl_tready)
);
-
- // ----------------------------------------------------
+ //-----------------------------------
// ddc1
- // ----------------------------------------------------
+ //-----------------------------------
+
wire ddc1_ce_clk;
wire [CHDR_W-1:0] s_ddc1_in_1_tdata , s_ddc1_in_0_tdata ;
wire s_ddc1_in_1_tlast , s_ddc1_in_0_tlast ;
@@ -940,44 +999,41 @@ module rfnoc_image_core #(
wire m_ddc1_out_1_tvalid, m_ddc1_out_0_tvalid;
wire m_ddc1_out_1_tready, m_ddc1_out_0_tready;
-
rfnoc_block_ddc #(
- .THIS_PORTID(6),
- .CHDR_W(CHDR_W),
- .NUM_PORTS(2),
- .NUM_HB(3),
- .CIC_MAX_DECIM(255),
- .MTU(MTU)
+ .THIS_PORTID (6),
+ .CHDR_W (CHDR_W),
+ .NUM_PORTS (2),
+ .NUM_HB (3),
+ .CIC_MAX_DECIM (255),
+ .MTU (MTU)
) b_ddc1_4 (
- .rfnoc_chdr_clk (rfnoc_chdr_clk),
- .rfnoc_ctrl_clk (rfnoc_ctrl_clk),
- .ce_clk(ddc1_ce_clk),
- .rfnoc_core_config (rfnoc_core_config[512*5-1:512*4]),
- .rfnoc_core_status (rfnoc_core_status[512*5-1:512*4]),
-
-
- .s_rfnoc_chdr_tdata ({s_ddc1_in_1_tdata , s_ddc1_in_0_tdata }),
- .s_rfnoc_chdr_tlast ({s_ddc1_in_1_tlast , s_ddc1_in_0_tlast }),
- .s_rfnoc_chdr_tvalid({s_ddc1_in_1_tvalid, s_ddc1_in_0_tvalid}),
- .s_rfnoc_chdr_tready({s_ddc1_in_1_tready, s_ddc1_in_0_tready}),
- .m_rfnoc_chdr_tdata ({m_ddc1_out_1_tdata , m_ddc1_out_0_tdata }),
- .m_rfnoc_chdr_tlast ({m_ddc1_out_1_tlast , m_ddc1_out_0_tlast }),
- .m_rfnoc_chdr_tvalid({m_ddc1_out_1_tvalid, m_ddc1_out_0_tvalid}),
- .m_rfnoc_chdr_tready({m_ddc1_out_1_tready, m_ddc1_out_0_tready}),
- .s_rfnoc_ctrl_tdata (s_ddc1_ctrl_tdata ),
- .s_rfnoc_ctrl_tlast (s_ddc1_ctrl_tlast ),
- .s_rfnoc_ctrl_tvalid(s_ddc1_ctrl_tvalid),
- .s_rfnoc_ctrl_tready(s_ddc1_ctrl_tready),
- .m_rfnoc_ctrl_tdata (m_ddc1_ctrl_tdata ),
- .m_rfnoc_ctrl_tlast (m_ddc1_ctrl_tlast ),
- .m_rfnoc_ctrl_tvalid(m_ddc1_ctrl_tvalid),
- .m_rfnoc_ctrl_tready(m_ddc1_ctrl_tready)
+ .rfnoc_chdr_clk (rfnoc_chdr_clk),
+ .rfnoc_ctrl_clk (rfnoc_ctrl_clk),
+ .ce_clk (ddc1_ce_clk),
+ .rfnoc_core_config (rfnoc_core_config[512*5-1:512*4]),
+ .rfnoc_core_status (rfnoc_core_status[512*5-1:512*4]),
+ .s_rfnoc_chdr_tdata ({s_ddc1_in_1_tdata , s_ddc1_in_0_tdata }),
+ .s_rfnoc_chdr_tlast ({s_ddc1_in_1_tlast , s_ddc1_in_0_tlast }),
+ .s_rfnoc_chdr_tvalid ({s_ddc1_in_1_tvalid, s_ddc1_in_0_tvalid}),
+ .s_rfnoc_chdr_tready ({s_ddc1_in_1_tready, s_ddc1_in_0_tready}),
+ .m_rfnoc_chdr_tdata ({m_ddc1_out_1_tdata , m_ddc1_out_0_tdata }),
+ .m_rfnoc_chdr_tlast ({m_ddc1_out_1_tlast , m_ddc1_out_0_tlast }),
+ .m_rfnoc_chdr_tvalid ({m_ddc1_out_1_tvalid, m_ddc1_out_0_tvalid}),
+ .m_rfnoc_chdr_tready ({m_ddc1_out_1_tready, m_ddc1_out_0_tready}),
+ .s_rfnoc_ctrl_tdata (s_ddc1_ctrl_tdata),
+ .s_rfnoc_ctrl_tlast (s_ddc1_ctrl_tlast),
+ .s_rfnoc_ctrl_tvalid (s_ddc1_ctrl_tvalid),
+ .s_rfnoc_ctrl_tready (s_ddc1_ctrl_tready),
+ .m_rfnoc_ctrl_tdata (m_ddc1_ctrl_tdata),
+ .m_rfnoc_ctrl_tlast (m_ddc1_ctrl_tlast),
+ .m_rfnoc_ctrl_tvalid (m_ddc1_ctrl_tvalid),
+ .m_rfnoc_ctrl_tready (m_ddc1_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 ;
@@ -988,79 +1044,77 @@ module rfnoc_image_core #(
wire m_radio1_out_1_tvalid, m_radio1_out_0_tvalid;
wire m_radio1_out_1_tready, m_radio1_out_0_tready;
- // ctrl_port
- wire [ 1-1:0] radio1_m_ctrlport_req_wr;
- wire [ 1-1:0] radio1_m_ctrlport_req_rd;
- wire [ 20-1:0] radio1_m_ctrlport_req_addr;
- wire [ 32-1:0] radio1_m_ctrlport_req_data;
- wire [ 4-1:0] radio1_m_ctrlport_req_byte_en;
- wire [ 1-1:0] radio1_m_ctrlport_req_has_time;
- wire [ 64-1:0] radio1_m_ctrlport_req_time;
- wire [ 1-1:0] radio1_m_ctrlport_resp_ack;
- wire [ 2-1:0] radio1_m_ctrlport_resp_status;
- wire [ 32-1:0] radio1_m_ctrlport_resp_data;
- // time_keeper
- wire [ 64-1:0] radio1_radio_time;
- // x300_radio
- wire [ 64-1:0] radio1_radio_rx_data;
- wire [ 2-1:0] radio1_radio_rx_stb;
- wire [ 2-1:0] radio1_radio_rx_running;
- wire [ 64-1:0] radio1_radio_tx_data;
- wire [ 2-1:0] radio1_radio_tx_stb;
- wire [ 2-1:0] radio1_radio_tx_running;
+ // ctrl_port
+ 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_keeper
+ wire [ 63:0] radio1_radio_time;
+ // x300_radio
+ wire [ 63:0] radio1_radio_rx_data;
+ wire [ 1:0] radio1_radio_rx_stb;
+ wire [ 1:0] radio1_radio_rx_running;
+ wire [ 63:0] radio1_radio_tx_data;
+ wire [ 1:0] radio1_radio_tx_stb;
+ wire [ 1:0] radio1_radio_tx_running;
rfnoc_block_radio #(
- .THIS_PORTID(7),
- .CHDR_W(CHDR_W),
- .NUM_PORTS(2),
- .MTU(MTU)
+ .THIS_PORTID (7),
+ .CHDR_W (CHDR_W),
+ .NUM_PORTS (2),
+ .MTU (MTU)
) b_radio1_5 (
- .rfnoc_chdr_clk (rfnoc_chdr_clk),
- .rfnoc_ctrl_clk (rfnoc_ctrl_clk),
- .radio_clk(radio1_radio_clk),
- .rfnoc_core_config (rfnoc_core_config[512*6-1:512*5]),
- .rfnoc_core_status (rfnoc_core_status[512*6-1:512*5]),
-
- .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),
+ .rfnoc_chdr_clk (rfnoc_chdr_clk),
+ .rfnoc_ctrl_clk (rfnoc_ctrl_clk),
+ .radio_clk (radio1_radio_clk),
+ .rfnoc_core_config (rfnoc_core_config[512*6-1:512*5]),
+ .rfnoc_core_status (rfnoc_core_status[512*6-1:512*5]),
+ .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_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)
+ .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_1_tdata , s_replay0_in_0_tdata ;
wire s_replay0_in_1_tlast , s_replay0_in_0_tlast ;
@@ -1071,219 +1125,218 @@ module rfnoc_image_core #(
wire m_replay0_out_1_tvalid, m_replay0_out_0_tvalid;
wire m_replay0_out_1_tready, m_replay0_out_0_tready;
- // axi_ram
- wire [ 1-1:0] replay0_axi_rst;
- wire [ 4-1:0] replay0_m_axi_awid;
- wire [128-1:0] replay0_m_axi_awaddr;
- wire [ 32-1:0] replay0_m_axi_awlen;
- wire [ 12-1:0] replay0_m_axi_awsize;
- wire [ 8-1:0] replay0_m_axi_awburst;
- wire [ 4-1:0] replay0_m_axi_awlock;
- wire [ 16-1:0] replay0_m_axi_awcache;
- wire [ 12-1:0] replay0_m_axi_awprot;
- wire [ 16-1:0] replay0_m_axi_awqos;
- wire [ 16-1:0] replay0_m_axi_awregion;
- wire [ 4-1:0] replay0_m_axi_awuser;
- wire [ 4-1:0] replay0_m_axi_awvalid;
- wire [ 4-1:0] replay0_m_axi_awready;
- wire [256-1:0] replay0_m_axi_wdata;
- wire [ 32-1:0] replay0_m_axi_wstrb;
- wire [ 4-1:0] replay0_m_axi_wlast;
- wire [ 4-1:0] replay0_m_axi_wuser;
- wire [ 4-1:0] replay0_m_axi_wvalid;
- wire [ 4-1:0] replay0_m_axi_wready;
- wire [ 4-1:0] replay0_m_axi_bid;
- wire [ 8-1:0] replay0_m_axi_bresp;
- wire [ 4-1:0] replay0_m_axi_buser;
- wire [ 4-1:0] replay0_m_axi_bvalid;
- wire [ 4-1:0] replay0_m_axi_bready;
- wire [ 4-1:0] replay0_m_axi_arid;
- wire [128-1:0] replay0_m_axi_araddr;
- wire [ 32-1:0] replay0_m_axi_arlen;
- wire [ 12-1:0] replay0_m_axi_arsize;
- wire [ 8-1:0] replay0_m_axi_arburst;
- wire [ 4-1:0] replay0_m_axi_arlock;
- wire [ 16-1:0] replay0_m_axi_arcache;
- wire [ 12-1:0] replay0_m_axi_arprot;
- wire [ 16-1:0] replay0_m_axi_arqos;
- wire [ 16-1:0] replay0_m_axi_arregion;
- wire [ 4-1:0] replay0_m_axi_aruser;
- wire [ 4-1:0] replay0_m_axi_arvalid;
- wire [ 4-1:0] replay0_m_axi_arready;
- wire [ 4-1:0] replay0_m_axi_rid;
- wire [256-1:0] replay0_m_axi_rdata;
- wire [ 8-1:0] replay0_m_axi_rresp;
- wire [ 4-1:0] replay0_m_axi_rlast;
- wire [ 4-1:0] replay0_m_axi_ruser;
- wire [ 4-1:0] replay0_m_axi_rvalid;
- wire [ 4-1:0] replay0_m_axi_rready;
+ // axi_ram
+ wire [ 0:0] replay0_axi_rst;
+ wire [ 3:0] replay0_m_axi_awid;
+ wire [ 127: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 [ 255:0] replay0_m_axi_wdata;
+ wire [ 31: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 [ 127: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 [ 255: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(8),
- .CHDR_W(CHDR_W),
- .NUM_PORTS(2),
- .MEM_ADDR_W(30),
- .MEM_DATA_W(64),
- .MTU(MTU)
+ .THIS_PORTID (8),
+ .CHDR_W (CHDR_W),
+ .NUM_PORTS (2),
+ .MEM_ADDR_W (30),
+ .MEM_DATA_W (64),
+ .MTU (MTU)
) b_replay0_6 (
- .rfnoc_chdr_clk (rfnoc_chdr_clk),
- .rfnoc_ctrl_clk (rfnoc_ctrl_clk),
- .mem_clk(replay0_mem_clk),
- .rfnoc_core_config (rfnoc_core_config[512*7-1:512*6]),
- .rfnoc_core_status (rfnoc_core_status[512*7-1:512*6]),
-
- .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_1_tdata , s_replay0_in_0_tdata }),
- .s_rfnoc_chdr_tlast ({s_replay0_in_1_tlast , s_replay0_in_0_tlast }),
- .s_rfnoc_chdr_tvalid({s_replay0_in_1_tvalid, s_replay0_in_0_tvalid}),
- .s_rfnoc_chdr_tready({s_replay0_in_1_tready, s_replay0_in_0_tready}),
- .m_rfnoc_chdr_tdata ({m_replay0_out_1_tdata , m_replay0_out_0_tdata }),
- .m_rfnoc_chdr_tlast ({m_replay0_out_1_tlast , m_replay0_out_0_tlast }),
- .m_rfnoc_chdr_tvalid({m_replay0_out_1_tvalid, m_replay0_out_0_tvalid}),
- .m_rfnoc_chdr_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)
+ .rfnoc_chdr_clk (rfnoc_chdr_clk),
+ .rfnoc_ctrl_clk (rfnoc_ctrl_clk),
+ .mem_clk (replay0_mem_clk),
+ .rfnoc_core_config (rfnoc_core_config[512*7-1:512*6]),
+ .rfnoc_core_status (rfnoc_core_status[512*7-1:512*6]),
+ .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_1_tdata , s_replay0_in_0_tdata }),
+ .s_rfnoc_chdr_tlast ({s_replay0_in_1_tlast , s_replay0_in_0_tlast }),
+ .s_rfnoc_chdr_tvalid ({s_replay0_in_1_tvalid, s_replay0_in_0_tvalid}),
+ .s_rfnoc_chdr_tready ({s_replay0_in_1_tready, s_replay0_in_0_tready}),
+ .m_rfnoc_chdr_tdata ({m_replay0_out_1_tdata , m_replay0_out_0_tdata }),
+ .m_rfnoc_chdr_tlast ({m_replay0_out_1_tlast , m_replay0_out_0_tlast }),
+ .m_rfnoc_chdr_tvalid ({m_replay0_out_1_tvalid, m_replay0_out_0_tvalid}),
+ .m_rfnoc_chdr_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_duc0_in_0_tdata = m_ep0_out0_tdata ;
- assign s_duc0_in_0_tlast = m_ep0_out0_tlast ;
+ //---------------------------------------------------------------------------
+
+ assign s_duc0_in_0_tdata = m_ep0_out0_tdata;
+ assign s_duc0_in_0_tlast = m_ep0_out0_tlast;
assign s_duc0_in_0_tvalid = m_ep0_out0_tvalid;
assign m_ep0_out0_tready = s_duc0_in_0_tready;
- assign s_radio0_in_0_tdata = m_duc0_out_0_tdata ;
- assign s_radio0_in_0_tlast = m_duc0_out_0_tlast ;
+ assign s_radio0_in_0_tdata = m_duc0_out_0_tdata;
+ assign s_radio0_in_0_tlast = m_duc0_out_0_tlast;
assign s_radio0_in_0_tvalid = m_duc0_out_0_tvalid;
assign m_duc0_out_0_tready = s_radio0_in_0_tready;
- assign s_ddc0_in_0_tdata = m_radio0_out_0_tdata ;
- assign s_ddc0_in_0_tlast = m_radio0_out_0_tlast ;
+ assign s_ddc0_in_0_tdata = m_radio0_out_0_tdata;
+ assign s_ddc0_in_0_tlast = m_radio0_out_0_tlast;
assign s_ddc0_in_0_tvalid = m_radio0_out_0_tvalid;
assign m_radio0_out_0_tready = s_ddc0_in_0_tready;
- assign s_ep0_in0_tdata = m_ddc0_out_0_tdata ;
- assign s_ep0_in0_tlast = m_ddc0_out_0_tlast ;
+ assign s_ep0_in0_tdata = m_ddc0_out_0_tdata;
+ assign s_ep0_in0_tlast = m_ddc0_out_0_tlast;
assign s_ep0_in0_tvalid = m_ddc0_out_0_tvalid;
assign m_ddc0_out_0_tready = s_ep0_in0_tready;
- assign s_ddc0_in_1_tdata = m_radio0_out_1_tdata ;
- assign s_ddc0_in_1_tlast = m_radio0_out_1_tlast ;
+ assign s_ddc0_in_1_tdata = m_radio0_out_1_tdata;
+ assign s_ddc0_in_1_tlast = m_radio0_out_1_tlast;
assign s_ddc0_in_1_tvalid = m_radio0_out_1_tvalid;
assign m_radio0_out_1_tready = s_ddc0_in_1_tready;
- assign s_ep1_in0_tdata = m_ddc0_out_1_tdata ;
- assign s_ep1_in0_tlast = m_ddc0_out_1_tlast ;
+ assign s_ep1_in0_tdata = m_ddc0_out_1_tdata;
+ assign s_ep1_in0_tlast = m_ddc0_out_1_tlast;
assign s_ep1_in0_tvalid = m_ddc0_out_1_tvalid;
assign m_ddc0_out_1_tready = s_ep1_in0_tready;
- assign s_duc1_in_0_tdata = m_ep2_out0_tdata ;
- assign s_duc1_in_0_tlast = m_ep2_out0_tlast ;
+ assign s_duc1_in_0_tdata = m_ep2_out0_tdata;
+ assign s_duc1_in_0_tlast = m_ep2_out0_tlast;
assign s_duc1_in_0_tvalid = m_ep2_out0_tvalid;
assign m_ep2_out0_tready = s_duc1_in_0_tready;
- assign s_radio1_in_0_tdata = m_duc1_out_0_tdata ;
- assign s_radio1_in_0_tlast = m_duc1_out_0_tlast ;
+ assign s_radio1_in_0_tdata = m_duc1_out_0_tdata;
+ assign s_radio1_in_0_tlast = m_duc1_out_0_tlast;
assign s_radio1_in_0_tvalid = m_duc1_out_0_tvalid;
assign m_duc1_out_0_tready = s_radio1_in_0_tready;
- assign s_ddc1_in_0_tdata = m_radio1_out_0_tdata ;
- assign s_ddc1_in_0_tlast = m_radio1_out_0_tlast ;
+ assign s_ddc1_in_0_tdata = m_radio1_out_0_tdata;
+ assign s_ddc1_in_0_tlast = m_radio1_out_0_tlast;
assign s_ddc1_in_0_tvalid = m_radio1_out_0_tvalid;
assign m_radio1_out_0_tready = s_ddc1_in_0_tready;
- assign s_ep2_in0_tdata = m_ddc1_out_0_tdata ;
- assign s_ep2_in0_tlast = m_ddc1_out_0_tlast ;
+ assign s_ep2_in0_tdata = m_ddc1_out_0_tdata;
+ assign s_ep2_in0_tlast = m_ddc1_out_0_tlast;
assign s_ep2_in0_tvalid = m_ddc1_out_0_tvalid;
assign m_ddc1_out_0_tready = s_ep2_in0_tready;
- assign s_ddc1_in_1_tdata = m_radio1_out_1_tdata ;
- assign s_ddc1_in_1_tlast = m_radio1_out_1_tlast ;
+ assign s_ddc1_in_1_tdata = m_radio1_out_1_tdata;
+ assign s_ddc1_in_1_tlast = m_radio1_out_1_tlast;
assign s_ddc1_in_1_tvalid = m_radio1_out_1_tvalid;
assign m_radio1_out_1_tready = s_ddc1_in_1_tready;
- assign s_ep3_in0_tdata = m_ddc1_out_1_tdata ;
- assign s_ep3_in0_tlast = m_ddc1_out_1_tlast ;
+ assign s_ep3_in0_tdata = m_ddc1_out_1_tdata;
+ assign s_ep3_in0_tlast = m_ddc1_out_1_tlast;
assign s_ep3_in0_tvalid = m_ddc1_out_1_tvalid;
assign m_ddc1_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_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_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_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_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;
- // ----------------------------------------------------
+ //---------------------------------------------------------------------------
// Unused Ports
- // ----------------------------------------------------
+ //---------------------------------------------------------------------------
+
assign s_radio0_in_1_tdata = {CHDR_W{1'b0}};
assign s_radio0_in_1_tlast = 1'b0;
assign s_radio0_in_1_tvalid = 1'b0;
@@ -1293,9 +1346,11 @@ module rfnoc_image_core #(
assign m_ep1_out0_tready = 1'b1;
assign m_ep3_out0_tready = 1'b1;
- // ----------------------------------------------------
+
+ //---------------------------------------------------------------------------
// Clock Domains
- // ----------------------------------------------------
+ //---------------------------------------------------------------------------
+
assign radio0_radio_clk = radio_clk;
assign ddc0_ce_clk = ce_clk;
assign duc0_ce_clk = ce_clk;
@@ -1305,9 +1360,10 @@ module rfnoc_image_core #(
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;
@@ -1397,3 +1453,6 @@ module rfnoc_image_core #(
assign radio1_radio_time = radio_time;
endmodule
+
+
+`default_nettype wire
diff --git a/fpga/usrp3/top/x300/x300_rfnoc_image_core.vh b/fpga/usrp3/top/x300/x300_rfnoc_image_core.vh
new file mode 100644
index 000000000..a651f32d1
--- /dev/null
+++ b/fpga/usrp3/top/x300/x300_rfnoc_image_core.vh
@@ -0,0 +1,21 @@
+//
+// Copyright 2021 Ettus Research, A National Instruments Brand
+//
+// SPDX-License-Identifier: LGPL-3.0-or-later
+//
+// Header: rfnoc_image_core.vh (for x300)
+//
+// 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: 2021-05-03T08:51:07.013471
+// Source: x300_rfnoc_image_core.yml
+// Source SHA256: 32a28be8a0bcbe6bb9a5df0058b3c813741fa80c1faafd11270d8b500d7d9b85
+//
+
+`define CHDR_WIDTH 64
+`define RFNOC_PROTOVER { 8'd1, 8'd0 }
diff --git a/fpga/usrp3/top/x300/x310_rfnoc_image_core.v b/fpga/usrp3/top/x300/x310_rfnoc_image_core.v
index 4dc38bd11..45588a7b0 100644
--- a/fpga/usrp3/top/x300/x310_rfnoc_image_core.v
+++ b/fpga/usrp3/top/x300/x310_rfnoc_image_core.v
@@ -1,19 +1,32 @@
//
-// Copyright 2020 Ettus Research, A National Instruments Brand
+// Copyright 2021 Ettus Research, A National Instruments Brand
//
// SPDX-License-Identifier: LGPL-3.0-or-later
//
-
// Module: rfnoc_image_core (for x300)
-// This file was autogenerated by UHD's image builder tool (rfnoc_image_builder)
-// Re-running that tool will overwrite this file!
-// File generated on: 2020-09-02T12:02:33.545638
-// Source: ./x310_rfnoc_image_core.yml
-// Source SHA256: acc39ec2e56ad0a5dd482a8db6b4dbb7e9790c03074d7461a38e0b5356456a83
+//
+// 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: 2021-05-03T08:51:07.732667
+// Source: x310_rfnoc_image_core.yml
+// Source SHA256: 7a01e3b4aa95b9e5b59f627d5a7d3f27c16afb4bb6bdad1f7fb9a624fb4b9647
+//
+
+`default_nettype none
+
module rfnoc_image_core #(
- parameter [15:0] PROTOVER = {8'd1, 8'd0}
-)(
+ parameter CHDR_W = 64,
+ parameter MTU = 10,
+ parameter [15:0] PROTOVER = {8'd1, 8'd0},
+ parameter RADIO_NIPC = 1
+) (
// Clocks
input wire chdr_aclk,
input wire ctrl_aclk,
@@ -22,131 +35,136 @@ module rfnoc_image_core #(
input wire ce_clk,
input wire dram_clk,
// Basic
- input wire [15:0] device_id,
-//// IO ports //////////////////////////////////
-// ctrlport_radio0
- output wire [ 1-1:0] m_ctrlport_radio0_req_wr,
- output wire [ 1-1:0] m_ctrlport_radio0_req_rd,
- output wire [ 20-1:0] m_ctrlport_radio0_req_addr,
- output wire [ 32-1:0] m_ctrlport_radio0_req_data,
- output wire [ 4-1:0] m_ctrlport_radio0_req_byte_en,
- output wire [ 1-1:0] m_ctrlport_radio0_req_has_time,
- output wire [ 64-1:0] m_ctrlport_radio0_req_time,
- input wire [ 1-1:0] m_ctrlport_radio0_resp_ack,
- input wire [ 2-1:0] m_ctrlport_radio0_resp_status,
- input wire [ 32-1:0] m_ctrlport_radio0_resp_data,
-// ctrlport_radio1
- output wire [ 1-1:0] m_ctrlport_radio1_req_wr,
- output wire [ 1-1:0] m_ctrlport_radio1_req_rd,
- output wire [ 20-1:0] m_ctrlport_radio1_req_addr,
- output wire [ 32-1:0] m_ctrlport_radio1_req_data,
- output wire [ 4-1:0] m_ctrlport_radio1_req_byte_en,
- output wire [ 1-1:0] m_ctrlport_radio1_req_has_time,
- output wire [ 64-1:0] m_ctrlport_radio1_req_time,
- input wire [ 1-1:0] m_ctrlport_radio1_resp_ack,
- input wire [ 2-1:0] m_ctrlport_radio1_resp_status,
- input wire [ 32-1:0] m_ctrlport_radio1_resp_data,
-// time_keeper
- input wire [ 64-1:0] radio_time,
-// x300_radio0
- input wire [ 64-1:0] radio_rx_data_radio0,
- input wire [ 2-1:0] radio_rx_stb_radio0,
- output wire [ 2-1:0] radio_rx_running_radio0,
- output wire [ 64-1:0] radio_tx_data_radio0,
- input wire [ 2-1:0] radio_tx_stb_radio0,
- output wire [ 2-1:0] radio_tx_running_radio0,
-// x300_radio1
- input wire [ 64-1:0] radio_rx_data_radio1,
- input wire [ 2-1:0] radio_rx_stb_radio1,
- output wire [ 2-1:0] radio_rx_running_radio1,
- output wire [ 64-1:0] radio_tx_data_radio1,
- input wire [ 2-1:0] radio_tx_stb_radio1,
- output wire [ 2-1:0] radio_tx_running_radio1,
-// dram
- input wire [ 1-1:0] axi_rst,
- output wire [ 4-1:0] m_axi_awid,
- output wire [128-1:0] m_axi_awaddr,
- output wire [ 32-1:0] m_axi_awlen,
- output wire [ 12-1:0] m_axi_awsize,
- output wire [ 8-1:0] m_axi_awburst,
- output wire [ 4-1:0] m_axi_awlock,
- output wire [ 16-1:0] m_axi_awcache,
- output wire [ 12-1:0] m_axi_awprot,
- output wire [ 16-1:0] m_axi_awqos,
- output wire [ 16-1:0] m_axi_awregion,
- output wire [ 4-1:0] m_axi_awuser,
- output wire [ 4-1:0] m_axi_awvalid,
- input wire [ 4-1:0] m_axi_awready,
- output wire [256-1:0] m_axi_wdata,
- output wire [ 32-1:0] m_axi_wstrb,
- output wire [ 4-1:0] m_axi_wlast,
- output wire [ 4-1:0] m_axi_wuser,
- output wire [ 4-1:0] m_axi_wvalid,
- input wire [ 4-1:0] m_axi_wready,
- input wire [ 4-1:0] m_axi_bid,
- input wire [ 8-1:0] m_axi_bresp,
- input wire [ 4-1:0] m_axi_buser,
- input wire [ 4-1:0] m_axi_bvalid,
- output wire [ 4-1:0] m_axi_bready,
- output wire [ 4-1:0] m_axi_arid,
- output wire [128-1:0] m_axi_araddr,
- output wire [ 32-1:0] m_axi_arlen,
- output wire [ 12-1:0] m_axi_arsize,
- output wire [ 8-1:0] m_axi_arburst,
- output wire [ 4-1:0] m_axi_arlock,
- output wire [ 16-1:0] m_axi_arcache,
- output wire [ 12-1:0] m_axi_arprot,
- output wire [ 16-1:0] m_axi_arqos,
- output wire [ 16-1:0] m_axi_arregion,
- output wire [ 4-1:0] m_axi_aruser,
- output wire [ 4-1:0] m_axi_arvalid,
- input wire [ 4-1:0] m_axi_arready,
- input wire [ 4-1:0] m_axi_rid,
- input wire [256-1:0] m_axi_rdata,
- input wire [ 8-1:0] m_axi_rresp,
- input wire [ 4-1:0] m_axi_rlast,
- input wire [ 4-1:0] m_axi_ruser,
- input wire [ 4-1:0] m_axi_rvalid,
- output wire [ 4-1:0] m_axi_rready,
- // Transport 0 (eth0 10G)
- input wire [64-1:0] s_eth0_tdata,
- input wire s_eth0_tlast,
- input wire s_eth0_tvalid,
- output wire s_eth0_tready,
- output wire [64-1:0] m_eth0_tdata,
- output wire m_eth0_tlast,
- output wire m_eth0_tvalid,
- input wire m_eth0_tready,
- // Transport 1 (eth1 1G)
- input wire [64-1:0] s_eth1_tdata,
- input wire s_eth1_tlast,
- input wire s_eth1_tvalid,
- output wire s_eth1_tready,
- output wire [64-1:0] m_eth1_tdata,
- output wire m_eth1_tlast,
- output wire m_eth1_tvalid,
- input wire m_eth1_tready,
- // Transport 2 (pcie PCIe)
- input wire [64-1:0] s_pcie_tdata,
- input wire s_pcie_tlast,
- input wire s_pcie_tvalid,
- output wire s_pcie_tready,
- output wire [64-1:0] m_pcie_tdata,
- output wire m_pcie_tlast,
- output wire m_pcie_tvalid,
- input wire m_pcie_tready
+ 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_keeper
+ input wire [ 63:0] radio_time,
+ // x300_radio0
+ input wire [ 63:0] radio_rx_data_radio0,
+ input wire [ 1:0] radio_rx_stb_radio0,
+ output wire [ 1:0] radio_rx_running_radio0,
+ output wire [ 63:0] radio_tx_data_radio0,
+ input wire [ 1:0] radio_tx_stb_radio0,
+ output wire [ 1:0] radio_tx_running_radio0,
+ // x300_radio1
+ input wire [ 63:0] radio_rx_data_radio1,
+ input wire [ 1:0] radio_rx_stb_radio1,
+ output wire [ 1:0] radio_rx_running_radio1,
+ output wire [ 63:0] radio_tx_data_radio1,
+ input wire [ 1:0] radio_tx_stb_radio1,
+ output wire [ 1:0] radio_tx_running_radio1,
+ // dram
+ input wire [ 0:0] axi_rst,
+ output wire [ 3:0] m_axi_awid,
+ output wire [ 127: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 [ 255:0] m_axi_wdata,
+ output wire [ 31: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 [ 127: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 [ 255: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 (pcie)
+ input wire [CHDR_W-1:0] s_pcie_tdata,
+ input wire s_pcie_tlast,
+ input wire s_pcie_tvalid,
+ output wire s_pcie_tready,
+ output wire [CHDR_W-1:0] m_pcie_tdata,
+ output wire m_pcie_tlast,
+ output wire m_pcie_tvalid,
+ input wire m_pcie_tready
);
- localparam CHDR_W = 64;
- localparam MTU = 10;
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;
@@ -211,12 +229,12 @@ module rfnoc_image_core #(
.clk (rfnoc_chdr_clk),
.reset (rfnoc_chdr_rst),
.device_id (device_id),
- .s_axis_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_pcie_tdata, s_eth1_tdata, s_eth0_tdata}),
- .s_axis_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_pcie_tlast, s_eth1_tlast, s_eth0_tlast}),
+ .s_axis_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_pcie_tdata , s_eth1_tdata , s_eth0_tdata }),
+ .s_axis_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_pcie_tlast , s_eth1_tlast , s_eth0_tlast }),
.s_axis_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_pcie_tvalid, s_eth1_tvalid, s_eth0_tvalid}),
.s_axis_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_pcie_tready, s_eth1_tready, s_eth0_tready}),
- .m_axis_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_pcie_tdata, m_eth1_tdata, m_eth0_tdata}),
- .m_axis_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_pcie_tlast, m_eth1_tlast, m_eth0_tlast}),
+ .m_axis_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_pcie_tdata , m_eth1_tdata , m_eth0_tdata }),
+ .m_axis_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_pcie_tlast , m_eth1_tlast , m_eth0_tlast }),
.m_axis_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_pcie_tvalid, m_eth1_tvalid, m_eth0_tvalid}),
.m_axis_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_pcie_tready, m_eth1_tready, m_eth0_tready}),
.ext_rtcfg_stb (1'h0),
@@ -225,9 +243,18 @@ module rfnoc_image_core #(
.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 = 65536;
+ 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;
@@ -237,8 +264,8 @@ module rfnoc_image_core #(
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 [ 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;
@@ -251,23 +278,23 @@ module rfnoc_image_core #(
.NUM_DATA_O (1),
.INST_NUM (0),
.CTRL_XBAR_PORT (1),
- .INGRESS_BUFF_SIZE (16),
+ .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 ),
+ .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}),
@@ -276,20 +303,28 @@ module rfnoc_image_core #(
.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_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_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 )
+ .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 = 0;
+ 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;
@@ -298,8 +333,8 @@ module rfnoc_image_core #(
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 [ 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;
@@ -312,23 +347,23 @@ module rfnoc_image_core #(
.NUM_DATA_O (1),
.INST_NUM (1),
.CTRL_XBAR_PORT (2),
- .INGRESS_BUFF_SIZE (5),
+ .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 ),
+ .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}),
@@ -337,20 +372,28 @@ module rfnoc_image_core #(
.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_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_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 )
+ .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 = 65536;
+ 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;
@@ -359,8 +402,8 @@ module rfnoc_image_core #(
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 [ 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;
@@ -373,23 +416,23 @@ module rfnoc_image_core #(
.NUM_DATA_O (1),
.INST_NUM (2),
.CTRL_XBAR_PORT (3),
- .INGRESS_BUFF_SIZE (16),
+ .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 ),
+ .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}),
@@ -398,20 +441,28 @@ module rfnoc_image_core #(
.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_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_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 )
+ .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 = 0;
+ 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;
@@ -420,8 +471,8 @@ module rfnoc_image_core #(
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 [ 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;
@@ -434,23 +485,23 @@ module rfnoc_image_core #(
.NUM_DATA_O (1),
.INST_NUM (3),
.CTRL_XBAR_PORT (4),
- .INGRESS_BUFF_SIZE (5),
+ .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 ),
+ .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}),
@@ -459,20 +510,28 @@ module rfnoc_image_core #(
.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_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_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 )
+ .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 = 4096;
+ 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;
@@ -481,8 +540,8 @@ module rfnoc_image_core #(
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 [ 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;
@@ -495,23 +554,23 @@ module rfnoc_image_core #(
.NUM_DATA_O (1),
.INST_NUM (4),
.CTRL_XBAR_PORT (5),
- .INGRESS_BUFF_SIZE (12),
+ .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 ),
+ .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}),
@@ -520,20 +579,28 @@ module rfnoc_image_core #(
.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_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_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 )
+ .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 = 4096;
+ 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;
@@ -542,8 +609,8 @@ module rfnoc_image_core #(
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 [ 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;
@@ -556,23 +623,23 @@ module rfnoc_image_core #(
.NUM_DATA_O (1),
.INST_NUM (5),
.CTRL_XBAR_PORT (6),
- .INGRESS_BUFF_SIZE (12),
+ .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 ),
+ .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}),
@@ -581,58 +648,57 @@ module rfnoc_image_core #(
.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_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_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 )
+ .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_duc0_ctrl_tdata , s_duc0_ctrl_tdata ;
- wire m_duc0_ctrl_tlast , s_duc0_ctrl_tlast ;
- wire m_duc0_ctrl_tvalid, s_duc0_ctrl_tvalid;
- wire m_duc0_ctrl_tready, s_duc0_ctrl_tready;
- wire [31:0] m_ddc0_ctrl_tdata , s_ddc0_ctrl_tdata ;
- wire m_ddc0_ctrl_tlast , s_ddc0_ctrl_tlast ;
- wire m_ddc0_ctrl_tvalid, s_ddc0_ctrl_tvalid;
- wire m_ddc0_ctrl_tready, s_ddc0_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_duc1_ctrl_tdata , s_duc1_ctrl_tdata ;
- wire m_duc1_ctrl_tlast , s_duc1_ctrl_tlast ;
- wire m_duc1_ctrl_tvalid, s_duc1_ctrl_tvalid;
- wire m_duc1_ctrl_tready, s_duc1_ctrl_tready;
- wire [31:0] m_ddc1_ctrl_tdata , s_ddc1_ctrl_tdata ;
- wire m_ddc1_ctrl_tlast , s_ddc1_ctrl_tlast ;
- wire m_ddc1_ctrl_tvalid, s_ddc1_ctrl_tvalid;
- wire m_ddc1_ctrl_tready, s_ddc1_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;
+ //---------------------------------------------------------------------------
+
+ 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_duc0_ctrl_tdata, s_duc0_ctrl_tdata;
+ wire m_duc0_ctrl_tlast, s_duc0_ctrl_tlast;
+ wire m_duc0_ctrl_tvalid, s_duc0_ctrl_tvalid;
+ wire m_duc0_ctrl_tready, s_duc0_ctrl_tready;
+ wire [31:0] m_ddc0_ctrl_tdata, s_ddc0_ctrl_tdata;
+ wire m_ddc0_ctrl_tlast, s_ddc0_ctrl_tlast;
+ wire m_ddc0_ctrl_tvalid, s_ddc0_ctrl_tvalid;
+ wire m_ddc0_ctrl_tready, s_ddc0_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_duc1_ctrl_tdata, s_duc1_ctrl_tdata;
+ wire m_duc1_ctrl_tlast, s_duc1_ctrl_tlast;
+ wire m_duc1_ctrl_tvalid, s_duc1_ctrl_tvalid;
+ wire m_duc1_ctrl_tready, s_duc1_ctrl_tready;
+ wire [31:0] m_ddc1_ctrl_tdata, s_ddc1_ctrl_tdata;
+ wire m_ddc1_ctrl_tlast, s_ddc1_ctrl_tlast;
+ wire m_ddc1_ctrl_tvalid, s_ddc1_ctrl_tvalid;
+ wire m_ddc1_ctrl_tready, s_ddc1_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),
@@ -656,9 +722,11 @@ module rfnoc_image_core #(
.deadlock_detected()
);
- // ----------------------------------------------------
+
+ //---------------------------------------------------------------------------
// RFNoC Core Kernel
- // ----------------------------------------------------
+ //---------------------------------------------------------------------------
+
wire [(512*7)-1:0] rfnoc_core_config, rfnoc_core_status;
rfnoc_core_kernel #(
@@ -683,12 +751,12 @@ module rfnoc_image_core #(
.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_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_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),
@@ -696,13 +764,15 @@ module rfnoc_image_core #(
.rfnoc_core_status (rfnoc_core_status)
);
- // ----------------------------------------------------
+
+ //---------------------------------------------------------------------------
// Blocks
- // ----------------------------------------------------
+ //---------------------------------------------------------------------------
- // ----------------------------------------------------
+ //-----------------------------------
// duc0
- // ----------------------------------------------------
+ //-----------------------------------
+
wire duc0_ce_clk;
wire [CHDR_W-1:0] s_duc0_in_0_tdata ;
wire s_duc0_in_0_tlast ;
@@ -713,44 +783,41 @@ module rfnoc_image_core #(
wire m_duc0_out_0_tvalid;
wire m_duc0_out_0_tready;
-
rfnoc_block_duc #(
- .THIS_PORTID(2),
- .CHDR_W(CHDR_W),
- .NUM_PORTS(1),
- .NUM_HB(3),
- .CIC_MAX_INTERP(255),
- .MTU(MTU)
+ .THIS_PORTID (2),
+ .CHDR_W (CHDR_W),
+ .NUM_PORTS (1),
+ .NUM_HB (3),
+ .CIC_MAX_INTERP (255),
+ .MTU (MTU)
) b_duc0_0 (
- .rfnoc_chdr_clk (rfnoc_chdr_clk),
- .rfnoc_ctrl_clk (rfnoc_ctrl_clk),
- .ce_clk(duc0_ce_clk),
- .rfnoc_core_config (rfnoc_core_config[512*1-1:512*0]),
- .rfnoc_core_status (rfnoc_core_status[512*1-1:512*0]),
-
-
- .s_rfnoc_chdr_tdata ({s_duc0_in_0_tdata }),
- .s_rfnoc_chdr_tlast ({s_duc0_in_0_tlast }),
- .s_rfnoc_chdr_tvalid({s_duc0_in_0_tvalid}),
- .s_rfnoc_chdr_tready({s_duc0_in_0_tready}),
- .m_rfnoc_chdr_tdata ({m_duc0_out_0_tdata }),
- .m_rfnoc_chdr_tlast ({m_duc0_out_0_tlast }),
- .m_rfnoc_chdr_tvalid({m_duc0_out_0_tvalid}),
- .m_rfnoc_chdr_tready({m_duc0_out_0_tready}),
- .s_rfnoc_ctrl_tdata (s_duc0_ctrl_tdata ),
- .s_rfnoc_ctrl_tlast (s_duc0_ctrl_tlast ),
- .s_rfnoc_ctrl_tvalid(s_duc0_ctrl_tvalid),
- .s_rfnoc_ctrl_tready(s_duc0_ctrl_tready),
- .m_rfnoc_ctrl_tdata (m_duc0_ctrl_tdata ),
- .m_rfnoc_ctrl_tlast (m_duc0_ctrl_tlast ),
- .m_rfnoc_ctrl_tvalid(m_duc0_ctrl_tvalid),
- .m_rfnoc_ctrl_tready(m_duc0_ctrl_tready)
+ .rfnoc_chdr_clk (rfnoc_chdr_clk),
+ .rfnoc_ctrl_clk (rfnoc_ctrl_clk),
+ .ce_clk (duc0_ce_clk),
+ .rfnoc_core_config (rfnoc_core_config[512*1-1:512*0]),
+ .rfnoc_core_status (rfnoc_core_status[512*1-1:512*0]),
+ .s_rfnoc_chdr_tdata ({s_duc0_in_0_tdata }),
+ .s_rfnoc_chdr_tlast ({s_duc0_in_0_tlast }),
+ .s_rfnoc_chdr_tvalid ({s_duc0_in_0_tvalid}),
+ .s_rfnoc_chdr_tready ({s_duc0_in_0_tready}),
+ .m_rfnoc_chdr_tdata ({m_duc0_out_0_tdata }),
+ .m_rfnoc_chdr_tlast ({m_duc0_out_0_tlast }),
+ .m_rfnoc_chdr_tvalid ({m_duc0_out_0_tvalid}),
+ .m_rfnoc_chdr_tready ({m_duc0_out_0_tready}),
+ .s_rfnoc_ctrl_tdata (s_duc0_ctrl_tdata),
+ .s_rfnoc_ctrl_tlast (s_duc0_ctrl_tlast),
+ .s_rfnoc_ctrl_tvalid (s_duc0_ctrl_tvalid),
+ .s_rfnoc_ctrl_tready (s_duc0_ctrl_tready),
+ .m_rfnoc_ctrl_tdata (m_duc0_ctrl_tdata),
+ .m_rfnoc_ctrl_tlast (m_duc0_ctrl_tlast),
+ .m_rfnoc_ctrl_tvalid (m_duc0_ctrl_tvalid),
+ .m_rfnoc_ctrl_tready (m_duc0_ctrl_tready)
);
-
- // ----------------------------------------------------
+ //-----------------------------------
// ddc0
- // ----------------------------------------------------
+ //-----------------------------------
+
wire ddc0_ce_clk;
wire [CHDR_W-1:0] s_ddc0_in_1_tdata , s_ddc0_in_0_tdata ;
wire s_ddc0_in_1_tlast , s_ddc0_in_0_tlast ;
@@ -761,44 +828,41 @@ module rfnoc_image_core #(
wire m_ddc0_out_1_tvalid, m_ddc0_out_0_tvalid;
wire m_ddc0_out_1_tready, m_ddc0_out_0_tready;
-
rfnoc_block_ddc #(
- .THIS_PORTID(3),
- .CHDR_W(CHDR_W),
- .NUM_PORTS(2),
- .NUM_HB(3),
- .CIC_MAX_DECIM(255),
- .MTU(MTU)
+ .THIS_PORTID (3),
+ .CHDR_W (CHDR_W),
+ .NUM_PORTS (2),
+ .NUM_HB (3),
+ .CIC_MAX_DECIM (255),
+ .MTU (MTU)
) b_ddc0_1 (
- .rfnoc_chdr_clk (rfnoc_chdr_clk),
- .rfnoc_ctrl_clk (rfnoc_ctrl_clk),
- .ce_clk(ddc0_ce_clk),
- .rfnoc_core_config (rfnoc_core_config[512*2-1:512*1]),
- .rfnoc_core_status (rfnoc_core_status[512*2-1:512*1]),
-
-
- .s_rfnoc_chdr_tdata ({s_ddc0_in_1_tdata , s_ddc0_in_0_tdata }),
- .s_rfnoc_chdr_tlast ({s_ddc0_in_1_tlast , s_ddc0_in_0_tlast }),
- .s_rfnoc_chdr_tvalid({s_ddc0_in_1_tvalid, s_ddc0_in_0_tvalid}),
- .s_rfnoc_chdr_tready({s_ddc0_in_1_tready, s_ddc0_in_0_tready}),
- .m_rfnoc_chdr_tdata ({m_ddc0_out_1_tdata , m_ddc0_out_0_tdata }),
- .m_rfnoc_chdr_tlast ({m_ddc0_out_1_tlast , m_ddc0_out_0_tlast }),
- .m_rfnoc_chdr_tvalid({m_ddc0_out_1_tvalid, m_ddc0_out_0_tvalid}),
- .m_rfnoc_chdr_tready({m_ddc0_out_1_tready, m_ddc0_out_0_tready}),
- .s_rfnoc_ctrl_tdata (s_ddc0_ctrl_tdata ),
- .s_rfnoc_ctrl_tlast (s_ddc0_ctrl_tlast ),
- .s_rfnoc_ctrl_tvalid(s_ddc0_ctrl_tvalid),
- .s_rfnoc_ctrl_tready(s_ddc0_ctrl_tready),
- .m_rfnoc_ctrl_tdata (m_ddc0_ctrl_tdata ),
- .m_rfnoc_ctrl_tlast (m_ddc0_ctrl_tlast ),
- .m_rfnoc_ctrl_tvalid(m_ddc0_ctrl_tvalid),
- .m_rfnoc_ctrl_tready(m_ddc0_ctrl_tready)
+ .rfnoc_chdr_clk (rfnoc_chdr_clk),
+ .rfnoc_ctrl_clk (rfnoc_ctrl_clk),
+ .ce_clk (ddc0_ce_clk),
+ .rfnoc_core_config (rfnoc_core_config[512*2-1:512*1]),
+ .rfnoc_core_status (rfnoc_core_status[512*2-1:512*1]),
+ .s_rfnoc_chdr_tdata ({s_ddc0_in_1_tdata , s_ddc0_in_0_tdata }),
+ .s_rfnoc_chdr_tlast ({s_ddc0_in_1_tlast , s_ddc0_in_0_tlast }),
+ .s_rfnoc_chdr_tvalid ({s_ddc0_in_1_tvalid, s_ddc0_in_0_tvalid}),
+ .s_rfnoc_chdr_tready ({s_ddc0_in_1_tready, s_ddc0_in_0_tready}),
+ .m_rfnoc_chdr_tdata ({m_ddc0_out_1_tdata , m_ddc0_out_0_tdata }),
+ .m_rfnoc_chdr_tlast ({m_ddc0_out_1_tlast , m_ddc0_out_0_tlast }),
+ .m_rfnoc_chdr_tvalid ({m_ddc0_out_1_tvalid, m_ddc0_out_0_tvalid}),
+ .m_rfnoc_chdr_tready ({m_ddc0_out_1_tready, m_ddc0_out_0_tready}),
+ .s_rfnoc_ctrl_tdata (s_ddc0_ctrl_tdata),
+ .s_rfnoc_ctrl_tlast (s_ddc0_ctrl_tlast),
+ .s_rfnoc_ctrl_tvalid (s_ddc0_ctrl_tvalid),
+ .s_rfnoc_ctrl_tready (s_ddc0_ctrl_tready),
+ .m_rfnoc_ctrl_tdata (m_ddc0_ctrl_tdata),
+ .m_rfnoc_ctrl_tlast (m_ddc0_ctrl_tlast),
+ .m_rfnoc_ctrl_tvalid (m_ddc0_ctrl_tvalid),
+ .m_rfnoc_ctrl_tready (m_ddc0_ctrl_tready)
);
-
- // ----------------------------------------------------
+ //-----------------------------------
// 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 ;
@@ -809,79 +873,77 @@ module rfnoc_image_core #(
wire m_radio0_out_1_tvalid, m_radio0_out_0_tvalid;
wire m_radio0_out_1_tready, m_radio0_out_0_tready;
- // ctrl_port
- wire [ 1-1:0] radio0_m_ctrlport_req_wr;
- wire [ 1-1:0] radio0_m_ctrlport_req_rd;
- wire [ 20-1:0] radio0_m_ctrlport_req_addr;
- wire [ 32-1:0] radio0_m_ctrlport_req_data;
- wire [ 4-1:0] radio0_m_ctrlport_req_byte_en;
- wire [ 1-1:0] radio0_m_ctrlport_req_has_time;
- wire [ 64-1:0] radio0_m_ctrlport_req_time;
- wire [ 1-1:0] radio0_m_ctrlport_resp_ack;
- wire [ 2-1:0] radio0_m_ctrlport_resp_status;
- wire [ 32-1:0] radio0_m_ctrlport_resp_data;
- // time_keeper
- wire [ 64-1:0] radio0_radio_time;
- // x300_radio
- wire [ 64-1:0] radio0_radio_rx_data;
- wire [ 2-1:0] radio0_radio_rx_stb;
- wire [ 2-1:0] radio0_radio_rx_running;
- wire [ 64-1:0] radio0_radio_tx_data;
- wire [ 2-1:0] radio0_radio_tx_stb;
- wire [ 2-1:0] radio0_radio_tx_running;
+ // ctrl_port
+ 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_keeper
+ wire [ 63:0] radio0_radio_time;
+ // x300_radio
+ wire [ 63:0] radio0_radio_rx_data;
+ wire [ 1:0] radio0_radio_rx_stb;
+ wire [ 1:0] radio0_radio_rx_running;
+ wire [ 63:0] radio0_radio_tx_data;
+ wire [ 1:0] radio0_radio_tx_stb;
+ wire [ 1:0] radio0_radio_tx_running;
rfnoc_block_radio #(
- .THIS_PORTID(4),
- .CHDR_W(CHDR_W),
- .NUM_PORTS(2),
- .MTU(MTU)
+ .THIS_PORTID (4),
+ .CHDR_W (CHDR_W),
+ .NUM_PORTS (2),
+ .MTU (MTU)
) b_radio0_2 (
- .rfnoc_chdr_clk (rfnoc_chdr_clk),
- .rfnoc_ctrl_clk (rfnoc_ctrl_clk),
- .radio_clk(radio0_radio_clk),
- .rfnoc_core_config (rfnoc_core_config[512*3-1:512*2]),
- .rfnoc_core_status (rfnoc_core_status[512*3-1:512*2]),
-
- .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),
+ .rfnoc_chdr_clk (rfnoc_chdr_clk),
+ .rfnoc_ctrl_clk (rfnoc_ctrl_clk),
+ .radio_clk (radio0_radio_clk),
+ .rfnoc_core_config (rfnoc_core_config[512*3-1:512*2]),
+ .rfnoc_core_status (rfnoc_core_status[512*3-1:512*2]),
+ .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_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)
+ .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)
);
-
- // ----------------------------------------------------
+ //-----------------------------------
// duc1
- // ----------------------------------------------------
+ //-----------------------------------
+
wire duc1_ce_clk;
wire [CHDR_W-1:0] s_duc1_in_0_tdata ;
wire s_duc1_in_0_tlast ;
@@ -892,44 +954,41 @@ module rfnoc_image_core #(
wire m_duc1_out_0_tvalid;
wire m_duc1_out_0_tready;
-
rfnoc_block_duc #(
- .THIS_PORTID(5),
- .CHDR_W(CHDR_W),
- .NUM_PORTS(1),
- .NUM_HB(3),
- .CIC_MAX_INTERP(255),
- .MTU(MTU)
+ .THIS_PORTID (5),
+ .CHDR_W (CHDR_W),
+ .NUM_PORTS (1),
+ .NUM_HB (3),
+ .CIC_MAX_INTERP (255),
+ .MTU (MTU)
) b_duc1_3 (
- .rfnoc_chdr_clk (rfnoc_chdr_clk),
- .rfnoc_ctrl_clk (rfnoc_ctrl_clk),
- .ce_clk(duc1_ce_clk),
- .rfnoc_core_config (rfnoc_core_config[512*4-1:512*3]),
- .rfnoc_core_status (rfnoc_core_status[512*4-1:512*3]),
-
-
- .s_rfnoc_chdr_tdata ({s_duc1_in_0_tdata }),
- .s_rfnoc_chdr_tlast ({s_duc1_in_0_tlast }),
- .s_rfnoc_chdr_tvalid({s_duc1_in_0_tvalid}),
- .s_rfnoc_chdr_tready({s_duc1_in_0_tready}),
- .m_rfnoc_chdr_tdata ({m_duc1_out_0_tdata }),
- .m_rfnoc_chdr_tlast ({m_duc1_out_0_tlast }),
- .m_rfnoc_chdr_tvalid({m_duc1_out_0_tvalid}),
- .m_rfnoc_chdr_tready({m_duc1_out_0_tready}),
- .s_rfnoc_ctrl_tdata (s_duc1_ctrl_tdata ),
- .s_rfnoc_ctrl_tlast (s_duc1_ctrl_tlast ),
- .s_rfnoc_ctrl_tvalid(s_duc1_ctrl_tvalid),
- .s_rfnoc_ctrl_tready(s_duc1_ctrl_tready),
- .m_rfnoc_ctrl_tdata (m_duc1_ctrl_tdata ),
- .m_rfnoc_ctrl_tlast (m_duc1_ctrl_tlast ),
- .m_rfnoc_ctrl_tvalid(m_duc1_ctrl_tvalid),
- .m_rfnoc_ctrl_tready(m_duc1_ctrl_tready)
+ .rfnoc_chdr_clk (rfnoc_chdr_clk),
+ .rfnoc_ctrl_clk (rfnoc_ctrl_clk),
+ .ce_clk (duc1_ce_clk),
+ .rfnoc_core_config (rfnoc_core_config[512*4-1:512*3]),
+ .rfnoc_core_status (rfnoc_core_status[512*4-1:512*3]),
+ .s_rfnoc_chdr_tdata ({s_duc1_in_0_tdata }),
+ .s_rfnoc_chdr_tlast ({s_duc1_in_0_tlast }),
+ .s_rfnoc_chdr_tvalid ({s_duc1_in_0_tvalid}),
+ .s_rfnoc_chdr_tready ({s_duc1_in_0_tready}),
+ .m_rfnoc_chdr_tdata ({m_duc1_out_0_tdata }),
+ .m_rfnoc_chdr_tlast ({m_duc1_out_0_tlast }),
+ .m_rfnoc_chdr_tvalid ({m_duc1_out_0_tvalid}),
+ .m_rfnoc_chdr_tready ({m_duc1_out_0_tready}),
+ .s_rfnoc_ctrl_tdata (s_duc1_ctrl_tdata),
+ .s_rfnoc_ctrl_tlast (s_duc1_ctrl_tlast),
+ .s_rfnoc_ctrl_tvalid (s_duc1_ctrl_tvalid),
+ .s_rfnoc_ctrl_tready (s_duc1_ctrl_tready),
+ .m_rfnoc_ctrl_tdata (m_duc1_ctrl_tdata),
+ .m_rfnoc_ctrl_tlast (m_duc1_ctrl_tlast),
+ .m_rfnoc_ctrl_tvalid (m_duc1_ctrl_tvalid),
+ .m_rfnoc_ctrl_tready (m_duc1_ctrl_tready)
);
-
- // ----------------------------------------------------
+ //-----------------------------------
// ddc1
- // ----------------------------------------------------
+ //-----------------------------------
+
wire ddc1_ce_clk;
wire [CHDR_W-1:0] s_ddc1_in_1_tdata , s_ddc1_in_0_tdata ;
wire s_ddc1_in_1_tlast , s_ddc1_in_0_tlast ;
@@ -940,44 +999,41 @@ module rfnoc_image_core #(
wire m_ddc1_out_1_tvalid, m_ddc1_out_0_tvalid;
wire m_ddc1_out_1_tready, m_ddc1_out_0_tready;
-
rfnoc_block_ddc #(
- .THIS_PORTID(6),
- .CHDR_W(CHDR_W),
- .NUM_PORTS(2),
- .NUM_HB(3),
- .CIC_MAX_DECIM(255),
- .MTU(MTU)
+ .THIS_PORTID (6),
+ .CHDR_W (CHDR_W),
+ .NUM_PORTS (2),
+ .NUM_HB (3),
+ .CIC_MAX_DECIM (255),
+ .MTU (MTU)
) b_ddc1_4 (
- .rfnoc_chdr_clk (rfnoc_chdr_clk),
- .rfnoc_ctrl_clk (rfnoc_ctrl_clk),
- .ce_clk(ddc1_ce_clk),
- .rfnoc_core_config (rfnoc_core_config[512*5-1:512*4]),
- .rfnoc_core_status (rfnoc_core_status[512*5-1:512*4]),
-
-
- .s_rfnoc_chdr_tdata ({s_ddc1_in_1_tdata , s_ddc1_in_0_tdata }),
- .s_rfnoc_chdr_tlast ({s_ddc1_in_1_tlast , s_ddc1_in_0_tlast }),
- .s_rfnoc_chdr_tvalid({s_ddc1_in_1_tvalid, s_ddc1_in_0_tvalid}),
- .s_rfnoc_chdr_tready({s_ddc1_in_1_tready, s_ddc1_in_0_tready}),
- .m_rfnoc_chdr_tdata ({m_ddc1_out_1_tdata , m_ddc1_out_0_tdata }),
- .m_rfnoc_chdr_tlast ({m_ddc1_out_1_tlast , m_ddc1_out_0_tlast }),
- .m_rfnoc_chdr_tvalid({m_ddc1_out_1_tvalid, m_ddc1_out_0_tvalid}),
- .m_rfnoc_chdr_tready({m_ddc1_out_1_tready, m_ddc1_out_0_tready}),
- .s_rfnoc_ctrl_tdata (s_ddc1_ctrl_tdata ),
- .s_rfnoc_ctrl_tlast (s_ddc1_ctrl_tlast ),
- .s_rfnoc_ctrl_tvalid(s_ddc1_ctrl_tvalid),
- .s_rfnoc_ctrl_tready(s_ddc1_ctrl_tready),
- .m_rfnoc_ctrl_tdata (m_ddc1_ctrl_tdata ),
- .m_rfnoc_ctrl_tlast (m_ddc1_ctrl_tlast ),
- .m_rfnoc_ctrl_tvalid(m_ddc1_ctrl_tvalid),
- .m_rfnoc_ctrl_tready(m_ddc1_ctrl_tready)
+ .rfnoc_chdr_clk (rfnoc_chdr_clk),
+ .rfnoc_ctrl_clk (rfnoc_ctrl_clk),
+ .ce_clk (ddc1_ce_clk),
+ .rfnoc_core_config (rfnoc_core_config[512*5-1:512*4]),
+ .rfnoc_core_status (rfnoc_core_status[512*5-1:512*4]),
+ .s_rfnoc_chdr_tdata ({s_ddc1_in_1_tdata , s_ddc1_in_0_tdata }),
+ .s_rfnoc_chdr_tlast ({s_ddc1_in_1_tlast , s_ddc1_in_0_tlast }),
+ .s_rfnoc_chdr_tvalid ({s_ddc1_in_1_tvalid, s_ddc1_in_0_tvalid}),
+ .s_rfnoc_chdr_tready ({s_ddc1_in_1_tready, s_ddc1_in_0_tready}),
+ .m_rfnoc_chdr_tdata ({m_ddc1_out_1_tdata , m_ddc1_out_0_tdata }),
+ .m_rfnoc_chdr_tlast ({m_ddc1_out_1_tlast , m_ddc1_out_0_tlast }),
+ .m_rfnoc_chdr_tvalid ({m_ddc1_out_1_tvalid, m_ddc1_out_0_tvalid}),
+ .m_rfnoc_chdr_tready ({m_ddc1_out_1_tready, m_ddc1_out_0_tready}),
+ .s_rfnoc_ctrl_tdata (s_ddc1_ctrl_tdata),
+ .s_rfnoc_ctrl_tlast (s_ddc1_ctrl_tlast),
+ .s_rfnoc_ctrl_tvalid (s_ddc1_ctrl_tvalid),
+ .s_rfnoc_ctrl_tready (s_ddc1_ctrl_tready),
+ .m_rfnoc_ctrl_tdata (m_ddc1_ctrl_tdata),
+ .m_rfnoc_ctrl_tlast (m_ddc1_ctrl_tlast),
+ .m_rfnoc_ctrl_tvalid (m_ddc1_ctrl_tvalid),
+ .m_rfnoc_ctrl_tready (m_ddc1_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 ;
@@ -988,79 +1044,77 @@ module rfnoc_image_core #(
wire m_radio1_out_1_tvalid, m_radio1_out_0_tvalid;
wire m_radio1_out_1_tready, m_radio1_out_0_tready;
- // ctrl_port
- wire [ 1-1:0] radio1_m_ctrlport_req_wr;
- wire [ 1-1:0] radio1_m_ctrlport_req_rd;
- wire [ 20-1:0] radio1_m_ctrlport_req_addr;
- wire [ 32-1:0] radio1_m_ctrlport_req_data;
- wire [ 4-1:0] radio1_m_ctrlport_req_byte_en;
- wire [ 1-1:0] radio1_m_ctrlport_req_has_time;
- wire [ 64-1:0] radio1_m_ctrlport_req_time;
- wire [ 1-1:0] radio1_m_ctrlport_resp_ack;
- wire [ 2-1:0] radio1_m_ctrlport_resp_status;
- wire [ 32-1:0] radio1_m_ctrlport_resp_data;
- // time_keeper
- wire [ 64-1:0] radio1_radio_time;
- // x300_radio
- wire [ 64-1:0] radio1_radio_rx_data;
- wire [ 2-1:0] radio1_radio_rx_stb;
- wire [ 2-1:0] radio1_radio_rx_running;
- wire [ 64-1:0] radio1_radio_tx_data;
- wire [ 2-1:0] radio1_radio_tx_stb;
- wire [ 2-1:0] radio1_radio_tx_running;
+ // ctrl_port
+ 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_keeper
+ wire [ 63:0] radio1_radio_time;
+ // x300_radio
+ wire [ 63:0] radio1_radio_rx_data;
+ wire [ 1:0] radio1_radio_rx_stb;
+ wire [ 1:0] radio1_radio_rx_running;
+ wire [ 63:0] radio1_radio_tx_data;
+ wire [ 1:0] radio1_radio_tx_stb;
+ wire [ 1:0] radio1_radio_tx_running;
rfnoc_block_radio #(
- .THIS_PORTID(7),
- .CHDR_W(CHDR_W),
- .NUM_PORTS(2),
- .MTU(MTU)
+ .THIS_PORTID (7),
+ .CHDR_W (CHDR_W),
+ .NUM_PORTS (2),
+ .MTU (MTU)
) b_radio1_5 (
- .rfnoc_chdr_clk (rfnoc_chdr_clk),
- .rfnoc_ctrl_clk (rfnoc_ctrl_clk),
- .radio_clk(radio1_radio_clk),
- .rfnoc_core_config (rfnoc_core_config[512*6-1:512*5]),
- .rfnoc_core_status (rfnoc_core_status[512*6-1:512*5]),
-
- .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),
+ .rfnoc_chdr_clk (rfnoc_chdr_clk),
+ .rfnoc_ctrl_clk (rfnoc_ctrl_clk),
+ .radio_clk (radio1_radio_clk),
+ .rfnoc_core_config (rfnoc_core_config[512*6-1:512*5]),
+ .rfnoc_core_status (rfnoc_core_status[512*6-1:512*5]),
+ .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_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)
+ .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_1_tdata , s_replay0_in_0_tdata ;
wire s_replay0_in_1_tlast , s_replay0_in_0_tlast ;
@@ -1071,219 +1125,218 @@ module rfnoc_image_core #(
wire m_replay0_out_1_tvalid, m_replay0_out_0_tvalid;
wire m_replay0_out_1_tready, m_replay0_out_0_tready;
- // axi_ram
- wire [ 1-1:0] replay0_axi_rst;
- wire [ 4-1:0] replay0_m_axi_awid;
- wire [128-1:0] replay0_m_axi_awaddr;
- wire [ 32-1:0] replay0_m_axi_awlen;
- wire [ 12-1:0] replay0_m_axi_awsize;
- wire [ 8-1:0] replay0_m_axi_awburst;
- wire [ 4-1:0] replay0_m_axi_awlock;
- wire [ 16-1:0] replay0_m_axi_awcache;
- wire [ 12-1:0] replay0_m_axi_awprot;
- wire [ 16-1:0] replay0_m_axi_awqos;
- wire [ 16-1:0] replay0_m_axi_awregion;
- wire [ 4-1:0] replay0_m_axi_awuser;
- wire [ 4-1:0] replay0_m_axi_awvalid;
- wire [ 4-1:0] replay0_m_axi_awready;
- wire [256-1:0] replay0_m_axi_wdata;
- wire [ 32-1:0] replay0_m_axi_wstrb;
- wire [ 4-1:0] replay0_m_axi_wlast;
- wire [ 4-1:0] replay0_m_axi_wuser;
- wire [ 4-1:0] replay0_m_axi_wvalid;
- wire [ 4-1:0] replay0_m_axi_wready;
- wire [ 4-1:0] replay0_m_axi_bid;
- wire [ 8-1:0] replay0_m_axi_bresp;
- wire [ 4-1:0] replay0_m_axi_buser;
- wire [ 4-1:0] replay0_m_axi_bvalid;
- wire [ 4-1:0] replay0_m_axi_bready;
- wire [ 4-1:0] replay0_m_axi_arid;
- wire [128-1:0] replay0_m_axi_araddr;
- wire [ 32-1:0] replay0_m_axi_arlen;
- wire [ 12-1:0] replay0_m_axi_arsize;
- wire [ 8-1:0] replay0_m_axi_arburst;
- wire [ 4-1:0] replay0_m_axi_arlock;
- wire [ 16-1:0] replay0_m_axi_arcache;
- wire [ 12-1:0] replay0_m_axi_arprot;
- wire [ 16-1:0] replay0_m_axi_arqos;
- wire [ 16-1:0] replay0_m_axi_arregion;
- wire [ 4-1:0] replay0_m_axi_aruser;
- wire [ 4-1:0] replay0_m_axi_arvalid;
- wire [ 4-1:0] replay0_m_axi_arready;
- wire [ 4-1:0] replay0_m_axi_rid;
- wire [256-1:0] replay0_m_axi_rdata;
- wire [ 8-1:0] replay0_m_axi_rresp;
- wire [ 4-1:0] replay0_m_axi_rlast;
- wire [ 4-1:0] replay0_m_axi_ruser;
- wire [ 4-1:0] replay0_m_axi_rvalid;
- wire [ 4-1:0] replay0_m_axi_rready;
+ // axi_ram
+ wire [ 0:0] replay0_axi_rst;
+ wire [ 3:0] replay0_m_axi_awid;
+ wire [ 127: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 [ 255:0] replay0_m_axi_wdata;
+ wire [ 31: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 [ 127: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 [ 255: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(8),
- .CHDR_W(CHDR_W),
- .NUM_PORTS(2),
- .MEM_ADDR_W(30),
- .MEM_DATA_W(64),
- .MTU(MTU)
+ .THIS_PORTID (8),
+ .CHDR_W (CHDR_W),
+ .NUM_PORTS (2),
+ .MEM_ADDR_W (30),
+ .MEM_DATA_W (64),
+ .MTU (MTU)
) b_replay0_6 (
- .rfnoc_chdr_clk (rfnoc_chdr_clk),
- .rfnoc_ctrl_clk (rfnoc_ctrl_clk),
- .mem_clk(replay0_mem_clk),
- .rfnoc_core_config (rfnoc_core_config[512*7-1:512*6]),
- .rfnoc_core_status (rfnoc_core_status[512*7-1:512*6]),
-
- .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_1_tdata , s_replay0_in_0_tdata }),
- .s_rfnoc_chdr_tlast ({s_replay0_in_1_tlast , s_replay0_in_0_tlast }),
- .s_rfnoc_chdr_tvalid({s_replay0_in_1_tvalid, s_replay0_in_0_tvalid}),
- .s_rfnoc_chdr_tready({s_replay0_in_1_tready, s_replay0_in_0_tready}),
- .m_rfnoc_chdr_tdata ({m_replay0_out_1_tdata , m_replay0_out_0_tdata }),
- .m_rfnoc_chdr_tlast ({m_replay0_out_1_tlast , m_replay0_out_0_tlast }),
- .m_rfnoc_chdr_tvalid({m_replay0_out_1_tvalid, m_replay0_out_0_tvalid}),
- .m_rfnoc_chdr_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)
+ .rfnoc_chdr_clk (rfnoc_chdr_clk),
+ .rfnoc_ctrl_clk (rfnoc_ctrl_clk),
+ .mem_clk (replay0_mem_clk),
+ .rfnoc_core_config (rfnoc_core_config[512*7-1:512*6]),
+ .rfnoc_core_status (rfnoc_core_status[512*7-1:512*6]),
+ .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_1_tdata , s_replay0_in_0_tdata }),
+ .s_rfnoc_chdr_tlast ({s_replay0_in_1_tlast , s_replay0_in_0_tlast }),
+ .s_rfnoc_chdr_tvalid ({s_replay0_in_1_tvalid, s_replay0_in_0_tvalid}),
+ .s_rfnoc_chdr_tready ({s_replay0_in_1_tready, s_replay0_in_0_tready}),
+ .m_rfnoc_chdr_tdata ({m_replay0_out_1_tdata , m_replay0_out_0_tdata }),
+ .m_rfnoc_chdr_tlast ({m_replay0_out_1_tlast , m_replay0_out_0_tlast }),
+ .m_rfnoc_chdr_tvalid ({m_replay0_out_1_tvalid, m_replay0_out_0_tvalid}),
+ .m_rfnoc_chdr_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_duc0_in_0_tdata = m_ep0_out0_tdata ;
- assign s_duc0_in_0_tlast = m_ep0_out0_tlast ;
+ //---------------------------------------------------------------------------
+
+ assign s_duc0_in_0_tdata = m_ep0_out0_tdata;
+ assign s_duc0_in_0_tlast = m_ep0_out0_tlast;
assign s_duc0_in_0_tvalid = m_ep0_out0_tvalid;
assign m_ep0_out0_tready = s_duc0_in_0_tready;
- assign s_radio0_in_0_tdata = m_duc0_out_0_tdata ;
- assign s_radio0_in_0_tlast = m_duc0_out_0_tlast ;
+ assign s_radio0_in_0_tdata = m_duc0_out_0_tdata;
+ assign s_radio0_in_0_tlast = m_duc0_out_0_tlast;
assign s_radio0_in_0_tvalid = m_duc0_out_0_tvalid;
assign m_duc0_out_0_tready = s_radio0_in_0_tready;
- assign s_ddc0_in_0_tdata = m_radio0_out_0_tdata ;
- assign s_ddc0_in_0_tlast = m_radio0_out_0_tlast ;
+ assign s_ddc0_in_0_tdata = m_radio0_out_0_tdata;
+ assign s_ddc0_in_0_tlast = m_radio0_out_0_tlast;
assign s_ddc0_in_0_tvalid = m_radio0_out_0_tvalid;
assign m_radio0_out_0_tready = s_ddc0_in_0_tready;
- assign s_ep0_in0_tdata = m_ddc0_out_0_tdata ;
- assign s_ep0_in0_tlast = m_ddc0_out_0_tlast ;
+ assign s_ep0_in0_tdata = m_ddc0_out_0_tdata;
+ assign s_ep0_in0_tlast = m_ddc0_out_0_tlast;
assign s_ep0_in0_tvalid = m_ddc0_out_0_tvalid;
assign m_ddc0_out_0_tready = s_ep0_in0_tready;
- assign s_ddc0_in_1_tdata = m_radio0_out_1_tdata ;
- assign s_ddc0_in_1_tlast = m_radio0_out_1_tlast ;
+ assign s_ddc0_in_1_tdata = m_radio0_out_1_tdata;
+ assign s_ddc0_in_1_tlast = m_radio0_out_1_tlast;
assign s_ddc0_in_1_tvalid = m_radio0_out_1_tvalid;
assign m_radio0_out_1_tready = s_ddc0_in_1_tready;
- assign s_ep1_in0_tdata = m_ddc0_out_1_tdata ;
- assign s_ep1_in0_tlast = m_ddc0_out_1_tlast ;
+ assign s_ep1_in0_tdata = m_ddc0_out_1_tdata;
+ assign s_ep1_in0_tlast = m_ddc0_out_1_tlast;
assign s_ep1_in0_tvalid = m_ddc0_out_1_tvalid;
assign m_ddc0_out_1_tready = s_ep1_in0_tready;
- assign s_duc1_in_0_tdata = m_ep2_out0_tdata ;
- assign s_duc1_in_0_tlast = m_ep2_out0_tlast ;
+ assign s_duc1_in_0_tdata = m_ep2_out0_tdata;
+ assign s_duc1_in_0_tlast = m_ep2_out0_tlast;
assign s_duc1_in_0_tvalid = m_ep2_out0_tvalid;
assign m_ep2_out0_tready = s_duc1_in_0_tready;
- assign s_radio1_in_0_tdata = m_duc1_out_0_tdata ;
- assign s_radio1_in_0_tlast = m_duc1_out_0_tlast ;
+ assign s_radio1_in_0_tdata = m_duc1_out_0_tdata;
+ assign s_radio1_in_0_tlast = m_duc1_out_0_tlast;
assign s_radio1_in_0_tvalid = m_duc1_out_0_tvalid;
assign m_duc1_out_0_tready = s_radio1_in_0_tready;
- assign s_ddc1_in_0_tdata = m_radio1_out_0_tdata ;
- assign s_ddc1_in_0_tlast = m_radio1_out_0_tlast ;
+ assign s_ddc1_in_0_tdata = m_radio1_out_0_tdata;
+ assign s_ddc1_in_0_tlast = m_radio1_out_0_tlast;
assign s_ddc1_in_0_tvalid = m_radio1_out_0_tvalid;
assign m_radio1_out_0_tready = s_ddc1_in_0_tready;
- assign s_ep2_in0_tdata = m_ddc1_out_0_tdata ;
- assign s_ep2_in0_tlast = m_ddc1_out_0_tlast ;
+ assign s_ep2_in0_tdata = m_ddc1_out_0_tdata;
+ assign s_ep2_in0_tlast = m_ddc1_out_0_tlast;
assign s_ep2_in0_tvalid = m_ddc1_out_0_tvalid;
assign m_ddc1_out_0_tready = s_ep2_in0_tready;
- assign s_ddc1_in_1_tdata = m_radio1_out_1_tdata ;
- assign s_ddc1_in_1_tlast = m_radio1_out_1_tlast ;
+ assign s_ddc1_in_1_tdata = m_radio1_out_1_tdata;
+ assign s_ddc1_in_1_tlast = m_radio1_out_1_tlast;
assign s_ddc1_in_1_tvalid = m_radio1_out_1_tvalid;
assign m_radio1_out_1_tready = s_ddc1_in_1_tready;
- assign s_ep3_in0_tdata = m_ddc1_out_1_tdata ;
- assign s_ep3_in0_tlast = m_ddc1_out_1_tlast ;
+ assign s_ep3_in0_tdata = m_ddc1_out_1_tdata;
+ assign s_ep3_in0_tlast = m_ddc1_out_1_tlast;
assign s_ep3_in0_tvalid = m_ddc1_out_1_tvalid;
assign m_ddc1_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_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_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_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_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;
- // ----------------------------------------------------
+ //---------------------------------------------------------------------------
// Unused Ports
- // ----------------------------------------------------
+ //---------------------------------------------------------------------------
+
assign s_radio0_in_1_tdata = {CHDR_W{1'b0}};
assign s_radio0_in_1_tlast = 1'b0;
assign s_radio0_in_1_tvalid = 1'b0;
@@ -1293,9 +1346,11 @@ module rfnoc_image_core #(
assign m_ep1_out0_tready = 1'b1;
assign m_ep3_out0_tready = 1'b1;
- // ----------------------------------------------------
+
+ //---------------------------------------------------------------------------
// Clock Domains
- // ----------------------------------------------------
+ //---------------------------------------------------------------------------
+
assign radio0_radio_clk = radio_clk;
assign ddc0_ce_clk = ce_clk;
assign duc0_ce_clk = ce_clk;
@@ -1305,9 +1360,10 @@ module rfnoc_image_core #(
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;
@@ -1397,3 +1453,6 @@ module rfnoc_image_core #(
assign radio1_radio_time = radio_time;
endmodule
+
+
+`default_nettype wire
diff --git a/fpga/usrp3/top/x300/x310_rfnoc_image_core.vh b/fpga/usrp3/top/x300/x310_rfnoc_image_core.vh
new file mode 100644
index 000000000..977751101
--- /dev/null
+++ b/fpga/usrp3/top/x300/x310_rfnoc_image_core.vh
@@ -0,0 +1,21 @@
+//
+// Copyright 2021 Ettus Research, A National Instruments Brand
+//
+// SPDX-License-Identifier: LGPL-3.0-or-later
+//
+// Header: rfnoc_image_core.vh (for x300)
+//
+// 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: 2021-05-03T08:51:07.779170
+// Source: x310_rfnoc_image_core.yml
+// Source SHA256: 7a01e3b4aa95b9e5b59f627d5a7d3f27c16afb4bb6bdad1f7fb9a624fb4b9647
+//
+
+`define CHDR_WIDTH 64
+`define RFNOC_PROTOVER { 8'd1, 8'd0 }