aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorMartin Braun <martin.braun@ettus.com>2019-05-20 18:37:42 -0700
committerMartin Braun <martin.braun@ettus.com>2019-05-22 15:35:15 -0700
commitdbfef2bcd770ec6f9d03b5c94960aa13177cf677 (patch)
tree773641659e303f4ae1390eeeaa6557ffffbc139f
parent441c97d33125e50e04c31229365698f121edde72 (diff)
downloaduhd-dbfef2bcd770ec6f9d03b5c94960aa13177cf677.tar.gz
uhd-dbfef2bcd770ec6f9d03b5c94960aa13177cf677.tar.bz2
uhd-dbfef2bcd770ec6f9d03b5c94960aa13177cf677.zip
cores: Use NSDMI consistently in ?x_dsp_core_3000.*
There are edge cases where the lack of initialization of _current_freq could crash libuhd. To resolve this, we initialize all elements of those cores to sensible values using NSDMI.
-rw-r--r--host/lib/usrp/cores/rx_dsp_core_3000.cpp22
-rw-r--r--host/lib/usrp/cores/tx_dsp_core_3000.cpp17
2 files changed, 16 insertions, 23 deletions
diff --git a/host/lib/usrp/cores/rx_dsp_core_3000.cpp b/host/lib/usrp/cores/rx_dsp_core_3000.cpp
index 191232541..46fce3f69 100644
--- a/host/lib/usrp/cores/rx_dsp_core_3000.cpp
+++ b/host/lib/usrp/cores/rx_dsp_core_3000.cpp
@@ -52,14 +52,6 @@ public:
rx_dsp_core_3000_impl(wb_iface::sptr iface, const size_t dsp_base, const bool is_b200)
: _iface(iface), _dsp_base(dsp_base), _is_b200(is_b200)
{
- // previously uninitialized - assuming zero for all
- _link_rate = _host_extra_scaling = _fxpt_scalar_correction = 0.0;
-
- // init to something so update method has reasonable defaults
- _scaling_adjustment = 1.0;
- _dsp_extra_scaling = 1.0;
- _tick_rate = 1.0;
- _dsp_freq_offset = 0.0;
}
~rx_dsp_core_3000_impl(void)
@@ -321,11 +313,15 @@ private:
wb_iface::sptr _iface;
const size_t _dsp_base;
const bool _is_b200; // TODO: Obsolete this when we switch to the new DDC on the B200
- double _tick_rate, _link_rate;
- double _scaling_adjustment, _dsp_extra_scaling, _host_extra_scaling,
- _fxpt_scalar_correction;
- double _dsp_freq_offset;
- double _current_freq;
+
+ double _dsp_freq_offset = 0.0;
+ double _tick_rate = 1.0;
+ double _link_rate = 0.0;
+ double _scaling_adjustment = 1.0;
+ double _dsp_extra_scaling = 1.0;
+ double _host_extra_scaling = 0.0;
+ double _fxpt_scalar_correction = 0.0;
+ double _current_freq = 0.0;
};
rx_dsp_core_3000::sptr rx_dsp_core_3000::make(
diff --git a/host/lib/usrp/cores/tx_dsp_core_3000.cpp b/host/lib/usrp/cores/tx_dsp_core_3000.cpp
index 029ca5c3d..be7593841 100644
--- a/host/lib/usrp/cores/tx_dsp_core_3000.cpp
+++ b/host/lib/usrp/cores/tx_dsp_core_3000.cpp
@@ -43,12 +43,6 @@ public:
tx_dsp_core_3000_impl(wb_iface::sptr iface, const size_t dsp_base)
: _iface(iface), _dsp_base(dsp_base)
{
- // previously uninitialized - assuming zero for all
- _link_rate = _host_extra_scaling = _fxpt_scalar_correction = 0.0;
-
- // init to something so update method has reasonable defaults
- _scaling_adjustment = 1.0;
- _dsp_extra_scaling = 1.0;
this->set_tick_rate(1.0);
}
@@ -205,10 +199,13 @@ public:
private:
wb_iface::sptr _iface;
const size_t _dsp_base;
- double _tick_rate, _link_rate;
- double _scaling_adjustment, _dsp_extra_scaling, _host_extra_scaling,
- _fxpt_scalar_correction;
- double _current_freq;
+ double _tick_rate = 1.0;
+ double _link_rate = 0.0;
+ double _scaling_adjustment = 1.0;
+ double _dsp_extra_scaling = 1.0;
+ double _host_extra_scaling = 0.0;
+ double _fxpt_scalar_correction = 0.0;
+ double _current_freq = 0.0;
};
tx_dsp_core_3000::sptr tx_dsp_core_3000::make(wb_iface::sptr iface, const size_t dsp_base)