aboutsummaryrefslogtreecommitdiffstats
path: root/fpga/usrp3/lib/rfnoc
diff options
context:
space:
mode:
Diffstat (limited to 'fpga/usrp3/lib/rfnoc')
-rw-r--r--fpga/usrp3/lib/rfnoc/blocks/rfnoc_block_radio/rx_frontend_gen3.v74
1 files changed, 73 insertions, 1 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 df2965a9d..c11f174e5 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
@@ -5,7 +5,79 @@
//
// SPDX-License-Identifier: LGPL-3.0-or-later
//
-
+// Module: rx_frontend_gen3
+//
+// Description:
+//
+// RX Frontend Correction Module
+// -----------------------------
+//
+// This module will perform the following modifications of the signal, in this
+// order:
+//
+// 1) I/Q Swapping/Reordering: The I and Q values from the ADC can be remapped
+// arbitrarily and can be inverted. The behaviour of this IQ mux is
+// controlled by writing to the settings register at SR_IQ_MAPPING.
+//
+// This register uses the following bits:
+//
+// Bit 0: Set to 1 to swap I and Q.
+// Bit 1: Set to 1 to enable real mode (only relevant if
+// BYPASS_REALMODE_DSP is set to 0, see below). If it is 1, then
+// the Q input signal is ignored and assumed to be zero.
+// Bit 2: Set to 1 to invert the Q input signal
+// Bit 3: Set to 1 to invert the I input signal
+// Bit 4: Set to 1 to enable the quarter-rate downconverter (only relevant
+// when BYPASS_REALMODE_DSP is set to 0, see below).
+// Bit 7: Disable all corrections in this module.
+//
+// 2) DC offset correction. See the rx_dcoffset module for details. This is
+// either a fixed DC offset, or a notch filter around DC. The behaviour of
+// this correction step is controlled by writing to settings registers at
+// SR_OFFSET_I and SR_OFFSET_Q (they get forwarded to rx_dcoffset).
+// Set BYPASS_DC_OFFSET_CORR to 1 to not synthesize this step.
+//
+// 3) IQ imbalance correction. This implements a simple, one-shot IQ imbalance
+// correction. It will modify the I and Q signals as follows:
+// _ _ _ _ _ _
+// | I' | | A/64+1 0 | | I |
+// | | = | | | |
+// |_Q'_| |_ B/64 1_| |_ Q _|
+//
+// Here, A is the value written to the register at SR_MAG_CORRECTION, and
+// B is the value written to the register at SR_PHASE_CORRECTION.
+// Set BYPASS_IQ_COMP to 1 to not synthesize this step.
+//
+// 4) Real-to-imaginary conversion. The converter is only enabled when the
+// "downconvert" bit in the SR_IQ_MAPPING register is asserted. In this
+// case, it enables a quarter-rate mixer. The direction of this mixer is
+// controlled by the SR_HET_PHASE_INCR register (a 0 in this register
+// rotates by pi/2 every clock cycle, a 1 in this register rotates by -pi/2).
+//
+// The mixer is followed by a non-decimating half-band filter.
+//
+// Set BYPASS_REALMODE_DSP to 1 to not synthesize this step.
+//
+//
+// UHD Developers Note: This module is typically controlled by rx_frontend_core_3000 in UHD,
+// and is also described in the calibration.dox manual page. When modifying this file, make
+// sure to also modify those files if necessary.
+//
+// Parameters:
+// SR_MAG_CORRECTION : Settings register address for the IQ correction "MAG" value
+// SR_PHASE_CORRECTION : Settings register address for the IQ correction "PHASE" value
+// SR_OFFSET_I : Settings register address for DC offset I correction
+// value (goes to rx_dcoffset)
+// SR_OFFSET_Q : Settings register address for DC offset Q correction
+// value (goes to rx_dcoffset)
+// SR_IQ_MAPPING : Settings register address for IQ mapping value
+// SR_HET_PHASE_INCR : Settings register address for the real mode phase
+// increment value
+// BYPASS_DC_OFFSET_CORR : Set to 1 to disable DC offset correction
+// BYPASS_IQ_COMP : Set to 1 to disable IQ offset correction
+// BYPASS_REALMODE_DSP : Set to 1 to disable realmode to complex conversion
+// DEVICE : Unused.
+//
module rx_frontend_gen3 #(
parameter SR_MAG_CORRECTION = 0,
parameter SR_PHASE_CORRECTION = 1,