aboutsummaryrefslogtreecommitdiffstats
path: root/fpga/usrp3/lib/xge_interface/axi64_to_xge64.v
diff options
context:
space:
mode:
Diffstat (limited to 'fpga/usrp3/lib/xge_interface/axi64_to_xge64.v')
-rw-r--r--fpga/usrp3/lib/xge_interface/axi64_to_xge64.v89
1 files changed, 89 insertions, 0 deletions
diff --git a/fpga/usrp3/lib/xge_interface/axi64_to_xge64.v b/fpga/usrp3/lib/xge_interface/axi64_to_xge64.v
new file mode 100644
index 000000000..3921c607c
--- /dev/null
+++ b/fpga/usrp3/lib/xge_interface/axi64_to_xge64.v
@@ -0,0 +1,89 @@
+//
+// Copyright 2013 Ettus Research LLC
+// Copyright 2018 Ettus Research, a National Instruments Company
+//
+// SPDX-License-Identifier: LGPL-3.0-or-later
+//
+
+
+//
+// Removes 6 alignment bytes at the beginning of every packet.
+// This gives us proper alignment to the IP/UDP header.
+//
+// Place an SOF indication in bit[3] of the output tuser.
+//
+
+module axi64_to_xge64
+ (
+ input clk,
+ input reset,
+ input clear,
+ input [63:0] s_axis_tdata,
+ input [3:0] s_axis_tuser,
+ input s_axis_tlast,
+ input s_axis_tvalid,
+ output s_axis_tready,
+ output [63:0] m_axis_tdata,
+ output [3:0] m_axis_tuser,
+ output m_axis_tlast,
+ output m_axis_tvalid,
+ input m_axis_tready
+ );
+
+ localparam STORE_FIRST = 0;
+ localparam FORWARD_FULL = 1;
+ localparam RELEASE_LAST = 2;
+
+ reg [1:0] state;
+ reg [15:0] saved;
+ reg [2:0] last_occ;
+ reg last_sof;
+
+ //on last line when eof and not finishing with 7 or 8 bytes as last word.
+ wire last_line = (s_axis_tlast && !(s_axis_tuser[2:0] == 3'b111 || s_axis_tuser[2:0] == 3'b000));
+
+ always @(posedge clk) begin
+ if(reset | clear) begin
+ last_sof <= 0;
+ last_occ <= 0;
+ state <= STORE_FIRST;
+ end
+ else begin
+ if (s_axis_tvalid && s_axis_tready) begin
+ saved <= s_axis_tdata[63:48];
+ last_occ <= s_axis_tuser[2:0];
+ last_sof <= (state == STORE_FIRST) ;
+ end
+
+ case(state)
+
+ STORE_FIRST: begin
+ if (s_axis_tvalid && s_axis_tready) begin
+ state <= FORWARD_FULL;
+ end
+ end
+
+ FORWARD_FULL: begin
+ if (s_axis_tvalid && s_axis_tready && s_axis_tlast) begin
+ state <= last_line? STORE_FIRST : RELEASE_LAST;
+ end
+ end
+
+ RELEASE_LAST: begin
+ if (m_axis_tvalid && m_axis_tready) begin
+ state <= STORE_FIRST;
+ end
+ end
+
+ endcase //state
+ end
+ end
+
+ assign m_axis_tdata[63:0] = {s_axis_tdata[47:0], saved};
+ assign m_axis_tuser[3] = last_sof;
+ assign m_axis_tlast = (state == RELEASE_LAST)? 1'b1 : last_line;
+ assign m_axis_tuser[2:0] = ((state == RELEASE_LAST)? last_occ : (last_line? s_axis_tuser[2:0] : 3'b110)) + 3'b010;
+ assign m_axis_tvalid = (state == STORE_FIRST)? 0 : ((state == RELEASE_LAST)? 1 : s_axis_tvalid);
+ assign s_axis_tready = (state == STORE_FIRST)? 1 : ((state == RELEASE_LAST)? 0 : m_axis_tready);
+
+endmodule //fifo69_txrealign