aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorBrent Stapleton <brent.stapleton@ettus.com>2019-07-19 12:13:44 -0700
committerMartin Braun <martin.braun@ettus.com>2019-11-26 11:49:25 -0800
commit5072a0f7b6bfacb18d7a7918a843c1da11447612 (patch)
tree5b5963b7cfb0477612fb9062c0d4901424e5efb0
parent7fb8523c935cbcda7fd0dbcbad0ac8c2e6dd1fc7 (diff)
downloaduhd-5072a0f7b6bfacb18d7a7918a843c1da11447612.tar.gz
uhd-5072a0f7b6bfacb18d7a7918a843c1da11447612.tar.bz2
uhd-5072a0f7b6bfacb18d7a7918a843c1da11447612.zip
rx_fe_3000: Changing register address calc
Changing how we calculate RX frontend register addresses to allow for different register offsets. The register addresses are now calculated in a manor similar to how gpio_atr_300_impl does register address calculations, which is to allow a reg_offset to be passes in at construction. The current default is reg_offset=4.
-rw-r--r--host/lib/include/uhdlib/usrp/cores/rx_frontend_core_3000.hpp3
-rw-r--r--host/lib/usrp/cores/rx_frontend_core_3000.cpp47
2 files changed, 31 insertions, 19 deletions
diff --git a/host/lib/include/uhdlib/usrp/cores/rx_frontend_core_3000.hpp b/host/lib/include/uhdlib/usrp/cores/rx_frontend_core_3000.hpp
index 0b544a959..2d20c63fa 100644
--- a/host/lib/include/uhdlib/usrp/cores/rx_frontend_core_3000.hpp
+++ b/host/lib/include/uhdlib/usrp/cores/rx_frontend_core_3000.hpp
@@ -28,7 +28,8 @@ public:
virtual ~rx_frontend_core_3000(void) = 0;
- static sptr make(uhd::wb_iface::sptr iface, const size_t base);
+ static sptr make(
+ uhd::wb_iface::sptr iface, const size_t base, const size_t reg_offset = 4);
/*! Set the input sampling rate (i.e. ADC rate)
*/
diff --git a/host/lib/usrp/cores/rx_frontend_core_3000.cpp b/host/lib/usrp/cores/rx_frontend_core_3000.cpp
index 7f88a3e98..dfaa4a76c 100644
--- a/host/lib/usrp/cores/rx_frontend_core_3000.cpp
+++ b/host/lib/usrp/cores/rx_frontend_core_3000.cpp
@@ -16,12 +16,12 @@
using namespace uhd;
-#define REG_RX_FE_MAG_CORRECTION (_base + 0) // 18 bits
-#define REG_RX_FE_PHASE_CORRECTION (_base + 4) // 18 bits
-#define REG_RX_FE_OFFSET_I (_base + 8) // 18 bits
-#define REG_RX_FE_OFFSET_Q (_base + 12) // 18 bits
-#define REG_RX_FE_MAPPING (_base + 16)
-#define REG_RX_FE_HET_CORDIC_PHASE (_base + 20)
+#define REG_RX_FE_MAG_CORRECTION (base + reg_offset * 0) // 18 bits
+#define REG_RX_FE_PHASE_CORRECTION (base + reg_offset * 1) // 18 bits
+#define REG_RX_FE_OFFSET_I (base + reg_offset * 2) // 18 bits
+#define REG_RX_FE_OFFSET_Q (base + reg_offset * 3) // 18 bits
+#define REG_RX_FE_MAPPING (base + reg_offset * 4)
+#define REG_RX_FE_HET_CORDIC_PHASE (base + reg_offset * 5)
#define FLAG_DSP_RX_MAPPING_SWAP_IQ (1 << 0)
#define FLAG_DSP_RX_MAPPING_REAL_MODE (1 << 1)
@@ -62,13 +62,19 @@ const std::complex<double> rx_frontend_core_3000::DEFAULT_IQ_BALANCE_VALUE =
class rx_frontend_core_3000_impl : public rx_frontend_core_3000
{
public:
- rx_frontend_core_3000_impl(wb_iface::sptr iface, const size_t base)
+ rx_frontend_core_3000_impl(
+ wb_iface::sptr iface, const size_t base, const size_t reg_offset)
: _i_dc_off(0)
, _q_dc_off(0)
, _adc_rate(0.0)
, _fe_conn(fe_connection_t("IQ"))
, _iface(iface)
- , _base(base)
+ , _rx_fe_mag_corr_reg(REG_RX_FE_MAG_CORRECTION)
+ , _rx_fe_phase_corr_reg(REG_RX_FE_PHASE_CORRECTION)
+ , _rx_fe_offset_i_reg(REG_RX_FE_OFFSET_I)
+ , _rx_fe_offset_q_reg(REG_RX_FE_OFFSET_Q)
+ , _rx_fe_mapping_reg(REG_RX_FE_MAPPING)
+ , _rx_fe_het_cordic_phase_reg(REG_RX_FE_HET_CORDIC_PHASE)
{
// NOP
}
@@ -81,7 +87,7 @@ public:
void bypass_all(bool bypass_en)
{
if (bypass_en) {
- _iface->poke32(REG_RX_FE_MAPPING, FLAG_DSP_RX_MAPPING_BYPASS_ALL);
+ _iface->poke32(_rx_fe_mapping_reg, FLAG_DSP_RX_MAPPING_BYPASS_ALL);
} else {
set_fe_connection(_fe_conn);
}
@@ -110,7 +116,7 @@ public:
if (fe_conn.is_q_inverted())
mapping_reg_val |= FLAG_DSP_RX_MAPPING_INVERT_Q;
- _iface->poke32(REG_RX_FE_MAPPING, mapping_reg_val);
+ _iface->poke32(_rx_fe_mapping_reg, mapping_reg_val);
UHD_ASSERT_THROW(_adc_rate != 0.0)
if (fe_conn.get_sampling_mode() == fe_connection_t::HETERODYNE) {
@@ -130,7 +136,7 @@ public:
UHD_ASSERT_THROW(uhd::math::fp_compare::fp_compare_epsilon<double>(4.0)
== std::abs(_adc_rate / cordic_freq));
- _iface->poke32(REG_RX_FE_HET_CORDIC_PHASE, (cordic_freq > 0) ? 0 : 1);
+ _iface->poke32(_rx_fe_het_cordic_phase_reg, (cordic_freq > 0) ? 0 : 1);
}
@@ -155,14 +161,14 @@ public:
void _set_dc_offset(const uint32_t flags)
{
- _iface->poke32(REG_RX_FE_OFFSET_I, flags | (_i_dc_off & ~FLAG_MASK));
- _iface->poke32(REG_RX_FE_OFFSET_Q, flags | (_q_dc_off & ~FLAG_MASK));
+ _iface->poke32(_rx_fe_offset_i_reg, flags | (_i_dc_off & ~FLAG_MASK));
+ _iface->poke32(_rx_fe_offset_q_reg, flags | (_q_dc_off & ~FLAG_MASK));
}
void set_iq_balance(const std::complex<double>& cor)
{
- _iface->poke32(REG_RX_FE_MAG_CORRECTION, fs_to_bits(cor.real(), 18));
- _iface->poke32(REG_RX_FE_PHASE_CORRECTION, fs_to_bits(cor.imag(), 18));
+ _iface->poke32(_rx_fe_mag_corr_reg, fs_to_bits(cor.real(), 18));
+ _iface->poke32(_rx_fe_phase_corr_reg, fs_to_bits(cor.imag(), 18));
}
void populate_subtree(uhd::property_tree::sptr subtree)
@@ -198,11 +204,16 @@ private:
double _adc_rate;
fe_connection_t _fe_conn;
wb_iface::sptr _iface;
- const size_t _base;
+ const size_t _rx_fe_mag_corr_reg;
+ const size_t _rx_fe_phase_corr_reg;
+ const size_t _rx_fe_offset_i_reg;
+ const size_t _rx_fe_offset_q_reg;
+ const size_t _rx_fe_mapping_reg;
+ const size_t _rx_fe_het_cordic_phase_reg;
};
rx_frontend_core_3000::sptr rx_frontend_core_3000::make(
- wb_iface::sptr iface, const size_t base)
+ wb_iface::sptr iface, const size_t base, const size_t reg_offset)
{
- return sptr(new rx_frontend_core_3000_impl(iface, base));
+ return sptr(new rx_frontend_core_3000_impl(iface, base, reg_offset));
}