aboutsummaryrefslogtreecommitdiffstats
path: root/fpga/usrp3
diff options
context:
space:
mode:
authorMichael West <michael.west@ettus.com>2020-03-19 12:29:29 -0700
committerAaron Rossetto <aaron.rossetto@ni.com>2020-05-12 12:03:31 -0500
commitd0c162bc7a4ac82f6104506b17d7be05e1780336 (patch)
tree464a4ce1852dcd7ee986dff9a0d1c74267f3ecf5 /fpga/usrp3
parent12dfb97c8efce40494efb35bdd81d06b6f8b9b62 (diff)
downloaduhd-d0c162bc7a4ac82f6104506b17d7be05e1780336.tar.gz
uhd-d0c162bc7a4ac82f6104506b17d7be05e1780336.tar.bz2
uhd-d0c162bc7a4ac82f6104506b17d7be05e1780336.zip
TwinRX: Remove decimation from frontend
The decimation in the rx_frontend_gen3 was added to reduce the bandwidth between the Radio and the DDC due to the limitation in bandwidth over the crossbar for dynamically connected blocks. The default FPGA image for the X300 now has a static connection between the Radio and DDC, so this is no longer necessary. This change allows the TwinRX receive channels to be time aligned with channels from other daughterboards so they can be used in the same streamer. Signed-off-by: Michael West <michael.west@ettus.com>
Diffstat (limited to 'fpga/usrp3')
-rw-r--r--fpga/usrp3/lib/rfnoc/blocks/rfnoc_block_radio/rx_frontend_gen3.v88
1 files changed, 52 insertions, 36 deletions
diff --git a/fpga/usrp3/lib/rfnoc/blocks/rfnoc_block_radio/rx_frontend_gen3.v b/fpga/usrp3/lib/rfnoc/blocks/rfnoc_block_radio/rx_frontend_gen3.v
index 54529136b..eaf082ac5 100644
--- a/fpga/usrp3/lib/rfnoc/blocks/rfnoc_block_radio/rx_frontend_gen3.v
+++ b/fpga/usrp3/lib/rfnoc/blocks/rfnoc_block_radio/rx_frontend_gen3.v
@@ -1,6 +1,7 @@
//
// Copyright 2015 Ettus Research LLC
// Copyright 2018 Ettus Research, a National Instruments Company
+// Copyright 2020 Ettus Research, a National Instruments Brand
//
// SPDX-License-Identifier: LGPL-3.0-or-later
//
@@ -27,7 +28,7 @@ module rx_frontend_gen3 #(
wire swap_iq;
wire invert_i;
wire invert_q;
- wire realmode_decim;
+ wire downconvert;
wire bypass_all;
wire [1:0] iq_map_reserved;
wire [17:0] mag_corr, phase_corr;
@@ -37,12 +38,10 @@ module rx_frontend_gen3 #(
reg [23:0] adc_i_mux, adc_q_mux;
reg adc_mux_stb;
wire [23:0] adc_i_ofs, adc_q_ofs, adc_i_comp, adc_q_comp;
- reg [23:0] adc_i_ofs_dly, adc_q_ofs_dly;
wire adc_ofs_stb, adc_comp_stb;
reg [1:0] adc_ofs_stb_dly;
wire [23:0] adc_i_dsp, adc_q_dsp;
wire adc_dsp_stb;
- wire [35:0] corr_i, corr_q;
wire [15:0] rx_i_out, rx_q_out;
/********************************************************
@@ -58,7 +57,9 @@ module rx_frontend_gen3 #(
setting_reg #(.my_addr(SR_IQ_MAPPING), .width(8)) sr_mux_sel (
.clk(clk),.rst(reset),.strobe(set_stb),.addr(set_addr),
- .in(set_data),.out({bypass_all,iq_map_reserved,realmode_decim,invert_i,invert_q,realmode,swap_iq}),.changed());
+ .in(set_data),
+ .out({bypass_all,iq_map_reserved,downconvert,invert_i,invert_q,realmode,swap_iq}),
+ .changed());
// Setting reg: 1 bit to set phase direction: default to 0:
// direction bit == 0: the phase is increased by pi/2 (counter clockwise)
@@ -179,17 +180,9 @@ module rx_frontend_gen3 #(
if (BYPASS_REALMODE_DSP == 0) begin
wire [24:0] adc_i_dsp_cout, adc_q_dsp_cout;
- wire [23:0] adc_i_cclip, adc_q_cclip;
- wire [23:0] adc_i_hb, adc_q_hb;
- wire [23:0] adc_i_dec, adc_q_dec;
+ wire [23:0] adc_i_filt, adc_q_filt;
wire adc_dsp_cout_stb;
- wire adc_cclip_stb;
- wire adc_hb_stb;
-
- wire valid_hbf0;
- wire valid_hbf1;
- wire valid_dec0;
- wire valid_dec1;
+ wire adc_filt_stb;
// 90 degree mixer
quarter_rate_downconverter #(.WIDTH(24)) qr_dc_i(
@@ -204,28 +197,51 @@ module rx_frontend_gen3 #(
18'd0, -18'd26536, 18'd0, 18'd14632, 18'd0, -18'd9187, 18'd0, 18'd5990, 18'd0, -18'd3900, 18'd0, 18'd2478, 18'd0, -18'd1505,
18'd0, 18'd855, 18'd0, -18'd440, 18'd0, 18'd194, 18'd0, -18'd62};
- axi_fir_filter_dec #(
- .WIDTH(24),
- .COEFF_WIDTH(18),
- .NUM_COEFFS(47),
- .COEFFS_VEC(HB_COEFS),
- .BLANK_OUTPUT(0)
- ) ffd0 (
- .clk(clk), .reset(reset || sync_in),
-
- .i_tdata({adc_i_dsp_cout, adc_q_dsp_cout}),
- .i_tlast(1'b1),
- .i_tvalid(adc_dsp_cout_stb),
- .i_tready(),
-
- .o_tdata({adc_i_dec, adc_q_dec}),
- .o_tlast(),
- .o_tvalid(adc_hb_stb),
- .o_tready(1'b1));
-
- assign adc_dsp_stb = realmode_decim ? adc_hb_stb : adc_comp_stb;
- assign adc_i_dsp = realmode_decim ? adc_i_dec : adc_i_comp;
- assign adc_q_dsp = realmode_decim ? adc_q_dec : adc_q_comp;
+ // FIR filter for real part
+ axi_fir_filter #(.IN_WIDTH(24), .COEFF_WIDTH(18), .OUT_WIDTH(24), .NUM_COEFFS(47), .COEFFS_VEC(HB_COEFS),
+ .RELOADABLE_COEFFS(0), .BLANK_OUTPUT(0), .SYMMETRIC_COEFFS(1), .SKIP_ZERO_COEFFS(1), .USE_EMBEDDED_REGS_COEFFS(0)
+ ) hbfir0(
+ .clk(clk),
+ .reset(reset),
+ .clear(reset),
+ .s_axis_data_tdata(adc_i_dsp_cout),
+ .s_axis_data_tlast(1'b1),
+ .s_axis_data_tvalid(adc_dsp_cout_stb),
+ .s_axis_data_tready(),
+ .m_axis_data_tdata(adc_i_filt),
+ .m_axis_data_tlast(),
+ .m_axis_data_tvalid(adc_filt_stb),
+ .m_axis_data_tready(1'b1),
+ .s_axis_reload_tdata(18'd0),
+ .s_axis_reload_tvalid(1'b0),
+ .s_axis_reload_tlast(1'b0),
+ .s_axis_reload_tready()
+ );
+
+ // FIR filter for imag. part
+ axi_fir_filter #(.IN_WIDTH(24), .COEFF_WIDTH(18), .OUT_WIDTH(24), .NUM_COEFFS(47), .COEFFS_VEC(HB_COEFS),
+ .RELOADABLE_COEFFS(0), .BLANK_OUTPUT(0), .SYMMETRIC_COEFFS(1), .SKIP_ZERO_COEFFS(1), .USE_EMBEDDED_REGS_COEFFS(0)
+ ) hbfir1(
+ .clk(clk),
+ .reset(reset),
+ .clear(reset),
+ .s_axis_data_tdata(adc_q_dsp_cout),
+ .s_axis_data_tlast(1'b1),
+ .s_axis_data_tvalid(adc_dsp_cout_stb),
+ .s_axis_data_tready(),
+ .m_axis_data_tdata(adc_q_filt),
+ .m_axis_data_tlast(),
+ .m_axis_data_tvalid(),
+ .m_axis_data_tready(1'b1),
+ .s_axis_reload_tdata(18'd0),
+ .s_axis_reload_tvalid(1'b0),
+ .s_axis_reload_tlast(1'b0),
+ .s_axis_reload_tready()
+ );
+
+ assign adc_dsp_stb = downconvert ? adc_filt_stb : adc_comp_stb;
+ assign adc_i_dsp = downconvert ? adc_i_filt : adc_i_comp;
+ assign adc_q_dsp = downconvert ? adc_q_filt : adc_q_comp;
end else begin
assign adc_dsp_stb = adc_comp_stb;