// // 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