aboutsummaryrefslogtreecommitdiffstats
path: root/fpga/usrp3/top/x300/bus_int.v
diff options
context:
space:
mode:
Diffstat (limited to 'fpga/usrp3/top/x300/bus_int.v')
-rw-r--r--fpga/usrp3/top/x300/bus_int.v623
1 files changed, 623 insertions, 0 deletions
diff --git a/fpga/usrp3/top/x300/bus_int.v b/fpga/usrp3/top/x300/bus_int.v
new file mode 100644
index 000000000..17c708f66
--- /dev/null
+++ b/fpga/usrp3/top/x300/bus_int.v
@@ -0,0 +1,623 @@
+//
+// Copyright 2013 Ettus Research LLC
+//
+
+`define LOG2(N) (\
+ N < 2 ? 0 : \
+ N < 4 ? 1 : \
+ N < 8 ? 2 : \
+ N < 16 ? 3 : \
+ N < 32 ? 4 : \
+ N < 64 ? 5 : \
+ N < 128 ? 6 : \
+ N < 256 ? 7 : \
+ N < 512 ? 8 : \
+ N < 1024 ? 9 : \
+ 10)
+
+module bus_int
+ #(
+ parameter dw = 32, // Data bus width
+ parameter aw = 16, // Address bus width, for byte addressibility, 16 = 64K byte memory space
+ parameter sw = 4 // Select width -- 32-bit data bus with 8-bit granularity.
+ )
+ (input clk, input reset,
+ output sen, output sclk, output mosi, input miso,
+ inout scl0, inout sda0,
+ inout scl1, inout sda1,
+ inout scl2, inout sda2,
+ output gps_txd, input gps_rxd,
+ output debug_txd, input debug_rxd,
+ output [7:0] leds,
+ output [3:0] sw_rst,
+ // SFP+ 0
+ input SFPP0_ModAbs,
+ input SFPP0_TxFault, // Current 10G PMA/PCS apparently ignores this signal.
+ input SFPP0_RxLOS,
+ inout SFPP0_RS0,
+ inout SFPP0_RS1,
+ // SFP+ 1
+ input SFPP1_ModAbs,
+ input SFPP1_TxFault, // Current 10G PMA/PCS apparently ignores this signal.
+ input SFPP1_RxLOS,
+ inout SFPP1_RS0,
+ inout SFPP1_RS1,
+ //
+ input [3:0] clock_status,
+ output [5:0] clock_control,
+ // ETH0
+ output [63:0] eth0_tx_tdata, output [3:0] eth0_tx_tuser, output eth0_tx_tlast, output eth0_tx_tvalid, input eth0_tx_tready,
+ input [63:0] eth0_rx_tdata, input [3:0] eth0_rx_tuser, input eth0_rx_tlast, input eth0_rx_tvalid, output eth0_rx_tready,
+ // ETH1
+ output [63:0] eth1_tx_tdata, output [3:0] eth1_tx_tuser, output eth1_tx_tlast, output eth1_tx_tvalid, input eth1_tx_tready,
+ input [63:0] eth1_rx_tdata, input [3:0] eth1_rx_tuser, input eth1_rx_tlast, input eth1_rx_tvalid, output eth1_rx_tready,
+ // Radio0
+ output [63:0] r0o_tdata, output r0o_tlast, output r0o_tvalid, input r0o_tready,
+ input [63:0] r0i_tdata, input r0i_tlast, input r0i_tvalid, output r0i_tready,
+ // Radio1
+ output [63:0] r1o_tdata, output r1o_tlast, output r1o_tvalid, input r1o_tready,
+ input [63:0] r1i_tdata, input r1i_tlast, input r1i_tvalid, output r1i_tready,
+ // CE0
+ output [63:0] ce0o_tdata, output ce0o_tlast, output ce0o_tvalid, input ce0o_tready,
+ input [63:0] ce0i_tdata, input ce0i_tlast, input ce0i_tvalid, output ce0i_tready,
+ // CE1
+ output [63:0] ce1o_tdata, output ce1o_tlast, output ce1o_tvalid, input ce1o_tready,
+ input [63:0] ce1i_tdata, input ce1i_tlast, input ce1i_tvalid, output ce1i_tready,
+ // CE2
+ output [63:0] ce2o_tdata, output ce2o_tlast, output ce2o_tvalid, input ce2o_tready,
+ input [63:0] ce2i_tdata, input ce2i_tlast, input ce2i_tvalid, output ce2i_tready,
+ //iop2 message fifos
+ output [63:0] o_iop2_msg_tdata, output o_iop2_msg_tvalid, output o_iop2_msg_tlast, input o_iop2_msg_tready,
+ input [63:0] i_iop2_msg_tdata, input i_iop2_msg_tvalid, input i_iop2_msg_tlast, output i_iop2_msg_tready,
+ // PCIe
+ output [63:0] pcio_tdata, output pcio_tlast, output pcio_tvalid, input pcio_tready,
+ input [63:0] pcii_tdata, input pcii_tlast, input pcii_tvalid, output pcii_tready,
+ //------------------------------------------------------------------
+ // Wishbone Slave Interface(s)
+ //------------------------------------------------------------------
+ input [dw-1:0] s4_dat_i,
+ output [dw-1:0] s4_dat_o,
+ output [aw-1:0] s4_adr,
+ output [sw-1:0] s4_sel,
+ input s4_ack,
+ output s4_stb,
+ output s4_cyc,
+ output s4_we,
+ input s4_int, // IJB. Nothing to connect this too!! No IRQ controller on x300.
+
+ input [dw-1:0] s5_dat_i,
+ output [dw-1:0] s5_dat_o,
+ output [aw-1:0] s5_adr,
+ output [sw-1:0] s5_sel,
+ input s5_ack,
+ output s5_stb,
+ output s5_cyc,
+ output s5_we,
+ input s5_int, // IJB. Nothing to connect this too!! No IRQ controller on x300.
+
+ // AXI_DRAM_FIFO BIST. Not for production.
+ output bist_start,
+ output [15:0] bist_control,
+ input bist_done,
+ input bist_fail,
+
+
+ // Debug
+ input [3:0] fifo_flags,
+ output [31:0] debug0,
+ output [31:0] debug1,
+ output [127:0] debug2);
+
+ localparam SR_AWIDTH = 8;
+ localparam RB_AWIDTH = 8;
+
+ localparam SR_LEDS = 8'd00;
+ localparam SR_SW_RST = 8'd01;
+ localparam SR_CLOCK_CTRL = 8'd02;
+ localparam SR_XB_LOCAL = 8'd03;
+ localparam SR_SFPP_CTRL0 = 8'd08;
+ localparam SR_SFPP_CTRL1 = 8'd09;
+ localparam SR_FIFOFLAGS = 8'd10;
+ localparam SR_SPI = 8'd32;
+ localparam SR_ETHINT0 = 8'd40;
+ localparam SR_ETHINT1 = 8'd56;
+ // For AXI_DRAM_FIFO debug, not production
+ localparam SR_BIST = 8'd128;
+
+
+ localparam RB_COUNTER = 8'd00;
+ localparam RB_SPI_RDY = 8'd01;
+ localparam RB_SPI_DATA = 8'd02;
+ localparam RB_CLK_STATUS = 8'd03;
+ localparam RB_ETH_TYPE0 = 8'd04;
+ localparam RB_ETH_TYPE1 = 8'd05;
+ localparam RB_COMPAT_NUM = 8'd06;
+
+ localparam RB_SFPP_STATUS0 = 8'd08;
+ localparam RB_SFPP_STATUS1 = 8'd09;
+ localparam RB_FIFOFLAGS = 8'd10;
+ localparam RB_CROSSBAR = 8'd64; // Block of 64 addresses start here.
+ // For AXI_DRAM_FIFO debug, not production
+ localparam RB_BIST = 8'd128;
+
+
+ localparam COMPAT_MAJOR = 16'h0003;
+ localparam COMPAT_MINOR = 16'h0000;
+
+ wire [31:0] set_data;
+ wire [7:0] set_addr;
+ reg [31:0] rb_data;
+ wire [RB_AWIDTH-1:0] rb_addr;
+ wire rb_rd_stb;
+ wire set_stb;
+ wire spi_ready;
+ wire [31:0] rb_spi_data;
+ wire [17:0] eth_debug_flags;
+
+
+ // ZPU in and ZPU out axi streams
+ wire [63:0] zpui_tdata, zpuo_tdata;
+ wire [3:0] zpui_tuser, zpuo_tuser;
+ wire zpui_tlast, zpuo_tlast, zpui_tvalid, zpuo_tvalid, zpui_tready, zpuo_tready;
+ wire [63:0] zpui0_tdata, zpuo0_tdata;
+ wire [3:0] zpui0_tuser, zpuo0_tuser;
+ wire zpui0_tlast, zpuo0_tlast, zpui0_tvalid, zpuo0_tvalid, zpui0_tready, zpuo0_tready;
+ wire [63:0] zpui1_tdata, zpuo1_tdata;
+ wire [3:0] zpui1_tuser, zpuo1_tuser;
+ wire zpui1_tlast, zpuo1_tlast, zpui1_tvalid, zpuo1_tvalid, zpui1_tready, zpuo1_tready;
+
+ // v2e (vita to ethernet) and e2v (eth to vita)
+ wire [63:0] v2e0_tdata, v2e1_tdata, e2v0_tdata, e2v1_tdata;
+ wire v2e0_tlast, v2e1_tlast, v2e0_tvalid, v2e1_tvalid, v2e0_tready, v2e1_tready;
+ wire e2v0_tlast, e2v1_tlast, e2v0_tvalid, e2v1_tvalid, e2v0_tready, e2v1_tready;
+
+ //settings bus for crossbar router
+ wire [31:0] set_data_xb;
+ wire [8:0] set_addr_xb;
+ wire set_stb_xb;
+
+ // SFP+ logic
+ reg SFPP0_ModAbs_reg, SFPP0_TxFault_reg,SFPP0_RxLOS_reg;
+ reg SFPP0_ModAbs_reg2, SFPP0_TxFault_reg2,SFPP0_RxLOS_reg2;
+ reg SFPP0_ModAbs_chgd, SFPP0_TxFault_chgd, SFPP0_RxLOS_chgd;
+
+ reg SFPP1_ModAbs_reg, SFPP1_TxFault_reg,SFPP1_RxLOS_reg;
+ reg SFPP1_ModAbs_reg2, SFPP1_TxFault_reg2,SFPP1_RxLOS_reg2;
+ reg SFPP1_ModAbs_chgd, SFPP1_TxFault_chgd, SFPP1_RxLOS_chgd;
+
+
+ ////////////////////////////////////////////////////////////////////
+ // Soft CPU - drives network setup, soft reset, ICMP, ...
+ ////////////////////////////////////////////////////////////////////
+ soft_ctrl #(.SB_ADDRW(SR_AWIDTH), .RB_ADDRW(RB_AWIDTH)) sc
+ (
+ .clk(clk), .rst(reset),
+ //------------------------------------------------------------------
+ // I2C interfaces
+ //------------------------------------------------------------------
+ .scl0(scl0), .sda0(sda0),
+ .scl1(scl1), .sda1(sda1),
+ .scl2(scl2), .sda2(sda2),
+ //------------------------------------------------------------------
+ // UARTs for CPU comms
+ //------------------------------------------------------------------
+ .gps_rxd(gps_rxd), .gps_txd(gps_txd),
+ .debug_rxd(debug_rxd), .debug_txd(debug_txd),
+ //------------------------------------------------------------------
+ // settings bus interface
+ //------------------------------------------------------------------
+ .set_stb(set_stb),
+ .set_addr(set_addr),
+ .set_data(set_data),
+ //------------------------------------------------------------------
+ // settings bus interface for crossbar router
+ //------------------------------------------------------------------
+ .set_stb_xb(set_stb_xb),
+ .set_addr_xb(set_addr_xb),
+ .set_data_xb(set_data_xb),
+ //------------------------------------------------------------------
+ // readback bus interface
+ //------------------------------------------------------------------
+ .rb_addr(rb_addr),
+ .rb_data(rb_data),
+ .rb_rd_stb(rb_rd_stb),
+ //------------------------------------------------------------------
+ // packet interface in
+ //------------------------------------------------------------------
+ .rx_tdata(zpui_tdata),
+ .rx_tuser(zpui_tuser),
+ .rx_tlast(zpui_tlast),
+ .rx_tvalid(zpui_tvalid),
+ .rx_tready(zpui_tready),
+ //------------------------------------------------------------------
+ // packet interface out
+ //------------------------------------------------------------------
+ .tx_tdata(zpuo_tdata),
+ .tx_tuser(zpuo_tuser),
+ .tx_tlast(zpuo_tlast),
+ .tx_tvalid(zpuo_tvalid),
+ .tx_tready(zpuo_tready),
+ //------------------------------------------------------------------
+ // Wishbone Slave Interface(s)
+ //------------------------------------------------------------------
+ .s4_dat_i(s4_dat_i),
+ .s4_dat_o(s4_dat_o),
+ .s4_adr(s4_adr),
+ .s4_sel(s4_sel),
+ .s4_ack(s4_ack),
+ .s4_stb(s4_stb),
+ .s4_cyc(s4_cyc),
+ .s4_we(s4_we),
+ .s4_int(s4_int),
+ //------------------------------------------------------------------
+ // IoPort2 Msg Interface
+ //------------------------------------------------------------------
+ .o_iop2_msg_tdata(o_iop2_msg_tdata),
+ .o_iop2_msg_tvalid(o_iop2_msg_tvalid),
+ .o_iop2_msg_tlast(o_iop2_msg_tlast),
+ .o_iop2_msg_tready(o_iop2_msg_tready),
+ .i_iop2_msg_tdata(i_iop2_msg_tdata),
+ .i_iop2_msg_tvalid(i_iop2_msg_tvalid),
+ .i_iop2_msg_tlast(i_iop2_msg_tlast),
+ .i_iop2_msg_tready(i_iop2_msg_tready),
+
+ .s5_dat_i(s5_dat_i),
+ .s5_dat_o(s5_dat_o),
+ .s5_adr(s5_adr),
+ .s5_sel(s5_sel),
+ .s5_ack(s5_ack),
+ .s5_stb(s5_stb),
+ .s5_cyc(s5_cyc),
+ .s5_we(s5_we),
+ .s5_int(s5_int),
+
+ //------------------------------------------------------------------
+ // Debug
+ //------------------------------------------------------------------
+ .debug0(debug2),
+ .debug1()
+ );
+
+ setting_reg #(.my_addr(SR_LEDS), .awidth(SR_AWIDTH), .width(8)) set_leds
+ (.clk(clk), .rst(reset),
+ .strobe(set_stb), .addr(set_addr), .in(set_data),
+ .out(leds));
+
+ //
+ // SW_RST - Bit allocation:
+ // [0] - PHY reset
+ // [1] - Radio clk domain reset
+ // [2] - Radio Clk PLL reset.
+ // [3] - Usused.
+ //
+ setting_reg #(.my_addr(SR_SW_RST), .awidth(SR_AWIDTH), .width(4)) set_sw_rst
+ (.clk(clk), .rst(reset),
+ .strobe(set_stb), .addr(set_addr), .in(set_data),
+ .out(sw_rst));
+
+ setting_reg #(.my_addr(SR_CLOCK_CTRL), .awidth(SR_AWIDTH), .width(6),
+ .at_reset(6'b100000) //bit 5 high means GPSDO on by default
+ ) set_clk_ctrl
+ (.clk(clk), .rst(reset),
+ .strobe(set_stb), .addr(set_addr), .in(set_data),
+ .out(clock_control));
+
+ simple_spi_core #(.BASE(SR_SPI), .WIDTH(1), .CLK_IDLE(0), .SEN_IDLE(1'b1)) misc_spi
+ (.clock(clk), .reset(reset),
+ .set_stb(set_stb), .set_addr(set_addr), .set_data(set_data),
+ .readback(rb_spi_data), .ready(spi_ready),
+ .sen(sen), .sclk(sclk), .mosi(mosi), .miso(miso),
+ .debug());
+
+ //
+ // Provide instrumentation so that abnormal FIFO conditions can be identifed.
+ //
+ wire clear_debug_flags;
+ reg [31:0] debug_flags;
+
+ setting_reg #(.my_addr(SR_FIFOFLAGS), .awidth(16), .width(1)) sr_reset_fifo_debug
+ (.clk(clk),.rst(reset),.strobe(set_stb),.addr(set_addr),
+ .in(set_data),.out(),.changed(clear_debug_flags));
+
+ always @(posedge clk)
+ if (reset)
+ debug_flags <= 0;
+ else if (clear_debug_flags)
+ debug_flags <= 0;
+ else
+ debug_flags <= debug_flags | {
+ 10'h0,
+ ~fifo_flags[3:0],
+ eth_debug_flags};
+
+ reg [31:0] counter;
+ wire [31:0] rb_data_crossbar;
+
+ always @(posedge clk) counter <= counter + 1;
+
+ always @*
+ casex (rb_addr)
+ RB_COMPAT_NUM: rb_data = {COMPAT_MAJOR, COMPAT_MINOR};
+ RB_COUNTER: rb_data = counter;
+ RB_SPI_RDY: rb_data = {31'b0, spi_ready};
+ RB_SPI_DATA: rb_data = rb_spi_data;
+ RB_CLK_STATUS: rb_data = {28'b0, clock_status};
+ // SFPP Interface pins.
+ RB_SFPP_STATUS0: rb_data = {26'b0,SFPP0_ModAbs_chgd,SFPP0_TxFault_chgd,SFPP0_RxLOS_chgd,
+ SFPP0_ModAbs_reg2,SFPP0_TxFault_reg2,SFPP0_RxLOS_reg2};
+ RB_SFPP_STATUS1: rb_data = {26'b0,SFPP1_ModAbs_chgd,SFPP1_TxFault_chgd,SFPP1_RxLOS_chgd,
+ SFPP1_ModAbs_reg2,SFPP1_TxFault_reg2,SFPP1_RxLOS_reg2};
+ // Allow readback of configured ethernet interfaces.
+`ifdef ETH10G_PORT0
+ RB_ETH_TYPE0: rb_data = {32'h1};
+`else
+ RB_ETH_TYPE0: rb_data = {32'h0};
+`endif
+`ifdef ETH10G_PORT1
+ RB_ETH_TYPE1: rb_data = {32'h1};
+`else
+ RB_ETH_TYPE1: rb_data = {32'h0};
+`endif
+ // Read FIFO status from Ethernet Interfaces
+ RB_FIFOFLAGS: rb_data = debug_flags;
+
+ (RB_CROSSBAR | 6'bxxxxxx): rb_data = rb_data_crossbar;
+ // AXI_DRAM_FIFO BIST. Not for production.
+ RB_BIST: rb_data = {29'h0,bist_done,bist_fail,bist_start};
+
+
+ default: rb_data = 32'h0;
+ endcase // case (rb_addr)
+
+ // AXI_DRAM_FIFO BIST. Not for production.
+ setting_reg #(.my_addr(SR_BIST), .awidth(SR_AWIDTH), .width(17)) set_bist_start
+ (.clk(clk), .rst(reset),
+ .strobe(set_stb), .addr(set_addr), .in(set_data),
+ .out({bist_start,bist_control}));
+
+ // Latch state changes to SFP+ pins.
+ always @(posedge clk)
+ begin
+ SFPP0_ModAbs_reg <= SFPP0_ModAbs;
+ SFPP0_TxFault_reg <= SFPP0_TxFault;
+ SFPP0_RxLOS_reg <= SFPP0_RxLOS;
+ SFPP0_ModAbs_reg2 <= SFPP0_ModAbs_reg;
+ SFPP0_TxFault_reg2 <= SFPP0_TxFault_reg;
+ SFPP0_RxLOS_reg2 <= SFPP0_RxLOS_reg;
+ if (rb_rd_stb && (rb_addr == RB_SFPP_STATUS0) ) begin
+ SFPP0_ModAbs_chgd <= 1'b0;
+ SFPP0_TxFault_chgd <= 1'b0;
+ SFPP0_RxLOS_chgd <= 1'b0;
+ end else begin
+ if (SFPP0_ModAbs_reg2 != SFPP0_ModAbs_reg)
+ SFPP0_ModAbs_chgd <= 1'b1;
+ if (SFPP0_TxFault_reg2 != SFPP0_TxFault_reg)
+ SFPP0_TxFault_chgd <= 1'b1;
+ if (SFPP0_RxLOS_reg2 != SFPP0_RxLOS_reg)
+ SFPP0_RxLOS_chgd <= 1'b1;
+ end // else: !if(rb_rd_stb && (rb_addr == RB_SFPP_STATUS0) )
+ end
+
+ always @(posedge clk)
+ begin
+ SFPP1_ModAbs_reg <= SFPP1_ModAbs;
+ SFPP1_TxFault_reg <= SFPP1_TxFault;
+ SFPP1_RxLOS_reg <= SFPP1_RxLOS;
+ SFPP1_ModAbs_reg2 <= SFPP1_ModAbs_reg;
+ SFPP1_TxFault_reg2 <= SFPP1_TxFault_reg;
+ SFPP1_RxLOS_reg2 <= SFPP1_RxLOS_reg;
+ if (rb_rd_stb && (rb_addr == RB_SFPP_STATUS1) ) begin
+ SFPP1_ModAbs_chgd <= 1'b0;
+ SFPP1_TxFault_chgd <= 1'b0;
+ SFPP1_RxLOS_chgd <= 1'b0;
+ end else begin
+ if (SFPP1_ModAbs_reg2 != SFPP1_ModAbs_reg)
+ SFPP1_ModAbs_chgd <= 1'b1;
+ if (SFPP1_TxFault_reg2 != SFPP1_TxFault_reg)
+ SFPP1_TxFault_chgd <= 1'b1;
+ if (SFPP1_RxLOS_reg2 != SFPP1_RxLOS_reg)
+ SFPP1_RxLOS_chgd <= 1'b1;
+ end // else: !if(rb_rd_stb && (rb_addr == RB_SFPP_STATUS1) )
+ end
+
+ wire [1:0] sfpp0_ctrl;
+
+ // SFPP_RS0/1 pins are open drain.
+ setting_reg #(.my_addr(SR_SFPP_CTRL0), .awidth(SR_AWIDTH), .width(2), .at_reset(2'b00)) set_sfpp0_ctrl
+ (.clk(clk), .rst(reset),
+ .strobe(set_stb), .addr(set_addr), .in(set_data),
+ .out(sfpp0_ctrl));
+
+ assign SFPP0_RS0 = sfpp0_ctrl[0] ? 1'b0 : 1'bz;
+ assign SFPP0_RS1 = sfpp0_ctrl[1] ? 1'b0 : 1'bz;
+
+ wire [1:0] sfpp1_ctrl;
+
+ // SFPP1_RS0/1 pins are open drain.
+ setting_reg #(.my_addr(SR_SFPP_CTRL1), .awidth(SR_AWIDTH), .width(2), .at_reset(2'b00)) set_sfpp1_ctrl
+ (.clk(clk), .rst(reset),
+ .strobe(set_stb), .addr(set_addr), .in(set_data),
+ .out(sfpp1_ctrl));
+
+ assign SFPP1_RS0 = sfpp1_ctrl[0] ? 1'b0 : 1'bz;
+ assign SFPP1_RS1 = sfpp1_ctrl[1] ? 1'b0 : 1'bz;
+
+
+ //assign debug = { 9'b0, set_stb, spi_ready, i2c_ready, sen, sclk, mosi, miso, set_addr[7:0], state[7:0]};
+
+ // ////////////////////////////////////////////////////////////////
+ // ETH interfaces
+
+ wire [63:0] e01_tdata, e10_tdata;
+ wire [3:0] e01_tuser, e10_tuser;
+ wire e01_tlast, e01_tvalid, e01_tready;
+ wire e10_tlast, e10_tvalid, e10_tready;
+
+ eth_interface #(.BASE(SR_ETHINT0)) eth_interface0
+ (.clk(clk), .reset(reset), .clear(clear),
+ .set_stb(set_stb), .set_addr(set_addr), .set_data(set_data),
+ .eth_tx_tdata(eth0_tx_tdata), .eth_tx_tuser(eth0_tx_tuser), .eth_tx_tlast(eth0_tx_tlast),
+ .eth_tx_tvalid(eth0_tx_tvalid), .eth_tx_tready(eth0_tx_tready),
+ .eth_rx_tdata(eth0_rx_tdata), .eth_rx_tuser(eth0_rx_tuser), .eth_rx_tlast(eth0_rx_tlast),
+ .eth_rx_tvalid(eth0_rx_tvalid), .eth_rx_tready(eth0_rx_tready),
+ .e2v_tdata(e2v0_tdata), .e2v_tlast(e2v0_tlast), .e2v_tvalid(e2v0_tvalid), .e2v_tready(e2v0_tready),
+ .v2e_tdata(v2e0_tdata), .v2e_tlast(v2e0_tlast), .v2e_tvalid(v2e0_tvalid), .v2e_tready(v2e0_tready),
+ .xo_tdata(e01_tdata), .xo_tuser(e01_tuser), .xo_tlast(e01_tlast), .xo_tvalid(e01_tvalid), .xo_tready(e01_tready),
+ .xi_tdata(e10_tdata), .xi_tuser(e10_tuser), .xi_tlast(e10_tlast), .xi_tvalid(e10_tvalid), .xi_tready(e10_tready),
+ .e2z_tdata(zpui0_tdata), .e2z_tuser(zpui0_tuser), .e2z_tlast(zpui0_tlast), .e2z_tvalid(zpui0_tvalid), .e2z_tready(zpui0_tready),
+ .z2e_tdata(zpuo0_tdata), .z2e_tuser(zpuo0_tuser), .z2e_tlast(zpuo0_tlast), .z2e_tvalid(zpuo0_tvalid), .z2e_tready(zpuo0_tready),
+ .debug_flags(eth_debug_flags[8:0]),.debug(/*debug2*/));
+
+ eth_interface #(.BASE(SR_ETHINT1)) eth_interface1
+ (.clk(clk), .reset(reset), .clear(clear),
+ .set_stb(set_stb), .set_addr(set_addr), .set_data(set_data),
+ .eth_tx_tdata(eth1_tx_tdata), .eth_tx_tuser(eth1_tx_tuser), .eth_tx_tlast(eth1_tx_tlast),
+ .eth_tx_tvalid(eth1_tx_tvalid), .eth_tx_tready(eth1_tx_tready),
+ .eth_rx_tdata(eth1_rx_tdata), .eth_rx_tuser(eth1_rx_tuser), .eth_rx_tlast(eth1_rx_tlast),
+ .eth_rx_tvalid(eth1_rx_tvalid), .eth_rx_tready(eth1_rx_tready),
+ .e2v_tdata(e2v1_tdata), .e2v_tlast(e2v1_tlast), .e2v_tvalid(e2v1_tvalid), .e2v_tready(e2v1_tready),
+ .v2e_tdata(v2e1_tdata), .v2e_tlast(v2e1_tlast), .v2e_tvalid(v2e1_tvalid), .v2e_tready(v2e1_tready),
+ .xo_tdata(e10_tdata), .xo_tuser(e10_tuser), .xo_tlast(e10_tlast), .xo_tvalid(e10_tvalid), .xo_tready(e10_tready),
+ .xi_tdata(e01_tdata), .xi_tuser(e01_tuser), .xi_tlast(e01_tlast), .xi_tvalid(e01_tvalid), .xi_tready(e01_tready),
+ .e2z_tdata(zpui1_tdata), .e2z_tuser(zpui1_tuser), .e2z_tlast(zpui1_tlast), .e2z_tvalid(zpui1_tvalid), .e2z_tready(zpui1_tready),
+ .z2e_tdata(zpuo1_tdata), .z2e_tuser(zpuo1_tuser), .z2e_tlast(zpuo1_tlast), .z2e_tvalid(zpuo1_tvalid), .z2e_tready(zpuo1_tready),
+ .debug_flags(eth_debug_flags[17:9]),.debug());
+
+ axi_mux4 #(.PRIO(0), .WIDTH(68)) zpui_mux
+ (.clk(clk), .reset(reset), .clear(clear),
+ .i0_tdata({zpui0_tuser,zpui0_tdata}), .i0_tlast(zpui0_tlast), .i0_tvalid(zpui0_tvalid), .i0_tready(zpui0_tready),
+ .i1_tdata({zpui1_tuser,zpui1_tdata}), .i1_tlast(zpui1_tlast), .i1_tvalid(zpui1_tvalid), .i1_tready(zpui1_tready),
+ .i2_tdata(68'h0), .i2_tlast(1'b0), .i2_tvalid(1'b0), .i2_tready(),
+ .i3_tdata(68'h0), .i3_tlast(1'b0), .i3_tvalid(1'b0), .i3_tready(),
+ .o_tdata({zpui_tuser,zpui_tdata}), .o_tlast(zpui_tlast), .o_tvalid(zpui_tvalid), .o_tready(zpui_tready));
+
+ // Demux ZPU to Eth output by the port number in top 8 bits of data on first line
+ wire [67:0] zpuo_eth_header;
+ wire [1:0] zpuo_eth_dest = (zpuo_eth_header[63:56] == 8'd0) ? 2'b00 : 2'b01;
+
+ axi_demux4 #(.ACTIVE_CHAN(4'b0011), .WIDTH(68)) zpuo_demux
+ (.clk(clk), .reset(reset), .clear(clear),
+ .header(zpuo_eth_header), .dest(zpuo_eth_dest),
+ .i_tdata({zpuo_tuser,zpuo_tdata}), .i_tlast(zpuo_tlast), .i_tvalid(zpuo_tvalid), .i_tready(zpuo_tready),
+ .o0_tdata({zpuo0_tuser,zpuo0_tdata}), .o0_tlast(zpuo0_tlast), .o0_tvalid(zpuo0_tvalid), .o0_tready(zpuo0_tready),
+ .o1_tdata({zpuo1_tuser,zpuo1_tdata}), .o1_tlast(zpuo1_tlast), .o1_tvalid(zpuo1_tvalid), .o1_tready(zpuo1_tready),
+ .o2_tdata(), .o2_tlast(), .o2_tvalid(), .o2_tready(1'b1),
+ .o3_tdata(), .o3_tlast(), .o3_tvalid(), .o3_tready(1'b1));
+
+ // //////////////////////////////////////////////////////////////////////
+ // axi_crossbar ports
+ // 0 - ETH0
+ // 1 - ETH1
+ // 2 - Radio0
+ // 3 - Radio1
+ // 4 - CE0
+ // 5 - CE1
+ // 6 - CE2
+ // 7 - PCIe
+
+ wire [7:0] local_addr;
+
+ setting_reg #(.my_addr(SR_XB_LOCAL), .awidth(SR_AWIDTH), .width(8)) sr_local_addr
+ (.clk(clk),.rst(reset),.strobe(set_stb),.addr(set_addr),
+ .in(set_data),.out(local_addr),.changed());
+
+
+ localparam CROSSBAR_IN = 8;
+ localparam CROSSBAR_OUT = 8;
+
+ axi_crossbar #(.FIFO_WIDTH(64), .DST_WIDTH(16), .NUM_INPUTS(CROSSBAR_IN), .NUM_OUTPUTS(CROSSBAR_OUT)) axi_crossbar
+ (.clk(clk), .reset(reset), .clear(0),
+ .local_addr(local_addr),
+ .set_stb(set_stb_xb), .set_addr(set_addr_xb), .set_data(set_data_xb),
+ .i_tdata({pcii_tdata,ce2i_tdata,ce1i_tdata,ce0i_tdata,r1i_tdata,r0i_tdata,e2v1_tdata,e2v0_tdata}),
+ .i_tlast({pcii_tlast,ce2i_tlast,ce1i_tlast,ce0i_tlast,r1i_tlast,r0i_tlast,e2v1_tlast,e2v0_tlast}),
+ .i_tvalid({pcii_tvalid,ce2i_tvalid,ce1i_tvalid,ce0i_tvalid,r1i_tvalid,r0i_tvalid,e2v1_tvalid,e2v0_tvalid}),
+ .i_tready({pcii_tready,ce2i_tready,ce1i_tready,ce0i_tready,r1i_tready,r0i_tready,e2v1_tready,e2v0_tready}),
+ .o_tdata({pcio_tdata,ce2o_tdata,ce1o_tdata,ce0o_tdata,r1o_tdata,r0o_tdata,v2e1_tdata,v2e0_tdata}),
+ .o_tlast({pcio_tlast,ce2o_tlast,ce1o_tlast,ce0o_tlast,r1o_tlast,r0o_tlast,v2e1_tlast,v2e0_tlast}),
+ .o_tvalid({pcio_tvalid,ce2o_tvalid,ce1o_tvalid,ce0o_tvalid,r1o_tvalid,r0o_tvalid,v2e1_tvalid,v2e0_tvalid}),
+ .o_tready({pcio_tready,ce2o_tready,ce1o_tready,ce0o_tready,r1o_tready,r0o_tready,v2e1_tready,v2e0_tready}),
+ .pkt_present({pcii_tvalid,ce2i_tvalid,ce1i_tvalid,ce0i_tvalid,r1i_tvalid,r0i_tvalid,e2v1_tvalid,e2v0_tvalid}),
+ .rb_rd_stb(rb_rd_stb && ((rb_addr >> (`LOG2(NUM_OUTPUTS)+`LOG2(NUM_INPUTS))) == RB_CROSSBAR >> (`LOG2(NUM_OUTPUTS)+`LOG2(NUM_INPUTS)))),
+ .rb_addr(rb_addr[`LOG2(CROSSBAR_IN)+`LOG2(CROSSBAR_OUT)-1:0]), .rb_data(rb_data_crossbar)
+ );
+
+/*
+assign debug2 = {
+ pcii_tdata[31:0], //[127:92]
+ pcio_tdata[31:0], //[91:64]
+ local_addr[5:0], //[63:58]
+ set_stb_xb, //[57]
+ set_addr_xb, //[56:48]
+ pcii_tvalid,ce2i_tvalid,ce1i_tvalid,ce0i_tvalid,r1i_tvalid,r0i_tvalid,e2v1_tvalid,e2v0_tvalid, //[47:40]
+ pcii_tready,ce2i_tready,ce1i_tready,ce0i_tready,r1i_tready,r0i_tready,e2v1_tready,e2v0_tready, //[39:32]
+ pcii_tlast,ce2i_tlast,ce1i_tlast,ce0i_tlast,r1i_tlast,r0i_tlast,e2v1_tlast,e2v0_tlast, //[31:24]
+ pcio_tvalid,ce2o_tvalid,ce1o_tvalid,ce0o_tvalid,r1o_tvalid,r0o_tvalid,v2e1_tvalid,v2e0_tvalid, //[23:16]
+ pcio_tready,ce2o_tready,ce1o_tready,ce0o_tready,r1o_tready,r0o_tready,v2e1_tready,v2e0_tready, //[15:8]
+ pcio_tlast,ce2o_tlast,ce1o_tlast,ce0o_tlast,r1o_tlast,r0o_tlast,v2e1_tlast,v2e0_tlast //[7:0]
+ };
+*/
+ //
+ // This next section adds the ability to send messages and data via chipscope and the setting bus.
+ // If chipscope is used elsewhere in the hierarchy then this must be commented.
+ //
+/* -----\/----- EXCLUDED -----\/-----
+ wire [35:0] CONTROL0;
+ (* keep = "true", max_fanout = 10 *) reg [31:0] set_data_debug;
+ (* keep = "true", max_fanout = 10 *) reg [7:0] set_addr_debug;
+ (* keep = "true", max_fanout = 10 *) reg set_stb_debug;
+
+ always @(posedge clk) begin
+ set_data_debug = set_data;
+ set_addr_debug = set_addr;
+ set_stb_debug = set_stb;
+ end
+
+ chipscope_icon chipscope_icon_i0
+ (
+ .CONTROL0(CONTROL0) // INOUT BUS [35:0]
+ );
+
+ chipscope_ila_64 chipscope_ila_i0
+ (
+ .CONTROL(CONTROL0), // INOUT BUS [35:0]
+ .CLK(clk), // IN
+ .TRIG0(
+ {
+ set_stb_debug, // [40]
+ set_addr_debug[7:0], // [39:32]
+ set_data_debug[31:0] // [31:0]
+ })
+ );
+ -----/\----- EXCLUDED -----/\----- */
+
+
+ // Fixed connections
+/* -----\/----- EXCLUDED -----\/-----
+ assign { r0o_tvalid, r0o_tlast, r0o_tdata } = { e2v0_tvalid, e2v0_tlast, e2v0_tdata };
+ assign e2v0_tready = r0o_tready;
+
+ assign { v2e0_tvalid, v2e0_tlast, v2e0_tdata } = { r0i_tvalid, r0i_tlast, r0i_tdata };
+ assign r0i_tready = v2e0_tready;
+ -----/\----- EXCLUDED -----/\----- */
+
+/*
+ assign debug2 = {
+ eth0_tx_tvalid, eth0_tx_tready,
+ eth0_rx_tvalid, eth0_rx_tready,
+ e2v0_tvalid, e2v0_tready,
+ v2e0_tvalid, v2e0_tready,
+
+ e01_tvalid, e01_tready,
+ e10_tvalid, e10_tready,
+ zpui0_tvalid, zpui0_tready,
+ zpuo0_tvalid, zpuo0_tready,
+
+ zpuo_tvalid, zpuo_tready,
+ zpui_tvalid, zpui_tready,
+ 4'b0,
+
+ 8'b0
+ };
+*/
+endmodule // bus_int