aboutsummaryrefslogtreecommitdiffstats
path: root/fpga/usrp3/lib/vita/chdr_16sc_to_32f.v
diff options
context:
space:
mode:
Diffstat (limited to 'fpga/usrp3/lib/vita/chdr_16sc_to_32f.v')
-rw-r--r--fpga/usrp3/lib/vita/chdr_16sc_to_32f.v138
1 files changed, 0 insertions, 138 deletions
diff --git a/fpga/usrp3/lib/vita/chdr_16sc_to_32f.v b/fpga/usrp3/lib/vita/chdr_16sc_to_32f.v
deleted file mode 100644
index 74aff2f08..000000000
--- a/fpga/usrp3/lib/vita/chdr_16sc_to_32f.v
+++ /dev/null
@@ -1,138 +0,0 @@
-//
-// Copyright 2013 Ettus Research LLC
-//
-
-
-
-
-
-module chdr_16sc_to_32f
- #(parameter BASE=0)
- ( input clk, input reset, input set_stb, input [7:0] set_addr,
- input [31:0] set_data,
- input [63:0] i_tdata,
- input i_tlast,
- input i_tvalid,
- output i_tready,
-
-
- output reg [63:0] o_tdata,
- output o_tlast,
- output o_tvalid,
- input o_tready,
-
- output [31:0] debug
- );
-
-
- wire [31:0] s0_real;
- wire [31:0] s0_imag;
- wire [31:0] s1_real;
- wire [31:0] s1_imag;
-
-
- wire chdr_has_hdr = 1'b1;
- wire chdr_has_time = i_tdata[61];
- wire chdr_has_tlr = 1'b0;
-
-
- //chdr length calculations
-
- wire [15:0] chdr_header_lines = chdr_has_time? 16:8;
- wire [15:0] samples = ((i_tdata[47:32] - chdr_header_lines) << 1);
- wire [15:0] i_samples = (i_tdata[47:32] - chdr_header_lines);
-
-
- wire [15:0] chdr_payload_lines = samples + chdr_header_lines;
-
-
-
- wire set_sid;
- wire [15:0] my_newhome;
-
- setting_reg #(.my_addr(BASE), .width(17)) new_destination
- (.clk(clk), .rst(reset), .strobe(set_stb), .addr(set_addr), .in(set_data),.out({set_sid, my_newhome[15:0]}));
-
-
-
-
-
- //state machines
- localparam HEADER = 2'd0;//IDLE
- localparam TIME = 2'd1;
- localparam ODD = 2'd2;
- localparam EVEN = 2'd3;
- reg [1:0] state;
- reg end_on_odd;
-
-
-
-
-
- always @(posedge clk) begin
-
-
- if (reset) begin
- state <= HEADER;
- end_on_odd <= 1'b0;
- end
- else if (o_tready && i_tvalid) case(state)
-
- HEADER: begin
- state <= (i_tdata[61])? TIME : ODD;
- end_on_odd <= (i_samples[2:1] == 2 || i_samples[2:1] == 1);
- end
-
- TIME: begin
- state <= (i_tlast)? HEADER: ODD;
- end
-
- ODD: begin
- state <= (i_tlast & end_on_odd)? HEADER:EVEN;
- end
-
- EVEN: begin
- state <= (i_tlast) ? HEADER: ODD;
- end
-
- default: state <= HEADER;
- endcase
- end
-
-
-
-
- iq_to_float #(.BITS_IN(16), .BITS_OUT(32))
- iq_to_float_imag0 (.in(i_tdata[63:48]), .out(s0_imag[31:0]));
-
- iq_to_float #(.BITS_IN(16), .BITS_OUT(32))
- iq_to_float_real0 (.in(i_tdata[47:32]), .out(s0_real[31:0]));
-
- iq_to_float #(.BITS_IN(16), .BITS_OUT(32))
- iq_to_float_imag1 (.in(i_tdata[31:16]), .out(s1_imag[31:0]));
-
- iq_to_float #(.BITS_IN(16), .BITS_OUT(32))
- iq_to_float_real1 (.in(i_tdata[15:0]), .out(s1_real[31:0]));
-
-
-
-
-
- always @(*)
- case(state)
-
- HEADER: o_tdata <= {i_tdata[63:48], chdr_payload_lines,
- set_sid ? {i_tdata[15:0], my_newhome[15:0]}:i_tdata[31:0]};
- TIME: o_tdata <= i_tdata;
- ODD: o_tdata <= {s0_imag,s0_real};
- EVEN: o_tdata <= {s1_imag,s1_real};
-
-
- default : o_tdata = i_tdata;
- endcase
-
- assign o_tvalid = i_tvalid;
- assign i_tready = o_tready && ((state != ODD) || (i_tlast && end_on_odd));
- assign o_tlast = i_tlast && ((state == EVEN) || (state == ODD && end_on_odd));
-
-endmodule