diff options
Diffstat (limited to 'fpga/usrp3/lib/gpif2')
-rw-r--r-- | fpga/usrp3/lib/gpif2/fifo64_to_gpif2.v | 14 | ||||
-rw-r--r-- | fpga/usrp3/lib/gpif2/gpif2_slave_fifo32.v | 127 | ||||
-rw-r--r-- | fpga/usrp3/lib/gpif2/gpif2_to_fifo64.v | 228 |
3 files changed, 180 insertions, 189 deletions
diff --git a/fpga/usrp3/lib/gpif2/fifo64_to_gpif2.v b/fpga/usrp3/lib/gpif2/fifo64_to_gpif2.v index cf3a221b7..1e4a429a3 100644 --- a/fpga/usrp3/lib/gpif2/fifo64_to_gpif2.v +++ b/fpga/usrp3/lib/gpif2/fifo64_to_gpif2.v @@ -1,7 +1,19 @@ // // Copyright 2012-2013 Ettus Research LLC // - +// This program is free software: you can redistribute it and/or modify +// it under the terms of the GNU General Public License as published by +// the Free Software Foundation, either version 3 of the License, or +// (at your option) any later version. +// +// This program is distributed in the hope that it will be useful, +// but WITHOUT ANY WARRANTY; without even the implied warranty of +// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the +// GNU General Public License for more details. +// +// You should have received a copy of the GNU General Public License +// along with this program. If not, see <http://www.gnu.org/licenses/>. +// module fifo64_to_gpif2 #( diff --git a/fpga/usrp3/lib/gpif2/gpif2_slave_fifo32.v b/fpga/usrp3/lib/gpif2/gpif2_slave_fifo32.v index f332a6ab3..93aa6041f 100644 --- a/fpga/usrp3/lib/gpif2/gpif2_slave_fifo32.v +++ b/fpga/usrp3/lib/gpif2/gpif2_slave_fifo32.v @@ -1,7 +1,19 @@ // // Copyright 2011-2013 Ettus Research LLC // - +// This program is free software: you can redistribute it and/or modify +// it under the terms of the GNU General Public License as published by +// the Free Software Foundation, either version 3 of the License, or +// (at your option) any later version. +// +// This program is distributed in the hope that it will be useful, +// but WITHOUT ANY WARRANTY; without even the implied warranty of +// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the +// GNU General Public License for more details. +// +// You should have received a copy of the GNU General Public License +// along with this program. If not, see <http://www.gnu.org/licenses/>. +// ////////////////////////////////////////////////////////////////////////////////// @@ -23,8 +35,11 @@ module gpif2_slave_fifo32 parameter END_WITH_COMMA = 0 ) - (// GPIF signals - input gpif_clk, input gpif_rst, input gpif_enb, + ( + // GPIF signals + input gpif_clk, + input gpif_rst, + input gpif_enb, inout [31:0] gpif_d, input [3:0] gpif_ctl, output reg sloe, @@ -33,15 +48,18 @@ module gpif2_slave_fifo32 output slcs, output reg pktend, output reg [1:0] fifoadr, - // FIFO interfaces - input fifo_clk, input fifo_rst, - + input fifo_clk, + input fifo_rst, + // TX Data interface to DSP output [63:0] tx_tdata, output tx_tlast, output tx_tvalid, input tx_tready, + // RX Data interface to DSP input [63:0] rx_tdata, input rx_tlast, input rx_tvalid, output rx_tready, + // Incomming control interface output [63:0] ctrl_tdata, output ctrl_tlast, output ctrl_tvalid, input ctrl_tready, + // Outgoing control interface input [63:0] resp_tdata, input resp_tlast, input resp_tvalid, output resp_tready, - + // Debug Signals output [31:0] debug ); @@ -49,8 +67,6 @@ module gpif2_slave_fifo32 wire ctrl_tx_fifo_nearly_full, data_tx_fifo_nearly_full; wire ctrl_tx_fifo_has_space, data_tx_fifo_has_space; - - wire [159:0] debug_tx_data, debug_tx_ctrl; assign slcs = 1'b0; @@ -137,14 +153,19 @@ module gpif2_slave_fifo32 end // - // now wait here for 8 clock cycles before transitioning to STATE_THINK. - // We stay in this state if no local FIFO's can proceed at this point. + // If the current thread we are pointing at (fifoadr) can not immediately proceed + // then quickly move to the next thread. Once we are pointing at a thread that can proceed locally + // wait for 8 clock cycles to allow fifoadr to propogate to FX3, and corresponding flag state to + // propogate back to FPGA and through resampling flops. At this point transition to STATE_THINK + // to evaluate remote flag. // STATE_WAIT: begin + // Current thread can proceed locally if (local_fifo_ready) begin idle_cycles <= idle_cycles + 1'b1; if (idle_cycles == 3'b111) state <= STATE_THINK; end + // ....move onto next thread. else begin idle_cycles <= 3'b0; fifoadr <= fifoadr + 2'b1; @@ -154,10 +175,10 @@ module gpif2_slave_fifo32 // // If there is a read to start, assert SLRD and SLOE and transition to STATE_READ. // If there is a write to perform, set flags that says there is the possibility to do at least - // one write (wr_one) and transition to STATE_WRITE + // one write (wr_one) and transition to STATE_WRITE. + // If the FX3 has nothing ready for this thread return immediately to STATE_IDLE. // STATE_THINK: begin - if (EP_READY1 && read_ready_go) begin state <= STATE_READ; slrd <= 0; @@ -215,13 +236,17 @@ module gpif2_slave_fifo32 //Priority encoding for the the next address to service: //The next address to service is based on the readiness //of the internal fifos and last serviced fairness metric. +/* -----\/----- EXCLUDED -----\/----- always @(posedge gpif_clk) next_addr <= - ((ctrl_rx_tvalid && last_addr != ADDR_CTRL_RX)? ADDR_CTRL_RX : - ((ctrl_tx_fifo_has_space && last_addr != ADDR_CTRL_TX)? ADDR_CTRL_TX : - ((data_rx_tvalid && last_addr != ADDR_DATA_RX)? ADDR_DATA_RX : - ((data_tx_fifo_has_space && last_addr != ADDR_DATA_TX)? ADDR_DATA_TX : + ((ctrl_rx_tvalid && (last_addr != ADDR_CTRL_RX))? ADDR_CTRL_RX : + ((ctrl_tx_fifo_has_space && (last_addr != ADDR_CTRL_TX))? ADDR_CTRL_TX : + ((data_rx_tvalid && (last_addr != ADDR_DATA_RX))? ADDR_DATA_RX : + ((data_tx_fifo_has_space && (last_addr != ADDR_DATA_TX))? ADDR_DATA_TX : (fifoadr + 2'b1) )))); + -----/\----- EXCLUDED -----/\----- */ + always @(posedge gpif_clk) next_addr <= (fifoadr + 2'b1); + //Help the FPGA search to only look for addrs that the FPGA is ready for assign local_fifo_ready = @@ -268,7 +293,7 @@ module gpif2_slave_fifo32 .fifo_clk(fifo_clk), .fifo_rst(fifo_rst), .fifo_nearly_full(data_tx_fifo_nearly_full), .fifo_has_space(data_tx_fifo_has_space), .o_tdata(tx_tdata), .o_tlast(tx_tlast), .o_tvalid(tx_tvalid), .o_tready(tx_tready), - .bus_error(tx_bus_error), .debug(debug_tx_data) + .bus_error(tx_bus_error), .debug() ); // //////////////////////////////////////////// @@ -290,7 +315,7 @@ module gpif2_slave_fifo32 .fifo_clk(fifo_clk), .fifo_rst(fifo_rst), .fifo_nearly_full(ctrl_tx_fifo_nearly_full), .fifo_has_space(ctrl_tx_fifo_has_space), .o_tdata(ctrl_tdata), .o_tlast(ctrl_tlast), .o_tvalid(ctrl_tvalid), .o_tready(ctrl_tready), - .bus_error(ctrl_bus_error), .debug(debug_tx_ctrl) + .bus_error(ctrl_bus_error), .debug() ); // //////////////////////////////////////////////////////////////////// @@ -306,70 +331,6 @@ module gpif2_slave_fifo32 // //////////////////////////////////////////// // DEBUG - wire [31:0] debug0 = { - sloe, slrd, slwr, pktend, fifoadr, EP_READY, EP_WMARK, //8 - state, //4 - data_tx_tvalid, data_tx_tready, data_rx_tvalid, data_rx_tready, //4 - gpif_d[15:0] //16 - }; - - reg [31:0] debug_reg0; - reg [31:0] debug_reg1; - reg [31:0] debug_reg2; - always @(posedge gpif_clk) debug_reg0 <= debug0; - always @(posedge gpif_clk) debug_reg1 <= debug_reg0; - always @(posedge gpif_clk) debug_reg2 <= debug_reg1; - assign debug = debug_reg2; - - wire [37:0] debug_resp = { - resp_tlast, // 37 - resp_tready, // 36 - resp_tvalid, // 35 - ctrl_rx_tlast, // 34 - ctrl_rx_tready, // 33 - ctrl_rx_tvalid, // 32 - ctrl_rx_tdata // 31:0 - }; - - - reg [255:0] debug1,debug2; - - always @(posedge gpif_clk) debug1 <= {debug_resp,debug_tx_ctrl,debug0}; - always @(posedge gpif_clk) debug2 <= debug1; - - - - wire [35:0] CONTROL0,CONTROL1; - /* - chipscope_ila_32 chipscope_ila_32( - .CONTROL(CONTROL0), // INOUT BUS [35:0] - .CLK(gpif_clk), // IN - .TRIG0(debug2) // IN BUS [31:0] - ); - - chipscope_ila_128 chipscope_ila_128( - .CONTROL(CONTROL1), // INOUT BUS [35:0] - .CLK(fifo_clk), // IN - .TRIG0({debug4,debug6}) // IN BUS [31:0] - ); - - - chipscope_ila_256 chipscope_ila_256( - .CONTROL(CONTROL0), // INOUT BUS [35:0] - .CLK(gpif_clk), // IN - .TRIG0(debug2) // IN BUS [31:0] - ); - chipscope_ila_32 chipscope_ila_32_2( - .CONTROL(CONTROL1), // INOUT BUS [35:0] - .CLK(gpif_clk), // IN - .TRIG0(32'd0) // IN BUS [31:0] - ); - - chipscope_icon chipscope_icon( - .CONTROL0(CONTROL0), // INOUT BUS [35:0] - .CONTROL1(CONTROL1) // INOUT BUS [35:0] - ); - */ endmodule // gpif2_slave_fifo32 diff --git a/fpga/usrp3/lib/gpif2/gpif2_to_fifo64.v b/fpga/usrp3/lib/gpif2/gpif2_to_fifo64.v index 3d60c7326..c6d50a59d 100644 --- a/fpga/usrp3/lib/gpif2/gpif2_to_fifo64.v +++ b/fpga/usrp3/lib/gpif2/gpif2_to_fifo64.v @@ -1,118 +1,136 @@ // // Copyright 2012-2013 Ettus Research LLC // - +// This program is free software: you can redistribute it and/or modify +// it under the terms of the GNU General Public License as published by +// the Free Software Foundation, either version 3 of the License, or +// (at your option) any later version. +// +// This program is distributed in the hope that it will be useful, +// but WITHOUT ANY WARRANTY; without even the implied warranty of +// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the +// GNU General Public License for more details. +// +// You should have received a copy of the GNU General Public License +// along with this program. If not, see <http://www.gnu.org/licenses/>. +// module gpif2_to_fifo64 -#( + #( parameter FIFO_SIZE = 9 -) -( - //input interface - input gpif_clk, input gpif_rst, - input [31:0] i_tdata, - input i_tlast, - input i_tvalid, - output i_tready, - output fifo_has_space, - output fifo_nearly_full, - - //output fifo interface - input fifo_clk, input fifo_rst, - output [63:0] o_tdata, - output o_tlast, - output o_tvalid, - input o_tready, - - output bus_error, - output [159:0] debug -); - - wire [31:0] int_tdata; - wire int_tlast; - wire int_tvalid, int_tready; - - wire [31:0] int0_tdata; wire int0_tlast, int0_tvalid, int0_tready; - - //this fifo provides a space signal so we know a burst is possible - localparam BURST_SIZE = (FIFO_SIZE < 8)? FIFO_SIZE : 8; - wire [15:0] space; - - - assign fifo_has_space = space >= (1 << BURST_SIZE); - assign fifo_nearly_full = (space < 6); // 5 spaces left. - - axi_fifo #(.WIDTH(33), .SIZE(0)) ingress_timing_fifo - ( - .clk(gpif_clk), .reset(gpif_rst), .clear(1'b0), - .i_tdata({i_tlast, i_tdata}), .i_tvalid(i_tvalid), .i_tready(i_tready), .space(), - .o_tdata({int0_tlast, int0_tdata}), .o_tvalid(int0_tvalid), .o_tready(int0_tready), .occupied() - ); - axi_fifo #(.WIDTH(33), .SIZE(BURST_SIZE)) min_read_buff + ) ( - .clk(gpif_clk), .reset(gpif_rst), .clear(1'b0), - .i_tdata({int0_tlast, int0_tdata}), .i_tvalid(int0_tvalid), .i_tready(int0_tready), .space(space), - .o_tdata({int_tlast, int_tdata}), .o_tvalid(int_tvalid), .o_tready(int_tready), .occupied() - ); - - reg input_write_error; - - always @(posedge gpif_clk) input_write_error <= i_tvalid & ~i_tready; - + //input interface + input gpif_clk, + input gpif_rst, + input [31:0] i_tdata, + input i_tlast, + input i_tvalid, + output i_tready, + output fifo_has_space, + output fifo_nearly_full, - wire [31:0] chk_tdata; - wire chk_tlast; - wire chk_tvalid, chk_tready; + //output fifo interface + input fifo_clk, + input fifo_rst, + output [63:0] o_tdata, + output o_tlast, + output o_tvalid, + input o_tready, - axi_fifo_2clk #(.WIDTH(33), .SIZE(0/*SRL*/)) cross_clock_fifo - ( - .reset(fifo_rst | gpif_rst), - .i_aclk(gpif_clk), .i_tdata({int_tlast, int_tdata}), .i_tvalid(int_tvalid), .i_tready(int_tready), - .o_aclk(fifo_clk), .o_tdata({chk_tlast, chk_tdata}), .o_tvalid(chk_tvalid), .o_tready(chk_tready) - ); - - wire [31:0] o32_tdata; - wire o32_tlast; - wire o32_tvalid, o32_tready; - - //reframes a tlast from the vita header - and drops bad packets - //* - gpif2_error_checker #(.SIZE(FIFO_SIZE)) checker - ( - .clk(fifo_clk), .reset(fifo_rst), .clear(1'b0), - .i_tdata(chk_tdata), .i_tlast(chk_tlast), .i_tvalid(chk_tvalid), .i_tready(chk_tready), - .o_tdata(o32_tdata), .o_tlast(o32_tlast), .o_tvalid(o32_tvalid), .o_tready(o32_tready), - .bus_error(bus_error), .debug(debug[63:0]) - ); - //*/ - //assign o32_tdata = chk_tdata; - //assign o32_tlast = chk_tlast; - //assign o32_tvalid = chk_tvalid; - //assign chk_tready = o32_tready; - - axi_fifo32_to_fifo64 fifo32_to_fifo64 - ( - .clk(fifo_clk), .reset(fifo_rst), .clear(1'b0), - .i_tdata(o32_tdata), .i_tuser(2'b0/*always 32 bits*/), .i_tlast(o32_tlast), .i_tvalid(o32_tvalid), .i_tready(o32_tready), - .o_tdata(o_tdata), .o_tuser(/*ignored cuz vita has len*/), .o_tlast(o_tlast), .o_tvalid(o_tvalid), .o_tready(o_tready) - ); - - assign debug[159:64] = { - fifo_nearly_full, // 146 - space[9:0], // 145:136 - input_write_error, // 135 - int_tlast, // 134 - int_tready, // 133 - int_tvalid, // 132 - i_tlast, // 131 - i_tready, // 130 - fifo_has_space, // 129 - i_tvalid, // 128 - int_tdata[31:0], // 127:96 - i_tdata[31:0] // 95:64 - }; + output bus_error, + output [31:0] debug + ); + wire [31:0] int_tdata; + wire int_tlast; + wire int_tvalid, int_tready; + + wire [31:0] int0_tdata; + wire int0_tlast, int0_tvalid, int0_tready; + + // + // Generate flags that show if initial FIFO's can accept a maximum sized burst from the FX3 + // or if the FIFO is about to fill. + // + localparam BURST_SIZE = (FIFO_SIZE < 8)? FIFO_SIZE : 8; + wire [15:0] space; + assign fifo_has_space = space >= (1 << BURST_SIZE); + assign fifo_nearly_full = (space < 6); // 5 spaces left. + + // + // This FIFO is provdied purely to easy FPGA timing closure as data is comming from I/O pins. + // + axi_fifo #(.WIDTH(33), .SIZE(0)) ingress_timing_fifo + ( + .clk(gpif_clk), .reset(gpif_rst), .clear(1'b0), + .i_tdata({i_tlast, i_tdata}), .i_tvalid(i_tvalid), .i_tready(i_tready), .space(), + .o_tdata({int0_tlast, int0_tdata}), .o_tvalid(int0_tvalid), .o_tready(int0_tready), .occupied() + ); + + // + // This FIFO provides space to accept a single burst from FX3 and it's fullness drives flags to GPIF2 logic + // + axi_fifo #(.WIDTH(33), .SIZE(BURST_SIZE)) min_read_buff + ( + .clk(gpif_clk), .reset(gpif_rst), .clear(1'b0), + .i_tdata({int0_tlast, int0_tdata}), .i_tvalid(int0_tvalid), .i_tready(int0_tready), .space(space), + .o_tdata({int_tlast, int_tdata}), .o_tvalid(int_tvalid), .o_tready(int_tready), .occupied() + ); + + // + // This logic allows signals to cross from the GPIF2 clock domain to the BUS clock domain. + // It may now be obselete if bus_clk and gpif_clk are merged + // + wire [31:0] chk_tdata; + wire chk_tlast; + wire chk_tvalid, chk_tready; + + axi_fifo_2clk #(.WIDTH(33), .SIZE(0/*SRL*/)) cross_clock_fifo + ( + .reset(fifo_rst | gpif_rst), + .i_aclk(gpif_clk), .i_tdata({int_tlast, int_tdata}), .i_tvalid(int_tvalid), .i_tready(int_tready), + .o_aclk(fifo_clk), .o_tdata({chk_tlast, chk_tdata}), .o_tvalid(chk_tvalid), .o_tready(chk_tready) + ); + + // + // Performs basic tests on incomming packets such as testing if size on the wire patches + // the internal size field. Uses axi_packet_gate internally so can back pressure upstream if + // packet needs to be dropped. + // + wire [31:0] o32_tdata; + wire o32_tlast; + wire o32_tvalid, o32_tready; + + gpif2_error_checker #(.SIZE(FIFO_SIZE)) checker + ( + .clk(fifo_clk), .reset(fifo_rst), .clear(1'b0), + .i_tdata(chk_tdata), .i_tlast(chk_tlast), .i_tvalid(chk_tvalid), .i_tready(chk_tready), + .o_tdata(o32_tdata), .o_tlast(o32_tlast), .o_tvalid(o32_tvalid), .o_tready(o32_tready), + .bus_error(bus_error), .debug() + ); - + //assign o32_tdata = chk_tdata; + //assign o32_tlast = chk_tlast; + //assign o32_tvalid = chk_tvalid; + //assign chk_tready = o32_tready; + + // + // Convert 32bit AXIS bus to 64bit + // + axi_fifo32_to_fifo64 fifo32_to_fifo64 + ( + .clk(fifo_clk), .reset(fifo_rst), .clear(1'b0), + .i_tdata(o32_tdata), .i_tuser(2'b0/*always 32 bits*/), .i_tlast(o32_tlast), .i_tvalid(o32_tvalid), .i_tready(o32_tready), + .o_tdata(o_tdata), .o_tuser(/*ignored cuz vita has len*/), .o_tlast(o_tlast), .o_tvalid(o_tvalid), .o_tready(o_tready) + ); + + + ///////////////////////////////////////////// + // + // Debug logic only + // + ///////////////////////////////////////////// + endmodule //fifo_to_gpif2 |