aboutsummaryrefslogtreecommitdiffstats
path: root/fpga/usrp2/udp/prot_eng_tx.v
diff options
context:
space:
mode:
Diffstat (limited to 'fpga/usrp2/udp/prot_eng_tx.v')
-rw-r--r--fpga/usrp2/udp/prot_eng_tx.v127
1 files changed, 0 insertions, 127 deletions
diff --git a/fpga/usrp2/udp/prot_eng_tx.v b/fpga/usrp2/udp/prot_eng_tx.v
deleted file mode 100644
index 40abf3c04..000000000
--- a/fpga/usrp2/udp/prot_eng_tx.v
+++ /dev/null
@@ -1,127 +0,0 @@
-//
-// Copyright 2011 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 prot_eng_tx
- #(parameter BASE=0)
- (input clk, input reset, input clear,
- input set_stb, input [7:0] set_addr, input [31:0] set_data,
- input [35:0] datain, input src_rdy_i, output dst_rdy_o,
- output [35:0] dataout, output src_rdy_o, input dst_rdy_i);
-
- wire src_rdy_int1, dst_rdy_int1;
- wire src_rdy_int2, dst_rdy_int2;
- wire [35:0] data_int1, data_int2;
-
- // Shortfifo on input to guarantee no deadlock
- fifo_short #(.WIDTH(36)) head_fifo
- (.clk(clk),.reset(reset),.clear(clear),
- .datain(datain), .src_rdy_i(src_rdy_i), .dst_rdy_o(dst_rdy_o),
- .dataout(data_int1), .src_rdy_o(src_rdy_int1), .dst_rdy_i(dst_rdy_int1),
- .space(),.occupied() );
-
- // Store header values in a small dual-port (distributed) ram
- reg [31:0] header_ram[0:63];
- reg [3:0] state;
- reg [1:0] port_sel;
-
- always @(posedge clk)
- if(set_stb & ((set_addr & 8'hC0) == BASE))
- header_ram[set_addr[5:0]] <= set_data;
-
- wire [31:0] header_word = header_ram[{port_sel[1:0],state[3:0]}];
-
- reg [15:0] pre_checksums [0:3];
- always @(posedge clk)
- if(set_stb & ((set_addr & 8'hCF)== (BASE+7)))
- pre_checksums[set_addr[5:4]] <= set_data[15:0];
-
- wire [15:0] pre_checksum = pre_checksums[port_sel[1:0]];
-
- // Protocol State Machine
- reg [15:0] length;
- wire [15:0] ip_length = length + 28; // IP HDR + UDP HDR
- wire [15:0] udp_length = length + 8; // UDP HDR
- reg sof_o;
- reg [31:0] prot_data;
-
- always @(posedge clk)
- if(reset)
- begin
- state <= 0;
- sof_o <= 0;
- end
- else
- if(src_rdy_int1 & dst_rdy_int2)
- case(state)
- 0 :
- begin
- port_sel <= data_int1[18:17];
- length <= data_int1[15:0];
- sof_o <= 1;
- if(data_int1[16])
- state <= 1;
- else
- state <= 12;
- end
- 12 :
- begin
- sof_o <= 0;
- if(data_int1[33]) // eof
- state <= 0;
- end
- default :
- begin
- sof_o <= 0;
- state <= state + 1;
- end
- endcase // case (state)
-
- wire [15:0] ip_checksum;
- add_onescomp #(.WIDTH(16)) add_onescomp
- (.A(pre_checksum),.B(ip_length),.SUM(ip_checksum));
- reg [15:0] ip_checksum_reg;
- always @(posedge clk) ip_checksum_reg <= ip_checksum;
-
- always @*
- case(state)
- 1 : prot_data <= header_word; // ETH, top half ignored
- 2 : prot_data <= header_word; // ETH
- 3 : prot_data <= header_word; // ETH
- 4 : prot_data <= header_word; // ETH
- 5 : prot_data <= { header_word[31:16], ip_length }; // IP
- 6 : prot_data <= header_word; // IP
- 7 : prot_data <= { header_word[31:16], (16'hFFFF ^ ip_checksum_reg) }; // IP
- 8 : prot_data <= header_word; // IP
- 9 : prot_data <= header_word; // IP
- 10: prot_data <= header_word; // UDP
- 11: prot_data <= { udp_length, header_word[15:0]}; // UDP
- default : prot_data <= data_int1[31:0];
- endcase // case (state)
-
- assign data_int2 = { data_int1[35:33] & {3{state[3]}}, sof_o, prot_data };
- assign dst_rdy_int1 = dst_rdy_int2 & ((state == 0) | (state == 12));
- assign src_rdy_int2 = src_rdy_int1 & (state != 0);
-
- // Shortfifo on output to guarantee no deadlock
- fifo_short #(.WIDTH(36)) tail_fifo
- (.clk(clk),.reset(reset),.clear(clear),
- .datain(data_int2), .src_rdy_i(src_rdy_int2), .dst_rdy_o(dst_rdy_int2),
- .dataout(dataout), .src_rdy_o(src_rdy_o), .dst_rdy_i(dst_rdy_i),
- .space(),.occupied() );
-
-endmodule // prot_eng_tx