aboutsummaryrefslogtreecommitdiffstats
path: root/host/lib/usrp
diff options
context:
space:
mode:
authorBrent Stapleton <brent.stapleton@ettus.com>2019-07-19 12:10:22 -0700
committerMartin Braun <martin.braun@ettus.com>2019-08-25 19:22:06 -0700
commit0956ed4ea9371beeda95ccec02751528a93bec74 (patch)
tree3ea473a2a702f77f1ece0cf0ce14cca35ac7954d /host/lib/usrp
parent3c977dcecc39ee1d2a17d1aa3bbc864a3ffb5681 (diff)
downloaduhd-0956ed4ea9371beeda95ccec02751528a93bec74.tar.gz
uhd-0956ed4ea9371beeda95ccec02751528a93bec74.tar.bz2
uhd-0956ed4ea9371beeda95ccec02751528a93bec74.zip
rx_fe_3000: formatting for upcoming changes
Diffstat (limited to 'host/lib/usrp')
-rw-r--r--host/lib/usrp/cores/rx_frontend_core_3000.cpp186
1 files changed, 102 insertions, 84 deletions
diff --git a/host/lib/usrp/cores/rx_frontend_core_3000.cpp b/host/lib/usrp/cores/rx_frontend_core_3000.cpp
index 15c65ad03..7f88a3e98 100644
--- a/host/lib/usrp/cores/rx_frontend_core_3000.cpp
+++ b/host/lib/usrp/cores/rx_frontend_core_3000.cpp
@@ -8,69 +8,78 @@
#include <uhd/types/dict.hpp>
#include <uhd/types/ranges.hpp>
#include <uhd/utils/math.hpp>
-#include <uhdlib/usrp/cores/rx_frontend_core_3000.hpp>
#include <uhdlib/usrp/cores/dsp_core_utils.hpp>
-#include <boost/math/special_functions/round.hpp>
+#include <uhdlib/usrp/cores/rx_frontend_core_3000.hpp>
#include <boost/assign/list_of.hpp>
#include <boost/bind.hpp>
+#include <boost/math/special_functions/round.hpp>
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 FLAG_DSP_RX_MAPPING_SWAP_IQ (1 << 0)
-#define FLAG_DSP_RX_MAPPING_REAL_MODE (1 << 1)
-#define FLAG_DSP_RX_MAPPING_INVERT_Q (1 << 2)
-#define FLAG_DSP_RX_MAPPING_INVERT_I (1 << 3)
-#define FLAG_DSP_RX_MAPPING_REAL_DECIM (1 << 4)
+#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 FLAG_DSP_RX_MAPPING_SWAP_IQ (1 << 0)
+#define FLAG_DSP_RX_MAPPING_REAL_MODE (1 << 1)
+#define FLAG_DSP_RX_MAPPING_INVERT_Q (1 << 2)
+#define FLAG_DSP_RX_MAPPING_INVERT_I (1 << 3)
+#define FLAG_DSP_RX_MAPPING_REAL_DECIM (1 << 4)
//#define FLAG_DSP_RX_MAPPING_RESERVED (1 << 5)
//#define FLAG_DSP_RX_MAPPING_RESERVED (1 << 6)
-#define FLAG_DSP_RX_MAPPING_BYPASS_ALL (1 << 7)
+#define FLAG_DSP_RX_MAPPING_BYPASS_ALL (1 << 7)
#define OFFSET_FIXED (1ul << 31)
-#define OFFSET_SET (1ul << 30)
+#define OFFSET_SET (1ul << 30)
#define FLAG_MASK (OFFSET_FIXED | OFFSET_SET)
namespace {
- static const double DC_OFFSET_MIN = -1.0;
- static const double DC_OFFSET_MAX = 1.0;
-}
+static const double DC_OFFSET_MIN = -1.0;
+static const double DC_OFFSET_MAX = 1.0;
+} // namespace
using namespace uhd::usrp;
-static uint32_t fs_to_bits(const double num, const size_t bits){
- return int32_t(boost::math::round(num * (1 << (bits-1))));
+static uint32_t fs_to_bits(const double num, const size_t bits)
+{
+ return int32_t(boost::math::round(num * (1 << (bits - 1))));
}
-rx_frontend_core_3000::~rx_frontend_core_3000(void){
+rx_frontend_core_3000::~rx_frontend_core_3000(void)
+{
/* NOP */
}
-const std::complex<double> rx_frontend_core_3000::DEFAULT_DC_OFFSET_VALUE = std::complex<double>(0.0, 0.0);
+const std::complex<double> rx_frontend_core_3000::DEFAULT_DC_OFFSET_VALUE =
+ std::complex<double>(0.0, 0.0);
const bool rx_frontend_core_3000::DEFAULT_DC_OFFSET_ENABLE = true;
-const std::complex<double> rx_frontend_core_3000::DEFAULT_IQ_BALANCE_VALUE = std::complex<double>(0.0, 0.0);
+const std::complex<double> rx_frontend_core_3000::DEFAULT_IQ_BALANCE_VALUE =
+ std::complex<double>(0.0, 0.0);
-class rx_frontend_core_3000_impl : public rx_frontend_core_3000{
+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):
- _i_dc_off(0), _q_dc_off(0),
- _adc_rate(0.0),
- _fe_conn(fe_connection_t("IQ")),
- _iface(iface), _base(base)
+ rx_frontend_core_3000_impl(wb_iface::sptr iface, const size_t base)
+ : _i_dc_off(0)
+ , _q_dc_off(0)
+ , _adc_rate(0.0)
+ , _fe_conn(fe_connection_t("IQ"))
+ , _iface(iface)
+ , _base(base)
{
- //NOP
+ // NOP
}
- void set_adc_rate(const double rate) {
+ void set_adc_rate(const double rate)
+ {
_adc_rate = rate;
}
- void bypass_all(bool bypass_en) {
+ void bypass_all(bool bypass_en)
+ {
if (bypass_en) {
_iface->poke32(REG_RX_FE_MAPPING, FLAG_DSP_RX_MAPPING_BYPASS_ALL);
} else {
@@ -78,45 +87,48 @@ public:
}
}
- void set_fe_connection(const fe_connection_t& fe_conn) {
+ void set_fe_connection(const fe_connection_t& fe_conn)
+ {
uint32_t mapping_reg_val = 0;
switch (fe_conn.get_sampling_mode()) {
- case fe_connection_t::REAL:
- mapping_reg_val = FLAG_DSP_RX_MAPPING_REAL_MODE;
- break;
- case fe_connection_t::HETERODYNE:
- mapping_reg_val = FLAG_DSP_RX_MAPPING_REAL_MODE|FLAG_DSP_RX_MAPPING_REAL_DECIM;
- break;
- default:
- mapping_reg_val = 0;
- break;
+ case fe_connection_t::REAL:
+ mapping_reg_val = FLAG_DSP_RX_MAPPING_REAL_MODE;
+ break;
+ case fe_connection_t::HETERODYNE:
+ mapping_reg_val = FLAG_DSP_RX_MAPPING_REAL_MODE
+ | FLAG_DSP_RX_MAPPING_REAL_DECIM;
+ break;
+ default:
+ mapping_reg_val = 0;
+ break;
}
- if (fe_conn.is_iq_swapped()) mapping_reg_val |= FLAG_DSP_RX_MAPPING_SWAP_IQ;
- if (fe_conn.is_i_inverted()) mapping_reg_val |= FLAG_DSP_RX_MAPPING_INVERT_I;
- if (fe_conn.is_q_inverted()) mapping_reg_val |= FLAG_DSP_RX_MAPPING_INVERT_Q;
+ if (fe_conn.is_iq_swapped())
+ mapping_reg_val |= FLAG_DSP_RX_MAPPING_SWAP_IQ;
+ if (fe_conn.is_i_inverted())
+ mapping_reg_val |= FLAG_DSP_RX_MAPPING_INVERT_I;
+ if (fe_conn.is_q_inverted())
+ mapping_reg_val |= FLAG_DSP_RX_MAPPING_INVERT_Q;
_iface->poke32(REG_RX_FE_MAPPING, mapping_reg_val);
- UHD_ASSERT_THROW(_adc_rate!=0.0)
+ UHD_ASSERT_THROW(_adc_rate != 0.0)
if (fe_conn.get_sampling_mode() == fe_connection_t::HETERODYNE) {
- //1. Remember the sign of the IF frequency.
+ // 1. Remember the sign of the IF frequency.
// It will be discarded in the next step
const int if_freq_sign = boost::math::sign(fe_conn.get_if_freq());
- //2. Map IF frequency to the range [0, _adc_rate)
+ // 2. Map IF frequency to the range [0, _adc_rate)
double if_freq = std::abs(std::fmod(fe_conn.get_if_freq(), _adc_rate));
- //3. Map IF frequency to the range [-_adc_rate/2, _adc_rate/2)
+ // 3. Map IF frequency to the range [-_adc_rate/2, _adc_rate/2)
// This is the aliased frequency
if (if_freq > (_adc_rate / 2.0)) {
if_freq -= _adc_rate;
}
- //4. Set DSP offset to spin the signal in the opposite
+ // 4. Set DSP offset to spin the signal in the opposite
// direction as the aliased frequency
const double cordic_freq = if_freq * (-if_freq_sign);
- UHD_ASSERT_THROW(
- uhd::math::fp_compare::fp_compare_epsilon<double>(4.0) ==
- std::abs(_adc_rate / cordic_freq)
- );
+ 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);
}
@@ -125,66 +137,72 @@ public:
_fe_conn = fe_conn;
}
- void set_dc_offset_auto(const bool enb) {
+ void set_dc_offset_auto(const bool enb)
+ {
_set_dc_offset(enb ? 0 : OFFSET_FIXED);
}
- std::complex<double> set_dc_offset(const std::complex<double> &off) {
+ std::complex<double> set_dc_offset(const std::complex<double>& off)
+ {
static const double scaler = double(1ul << 29);
- _i_dc_off = boost::math::iround(off.real()*scaler);
- _q_dc_off = boost::math::iround(off.imag()*scaler);
+ _i_dc_off = boost::math::iround(off.real() * scaler);
+ _q_dc_off = boost::math::iround(off.imag() * scaler);
_set_dc_offset(OFFSET_SET | OFFSET_FIXED);
- return std::complex<double>(_i_dc_off/scaler, _q_dc_off/scaler);
+ return std::complex<double>(_i_dc_off / scaler, _q_dc_off / scaler);
}
- void _set_dc_offset(const uint32_t flags) {
+ 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));
}
- void set_iq_balance(const std::complex<double> &cor) {
+ 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));
}
- void populate_subtree(uhd::property_tree::sptr subtree) {
+ void populate_subtree(uhd::property_tree::sptr subtree)
+ {
subtree->create<uhd::meta_range_t>("dc_offset/range")
- .set(meta_range_t(DC_OFFSET_MIN, DC_OFFSET_MAX))
- ;
- subtree->create<std::complex<double> >("dc_offset/value")
+ .set(meta_range_t(DC_OFFSET_MIN, DC_OFFSET_MAX));
+ subtree->create<std::complex<double>>("dc_offset/value")
.set(DEFAULT_DC_OFFSET_VALUE)
- .set_coercer(boost::bind(&rx_frontend_core_3000::set_dc_offset, this, _1))
- ;
+ .set_coercer(boost::bind(&rx_frontend_core_3000::set_dc_offset, this, _1));
subtree->create<bool>("dc_offset/enable")
.set(DEFAULT_DC_OFFSET_ENABLE)
- .add_coerced_subscriber(boost::bind(&rx_frontend_core_3000::set_dc_offset_auto, this, _1))
- ;
- subtree->create<std::complex<double> >("iq_balance/value")
+ .add_coerced_subscriber(
+ boost::bind(&rx_frontend_core_3000::set_dc_offset_auto, this, _1));
+ subtree->create<std::complex<double>>("iq_balance/value")
.set(DEFAULT_IQ_BALANCE_VALUE)
- .add_coerced_subscriber(boost::bind(&rx_frontend_core_3000::set_iq_balance, this, _1))
- ;
+ .add_coerced_subscriber(
+ boost::bind(&rx_frontend_core_3000::set_iq_balance, this, _1));
}
- double get_output_rate() {
+ double get_output_rate()
+ {
switch (_fe_conn.get_sampling_mode()) {
- case fe_connection_t::REAL:
- case fe_connection_t::HETERODYNE:
- return _adc_rate / 2;
- default:
- return _adc_rate;
+ case fe_connection_t::REAL:
+ case fe_connection_t::HETERODYNE:
+ return _adc_rate / 2;
+ default:
+ return _adc_rate;
}
}
private:
- int32_t _i_dc_off, _q_dc_off;
- double _adc_rate;
+ int32_t _i_dc_off, _q_dc_off;
+ double _adc_rate;
fe_connection_t _fe_conn;
- wb_iface::sptr _iface;
- const size_t _base;
+ wb_iface::sptr _iface;
+ const size_t _base;
};
-rx_frontend_core_3000::sptr rx_frontend_core_3000::make(wb_iface::sptr iface, const size_t base){
+rx_frontend_core_3000::sptr rx_frontend_core_3000::make(
+ wb_iface::sptr iface, const size_t base)
+{
return sptr(new rx_frontend_core_3000_impl(iface, base));
}