aboutsummaryrefslogtreecommitdiffstats
path: root/host/lib/usrp/x300
diff options
context:
space:
mode:
Diffstat (limited to 'host/lib/usrp/x300')
-rw-r--r--host/lib/usrp/x300/x300_adc_ctrl.cpp11
-rw-r--r--host/lib/usrp/x300/x300_clock_ctrl.cpp27
-rw-r--r--host/lib/usrp/x300/x300_radio_control.cpp178
3 files changed, 114 insertions, 102 deletions
diff --git a/host/lib/usrp/x300/x300_adc_ctrl.cpp b/host/lib/usrp/x300/x300_adc_ctrl.cpp
index 26c1d85ff..afc581ce6 100644
--- a/host/lib/usrp/x300/x300_adc_ctrl.cpp
+++ b/host/lib/usrp/x300/x300_adc_ctrl.cpp
@@ -70,12 +70,12 @@ public:
this->send_ads62p48_reg(0x76);
}
- void reset()
+ void reset() override
{
init();
}
- double set_gain(const double& gain)
+ double set_gain(const double& gain) override
{
const meta_range_t gain_range = meta_range_t(0, 6.0, 0.5);
const int gain_bits = int((gain_range.clip(gain) * 2.0) + 0.5);
@@ -86,8 +86,9 @@ public:
return gain_bits / 2;
}
- void set_test_word(
- const std::string& patterna, const std::string& patternb, const uint32_t num)
+ void set_test_word(const std::string& patterna,
+ const std::string& patternb,
+ const uint32_t num) override
{
_ads62p48_regs.custom_pattern_low = num & 0xff;
_ads62p48_regs.custom_pattern_high = num >> 8;
@@ -117,7 +118,7 @@ public:
this->send_ads62p48_reg(0x75);
}
- ~x300_adc_ctrl_impl(void)
+ ~x300_adc_ctrl_impl(void) override
{
_ads62p48_regs.power_down = ads62p48_regs_t::POWER_DOWN_GLOBAL;
UHD_SAFE_CALL(this->send_ads62p48_reg(0x40);)
diff --git a/host/lib/usrp/x300/x300_clock_ctrl.cpp b/host/lib/usrp/x300/x300_clock_ctrl.cpp
index 9b54b001b..6452df365 100644
--- a/host/lib/usrp/x300/x300_clock_ctrl.cpp
+++ b/host/lib/usrp/x300/x300_clock_ctrl.cpp
@@ -70,7 +70,7 @@ x300_clock_ctrl::~x300_clock_ctrl(void)
class x300_clock_ctrl_impl : public x300_clock_ctrl
{
public:
- ~x300_clock_ctrl_impl(void) {}
+ ~x300_clock_ctrl_impl(void) override {}
x300_clock_ctrl_impl(uhd::spi_iface::sptr spiface,
const size_t slaveno,
@@ -88,7 +88,7 @@ public:
init();
}
- void reset_clocks()
+ void reset_clocks() override
{
_lmk04816_regs.RESET = lmk04816_regs_t::RESET_RESET;
this->write_regs(0);
@@ -113,23 +113,23 @@ public:
this->write_regs(11);
}
- double get_master_clock_rate(void)
+ double get_master_clock_rate(void) override
{
return _master_clock_rate;
}
- double get_sysref_clock_rate(void)
+ double get_sysref_clock_rate(void) override
{
return _system_ref_rate;
}
- double get_refout_clock_rate(void)
+ double get_refout_clock_rate(void) override
{
// We support only one reference output rate
return X300_REF_CLK_OUT_RATE;
}
- void set_dboard_rate(const x300_clock_which_t which, double rate)
+ void set_dboard_rate(const x300_clock_which_t which, double rate) override
{
uint16_t div = uint16_t(_vco_freq / rate);
uint16_t* reg = NULL;
@@ -174,7 +174,7 @@ public:
sync_clocks();
}
- double get_dboard_rate(const x300_clock_which_t which)
+ double get_dboard_rate(const x300_clock_which_t which) override
{
double rate = 0.0;
switch (which) {
@@ -192,7 +192,7 @@ public:
return rate;
}
- std::vector<double> get_dboard_rates(const x300_clock_which_t)
+ std::vector<double> get_dboard_rates(const x300_clock_which_t) override
{
std::vector<double> rates;
for (size_t div = size_t(_vco_freq / _master_clock_rate);
@@ -202,7 +202,7 @@ public:
return rates;
}
- void enable_dboard_clock(const x300_clock_which_t which, const bool enable)
+ void enable_dboard_clock(const x300_clock_which_t which, const bool enable) override
{
switch (which) {
case X300_CLOCK_WHICH_DB0_RX:
@@ -250,7 +250,7 @@ public:
}
}
- void set_ref_out(const bool enable)
+ void set_ref_out(const bool enable) override
{
// TODO Implement divider configuration to allow for configurable output
// rates
@@ -267,8 +267,9 @@ public:
_spiface->write_spi(_slaveno, spi_config_t::EDGE_RISE, data, 32);
}
- double set_clock_delay(
- const x300_clock_which_t which, const double delay_ns, const bool resync = true)
+ double set_clock_delay(const x300_clock_which_t which,
+ const double delay_ns,
+ const bool resync = true) override
{
// All dividers have are delayed by 5 taps by default. The delay
// set by this function is relative to the 5 tap delay
@@ -461,7 +462,7 @@ public:
return coerced_delay;
}
- double get_clock_delay(const x300_clock_which_t which)
+ double get_clock_delay(const x300_clock_which_t which) override
{
switch (which) {
case X300_CLOCK_WHICH_FPGA:
diff --git a/host/lib/usrp/x300/x300_radio_control.cpp b/host/lib/usrp/x300/x300_radio_control.cpp
index 36813d044..3ab60e661 100644
--- a/host/lib/usrp/x300/x300_radio_control.cpp
+++ b/host/lib/usrp/x300/x300_radio_control.cpp
@@ -219,7 +219,7 @@ public:
}
} /* ctor */
- ~x300_radio_control_impl()
+ ~x300_radio_control_impl() override
{
// nop
}
@@ -227,7 +227,7 @@ public:
/**************************************************************************
* Radio API calls
*************************************************************************/
- double set_rate(double rate)
+ double set_rate(double rate) override
{
// On X3x0, tick rate can't actually be changed at runtime
const double actual_rate = get_rate();
@@ -239,7 +239,7 @@ public:
return actual_rate;
}
- void set_tx_antenna(const std::string& ant, const size_t chan)
+ void set_tx_antenna(const std::string& ant, const size_t chan) override
{
// Antenna changes may result in a change of streaming mode for LF/Basic dboards
if (_basic_lf_tx) {
@@ -256,14 +256,14 @@ public:
.set(ant);
}
- std::string get_tx_antenna(const size_t chan) const
+ std::string get_tx_antenna(const size_t chan) const override
{
return get_tree()
->access<std::string>(get_db_path("tx", chan) / "antenna" / "value")
.get();
}
- std::vector<std::string> get_tx_antennas(size_t chan) const
+ std::vector<std::string> get_tx_antennas(size_t chan) const override
{
return get_tree()
->access<std::vector<std::string>>(
@@ -271,7 +271,7 @@ public:
.get();
}
- void set_rx_antenna(const std::string& ant, const size_t chan)
+ void set_rx_antenna(const std::string& ant, const size_t chan) override
{
// Antenna changes may result in a change of streaming mode for LF/Basic dboards
if (_basic_lf_rx) {
@@ -290,14 +290,14 @@ public:
.set(ant);
}
- std::string get_rx_antenna(const size_t chan) const
+ std::string get_rx_antenna(const size_t chan) const override
{
return get_tree()
->access<std::string>(get_db_path("rx", chan) / "antenna" / "value")
.get();
}
- std::vector<std::string> get_rx_antennas(size_t chan) const
+ std::vector<std::string> get_rx_antennas(size_t chan) const override
{
return get_tree()
->access<std::vector<std::string>>(
@@ -305,7 +305,7 @@ public:
.get();
}
- double set_tx_frequency(const double freq, const size_t chan)
+ double set_tx_frequency(const double freq, const size_t chan) override
{
return get_tree()
->access<double>(get_db_path("tx", chan) / "freq" / "value")
@@ -313,7 +313,7 @@ public:
.get();
}
- void set_tx_tune_args(const uhd::device_addr_t& tune_args, const size_t chan)
+ void set_tx_tune_args(const uhd::device_addr_t& tune_args, const size_t chan) override
{
if (get_tree()->exists(get_db_path("tx", chan) / "tune_args")) {
get_tree()
@@ -322,14 +322,14 @@ public:
}
}
- double get_tx_frequency(const size_t chan)
+ double get_tx_frequency(const size_t chan) override
{
return get_tree()
->access<double>(get_db_path("tx", chan) / "freq" / "value")
.get();
}
- double set_rx_frequency(const double freq, const size_t chan)
+ double set_rx_frequency(const double freq, const size_t chan) override
{
RFNOC_LOG_TRACE(
"set_rx_frequency(freq=" << (freq / 1e6) << " MHz, chan=" << chan << ")");
@@ -339,7 +339,7 @@ public:
.get();
}
- void set_rx_tune_args(const uhd::device_addr_t& tune_args, const size_t chan)
+ void set_rx_tune_args(const uhd::device_addr_t& tune_args, const size_t chan) override
{
if (get_tree()->exists(get_db_path("rx", chan) / "tune_args")) {
get_tree()
@@ -348,21 +348,21 @@ public:
}
}
- double get_rx_frequency(const size_t chan)
+ double get_rx_frequency(const size_t chan) override
{
return get_tree()
->access<double>(get_db_path("rx", chan) / "freq" / "value")
.get();
}
- uhd::freq_range_t get_tx_frequency_range(const size_t chan) const
+ uhd::freq_range_t get_tx_frequency_range(const size_t chan) const override
{
return get_tree()
->access<uhd::freq_range_t>(get_db_path("tx", chan) / "freq" / "range")
.get();
}
- uhd::freq_range_t get_rx_frequency_range(const size_t chan) const
+ uhd::freq_range_t get_rx_frequency_range(const size_t chan) const override
{
return get_tree()
->access<uhd::meta_range_t>(get_db_path("rx", chan) / "freq" / "range")
@@ -370,7 +370,7 @@ public:
}
/*** Bandwidth-Related APIs************************************************/
- double set_rx_bandwidth(const double bandwidth, const size_t chan)
+ double set_rx_bandwidth(const double bandwidth, const size_t chan) override
{
return get_tree()
->access<double>(get_db_path("rx", chan) / "bandwidth" / "value")
@@ -378,21 +378,21 @@ public:
.get();
}
- double get_rx_bandwidth(const size_t chan)
+ double get_rx_bandwidth(const size_t chan) override
{
return get_tree()
->access<double>(get_db_path("rx", chan) / "bandwidth" / "value")
.get();
}
- uhd::meta_range_t get_rx_bandwidth_range(size_t chan) const
+ uhd::meta_range_t get_rx_bandwidth_range(size_t chan) const override
{
return get_tree()
->access<uhd::meta_range_t>(get_db_path("rx", chan) / "bandwidth" / "range")
.get();
}
- double set_tx_bandwidth(const double bandwidth, const size_t chan)
+ double set_tx_bandwidth(const double bandwidth, const size_t chan) override
{
return get_tree()
->access<double>(get_db_path("tx", chan) / "bandwidth" / "value")
@@ -400,14 +400,14 @@ public:
.get();
}
- double get_tx_bandwidth(const size_t chan)
+ double get_tx_bandwidth(const size_t chan) override
{
return get_tree()
->access<double>(get_db_path("tx", chan) / "bandwidth" / "value")
.get();
}
- uhd::meta_range_t get_tx_bandwidth_range(size_t chan) const
+ uhd::meta_range_t get_tx_bandwidth_range(size_t chan) const override
{
return get_tree()
->access<uhd::meta_range_t>(get_db_path("tx", chan) / "bandwidth" / "range")
@@ -415,12 +415,13 @@ public:
}
/*** Gain-Related APIs ***************************************************/
- double set_tx_gain(const double gain, const size_t chan)
+ double set_tx_gain(const double gain, const size_t chan) override
{
return set_tx_gain(gain, ALL_GAINS, chan);
}
- double set_tx_gain(const double gain, const std::string& name, const size_t chan)
+ double set_tx_gain(
+ const double gain, const std::string& name, const size_t chan) override
{
_tx_pwr_mgr.at(chan)->set_tracking_mode(pwr_cal_mgr::tracking_mode::TRACK_GAIN);
if (_tx_gain_groups.count(chan)) {
@@ -431,12 +432,13 @@ public:
return radio_control_impl::set_tx_gain(0.0, chan);
}
- double set_rx_gain(const double gain, const size_t chan)
+ double set_rx_gain(const double gain, const size_t chan) override
{
return set_rx_gain(gain, ALL_GAINS, chan);
}
- double set_rx_gain(const double gain, const std::string& name, const size_t chan)
+ double set_rx_gain(
+ const double gain, const std::string& name, const size_t chan) override
{
_rx_pwr_mgr.at(chan)->set_tracking_mode(pwr_cal_mgr::tracking_mode::TRACK_GAIN);
auto& gg = _rx_gain_groups.at(chan);
@@ -444,42 +446,43 @@ public:
return radio_control_impl::set_rx_gain(gg->get_value(name), chan);
}
- double get_rx_gain(const size_t chan)
+ double get_rx_gain(const size_t chan) override
{
return get_rx_gain(ALL_GAINS, chan);
}
- double get_rx_gain(const std::string& name, const size_t chan)
+ double get_rx_gain(const std::string& name, const size_t chan) override
{
return _rx_gain_groups.at(chan)->get_value(name);
}
- double get_tx_gain(const size_t chan)
+ double get_tx_gain(const size_t chan) override
{
return get_tx_gain(ALL_GAINS, chan);
}
- double get_tx_gain(const std::string& name, const size_t chan)
+ double get_tx_gain(const std::string& name, const size_t chan) override
{
return _tx_gain_groups.at(chan)->get_value(name);
}
- std::vector<std::string> get_tx_gain_names(const size_t chan) const
+ std::vector<std::string> get_tx_gain_names(const size_t chan) const override
{
return _tx_gain_groups.at(chan)->get_names();
}
- std::vector<std::string> get_rx_gain_names(const size_t chan) const
+ std::vector<std::string> get_rx_gain_names(const size_t chan) const override
{
return _rx_gain_groups.at(chan)->get_names();
}
- uhd::gain_range_t get_tx_gain_range(const size_t chan) const
+ uhd::gain_range_t get_tx_gain_range(const size_t chan) const override
{
return get_tx_gain_range(ALL_GAINS, chan);
}
- uhd::gain_range_t get_tx_gain_range(const std::string& name, const size_t chan) const
+ uhd::gain_range_t get_tx_gain_range(
+ const std::string& name, const size_t chan) const override
{
if (!_tx_gain_groups.count(chan)) {
throw uhd::index_error(
@@ -488,12 +491,13 @@ public:
return _tx_gain_groups.at(chan)->get_range(name);
}
- uhd::gain_range_t get_rx_gain_range(const size_t chan) const
+ uhd::gain_range_t get_rx_gain_range(const size_t chan) const override
{
return get_rx_gain_range(ALL_GAINS, chan);
}
- uhd::gain_range_t get_rx_gain_range(const std::string& name, const size_t chan) const
+ uhd::gain_range_t get_rx_gain_range(
+ const std::string& name, const size_t chan) const override
{
if (!_rx_gain_groups.count(chan)) {
throw uhd::index_error(
@@ -502,7 +506,7 @@ public:
return _rx_gain_groups.at(chan)->get_range(name);
}
- std::vector<std::string> get_tx_gain_profile_names(const size_t chan) const
+ std::vector<std::string> get_tx_gain_profile_names(const size_t chan) const override
{
return get_tree()
->access<std::vector<std::string>>(
@@ -510,7 +514,7 @@ public:
.get();
}
- std::vector<std::string> get_rx_gain_profile_names(const size_t chan) const
+ std::vector<std::string> get_rx_gain_profile_names(const size_t chan) const override
{
return get_tree()
->access<std::vector<std::string>>(
@@ -519,14 +523,14 @@ public:
}
- void set_tx_gain_profile(const std::string& profile, const size_t chan)
+ void set_tx_gain_profile(const std::string& profile, const size_t chan) override
{
get_tree()
->access<std::string>(get_db_path("tx", chan) / "gains/all/profile/value")
.set(profile);
}
- void set_rx_gain_profile(const std::string& profile, const size_t chan)
+ void set_rx_gain_profile(const std::string& profile, const size_t chan) override
{
get_tree()
->access<std::string>(get_db_path("rx", chan) / "gains/all/profile/value")
@@ -534,14 +538,14 @@ public:
}
- std::string get_tx_gain_profile(const size_t chan) const
+ std::string get_tx_gain_profile(const size_t chan) const override
{
return get_tree()
->access<std::string>(get_db_path("tx", chan) / "gains/all/profile/value")
.get();
}
- std::string get_rx_gain_profile(const size_t chan) const
+ std::string get_rx_gain_profile(const size_t chan) const override
{
return get_tree()
->access<std::string>(get_db_path("rx", chan) / "gains/all/profile/value")
@@ -551,7 +555,7 @@ public:
/**************************************************************************
* LO controls
*************************************************************************/
- std::vector<std::string> get_rx_lo_names(const size_t chan) const
+ std::vector<std::string> get_rx_lo_names(const size_t chan) const override
{
fs_path rx_fe_fe_root = get_db_path("rx", chan);
std::vector<std::string> lo_names;
@@ -564,7 +568,7 @@ public:
}
std::vector<std::string> get_rx_lo_sources(
- const std::string& name, const size_t chan) const
+ const std::string& name, const size_t chan) const override
{
fs_path rx_fe_fe_root = get_db_path("rx", chan);
@@ -597,7 +601,7 @@ public:
}
void set_rx_lo_source(
- const std::string& src, const std::string& name, const size_t chan)
+ const std::string& src, const std::string& name, const size_t chan) override
{
fs_path rx_fe_fe_root = get_db_path("rx", chan);
@@ -631,7 +635,8 @@ public:
}
}
- const std::string get_rx_lo_source(const std::string& name, const size_t chan)
+ const std::string get_rx_lo_source(
+ const std::string& name, const size_t chan) override
{
fs_path rx_fe_fe_root = get_db_path("rx", chan);
@@ -659,7 +664,7 @@ public:
}
void set_rx_lo_export_enabled(
- bool enabled, const std::string& name, const size_t chan)
+ bool enabled, const std::string& name, const size_t chan) override
{
fs_path rx_fe_fe_root = get_db_path("rx", chan);
@@ -691,7 +696,8 @@ public:
}
}
- bool get_rx_lo_export_enabled(const std::string& name, const size_t chan) const
+ bool get_rx_lo_export_enabled(
+ const std::string& name, const size_t chan) const override
{
fs_path rx_fe_fe_root = get_db_path("rx", chan);
@@ -716,7 +722,8 @@ public:
}
}
- double set_rx_lo_freq(double freq, const std::string& name, const size_t chan)
+ double set_rx_lo_freq(
+ double freq, const std::string& name, const size_t chan) override
{
fs_path rx_fe_fe_root = get_db_path("rx", chan);
@@ -742,7 +749,7 @@ public:
}
}
- double get_rx_lo_freq(const std::string& name, const size_t chan)
+ double get_rx_lo_freq(const std::string& name, const size_t chan) override
{
fs_path rx_fe_fe_root = get_db_path("rx", chan);
@@ -765,7 +772,8 @@ public:
}
}
- freq_range_t get_rx_lo_freq_range(const std::string& name, const size_t chan) const
+ freq_range_t get_rx_lo_freq_range(
+ const std::string& name, const size_t chan) const override
{
fs_path rx_fe_fe_root = get_db_path("rx", chan);
@@ -792,7 +800,7 @@ public:
}
/*** Calibration API *****************************************************/
- void set_tx_dc_offset(const std::complex<double>& offset, size_t chan)
+ void set_tx_dc_offset(const std::complex<double>& offset, size_t chan) override
{
const fs_path dc_offset_path = get_fe_path("tx", chan) / "dc_offset" / "value";
if (get_tree()->exists(dc_offset_path)) {
@@ -802,7 +810,7 @@ public:
}
}
- meta_range_t get_tx_dc_offset_range(size_t chan) const
+ meta_range_t get_tx_dc_offset_range(size_t chan) const override
{
const fs_path range_path = get_fe_path("tx", chan) / "dc_offset" / "range";
if (get_tree()->exists(range_path)) {
@@ -814,7 +822,7 @@ public:
}
}
- void set_tx_iq_balance(const std::complex<double>& correction, size_t chan)
+ void set_tx_iq_balance(const std::complex<double>& correction, size_t chan) override
{
const fs_path iq_balance_path = get_fe_path("tx", chan) / "iq_balance" / "value";
if (get_tree()->exists(iq_balance_path)) {
@@ -824,7 +832,7 @@ public:
}
}
- void set_rx_dc_offset(const bool enb, size_t chan)
+ void set_rx_dc_offset(const bool enb, size_t chan) override
{
const fs_path dc_offset_path = get_fe_path("rx", chan) / "dc_offset" / "enable";
if (get_tree()->exists(dc_offset_path)) {
@@ -835,7 +843,7 @@ public:
}
}
- void set_rx_dc_offset(const std::complex<double>& offset, size_t chan)
+ void set_rx_dc_offset(const std::complex<double>& offset, size_t chan) override
{
const fs_path dc_offset_path = get_fe_path("rx", chan) / "dc_offset" / "value";
if (get_tree()->exists(dc_offset_path)) {
@@ -845,7 +853,7 @@ public:
}
}
- meta_range_t get_rx_dc_offset_range(size_t chan) const
+ meta_range_t get_rx_dc_offset_range(size_t chan) const override
{
const fs_path range_path = get_fe_path("rx", chan) / "dc_offset" / "range";
if (get_tree()->exists(range_path)) {
@@ -857,7 +865,7 @@ public:
}
}
- void set_rx_iq_balance(const bool enb, size_t chan)
+ void set_rx_iq_balance(const bool enb, size_t chan) override
{
const fs_path iq_balance_path = get_fe_path("rx", chan) / "iq_balance" / "enable";
if (get_tree()->exists(iq_balance_path)) {
@@ -867,7 +875,7 @@ public:
}
}
- void set_rx_iq_balance(const std::complex<double>& correction, size_t chan)
+ void set_rx_iq_balance(const std::complex<double>& correction, size_t chan) override
{
const fs_path iq_balance_path = get_fe_path("rx", chan) / "iq_balance" / "value";
if (get_tree()->exists(iq_balance_path)) {
@@ -878,13 +886,13 @@ public:
}
/*** GPIO API ************************************************************/
- std::vector<std::string> get_gpio_banks() const
+ std::vector<std::string> get_gpio_banks() const override
{
return {"RX", "TX", "FP0"};
}
void set_gpio_attr(
- const std::string& bank, const std::string& attr, const uint32_t value)
+ const std::string& bank, const std::string& attr, const uint32_t value) override
{
if (bank == "FP0") {
_fp_gpio->set_gpio_attr(usrp::gpio_atr::gpio_attr_rev_map.at(attr), value);
@@ -921,7 +929,7 @@ public:
<< "'. Ignoring call to set_gpio_attr() to retain backward compatibility.");
}
- uint32_t get_gpio_attr(const std::string& bank, const std::string& attr)
+ uint32_t get_gpio_attr(const std::string& bank, const std::string& attr) override
{
if (bank == "FP0") {
return _fp_gpio->get_attr_reg(usrp::gpio_atr::gpio_attr_rev_map.at(attr));
@@ -959,7 +967,7 @@ public:
/**************************************************************************
* Sensor API
*************************************************************************/
- std::vector<std::string> get_rx_sensor_names(size_t chan) const
+ std::vector<std::string> get_rx_sensor_names(size_t chan) const override
{
const fs_path sensor_path = get_db_path("rx", chan) / "sensors";
if (get_tree()->exists(sensor_path)) {
@@ -968,14 +976,14 @@ public:
return {};
}
- uhd::sensor_value_t get_rx_sensor(const std::string& name, size_t chan)
+ uhd::sensor_value_t get_rx_sensor(const std::string& name, size_t chan) override
{
return get_tree()
->access<uhd::sensor_value_t>(get_db_path("rx", chan) / "sensors" / name)
.get();
}
- std::vector<std::string> get_tx_sensor_names(size_t chan) const
+ std::vector<std::string> get_tx_sensor_names(size_t chan) const override
{
const fs_path sensor_path = get_db_path("tx", chan) / "sensors";
if (get_tree()->exists(sensor_path)) {
@@ -984,7 +992,7 @@ public:
return {};
}
- uhd::sensor_value_t get_tx_sensor(const std::string& name, size_t chan)
+ uhd::sensor_value_t get_tx_sensor(const std::string& name, size_t chan) override
{
return get_tree()
->access<uhd::sensor_value_t>(get_db_path("tx", chan) / "sensors" / name)
@@ -994,7 +1002,7 @@ public:
/**************************************************************************
* EEPROM API
*************************************************************************/
- void set_db_eeprom(const uhd::eeprom_map_t& db_eeprom)
+ void set_db_eeprom(const uhd::eeprom_map_t& db_eeprom) override
{
const std::string key_prefix = db_eeprom.count("rx_id") ? "rx_" : "tx_";
const std::string id_key = key_prefix + "id";
@@ -1021,7 +1029,7 @@ public:
}
- uhd::eeprom_map_t get_db_eeprom()
+ uhd::eeprom_map_t get_db_eeprom() override
{
uhd::eeprom_map_t result;
if (get_tree()->exists(DB_PATH / "rx_eeprom")) {
@@ -1044,13 +1052,13 @@ public:
/**************************************************************************
* Radio Identification API Calls
*************************************************************************/
- std::string get_slot_name() const
+ std::string get_slot_name() const override
{
return _radio_type == PRIMARY ? "A" : "B";
}
size_t get_chan_from_dboard_fe(
- const std::string& fe, const uhd::direction_t direction) const
+ const std::string& fe, const uhd::direction_t direction) const override
{
switch (direction) {
case uhd::TX_DIRECTION:
@@ -1063,7 +1071,7 @@ public:
}
std::string get_dboard_fe_from_chan(
- const size_t chan, const uhd::direction_t direction) const
+ const size_t chan, const uhd::direction_t direction) const override
{
switch (direction) {
case uhd::TX_DIRECTION:
@@ -1075,7 +1083,8 @@ public:
}
}
- std::string get_fe_name(const size_t chan, const uhd::direction_t direction) const
+ std::string get_fe_name(
+ const size_t chan, const uhd::direction_t direction) const override
{
fs_path name_path =
get_db_path(direction == uhd::RX_DIRECTION ? "rx" : "tx", chan) / "name";
@@ -1087,7 +1096,7 @@ public:
}
- virtual void set_command_time(uhd::time_spec_t time, const size_t chan)
+ void set_command_time(uhd::time_spec_t time, const size_t chan) override
{
node_t::set_command_time(time, chan);
// This is for TwinRX only:
@@ -1100,30 +1109,31 @@ public:
/**************************************************************************
* MB Interface API Calls
*************************************************************************/
- uint32_t get_adc_rx_word()
+ uint32_t get_adc_rx_word() override
{
return regs().peek32(regmap::RADIO_BASE_ADDR + regmap::REG_RX_DATA);
}
- void set_adc_test_word(const std::string& patterna, const std::string& patternb)
+ void set_adc_test_word(
+ const std::string& patterna, const std::string& patternb) override
{
_adc->set_test_word(patterna, patternb);
}
- void set_adc_checker_enabled(const bool enb)
+ void set_adc_checker_enabled(const bool enb) override
{
_regs->misc_outs_reg.write(
radio_regmap_t::misc_outs_reg_t::ADC_CHECKER_ENABLED, enb ? 1 : 0);
}
- bool get_adc_checker_locked(const bool I)
+ bool get_adc_checker_locked(const bool I) override
{
return bool(_regs->misc_ins_reg.read(
I ? radio_regmap_t::misc_ins_reg_t::ADC_CHECKER1_I_LOCKED
: radio_regmap_t::misc_ins_reg_t::ADC_CHECKER1_Q_LOCKED));
}
- uint32_t get_adc_checker_error_code(const bool I)
+ uint32_t get_adc_checker_error_code(const bool I) override
{
return _regs->misc_ins_reg.get(
I ? radio_regmap_t::misc_ins_reg_t::ADC_CHECKER1_I_ERROR
@@ -1131,7 +1141,7 @@ public:
}
// Documented in x300_radio_mbc_iface.hpp
- void self_test_adc(const uint32_t ramp_time_ms)
+ void self_test_adc(const uint32_t ramp_time_ms) override
{
RFNOC_LOG_DEBUG("Running ADC self-cal...");
// Bypass all front-end corrections
@@ -1208,12 +1218,12 @@ public:
}
}
- void sync_dac()
+ void sync_dac() override
{
_dac->sync();
}
- void set_dac_sync(const bool enb, const uhd::time_spec_t& time)
+ void set_dac_sync(const bool enb, const uhd::time_spec_t& time) override
{
if (time != uhd::time_spec_t(0.0)) {
set_command_time(time, 0);
@@ -1225,7 +1235,7 @@ public:
}
}
- void dac_verify_sync()
+ void dac_verify_sync() override
{
_dac->verify_sync();
}
@@ -1816,7 +1826,7 @@ private:
//! Safely shut down all peripherals
//
// Reminder: After this is called, no peeks and pokes are allowed!
- void deinit()
+ void deinit() override
{
RFNOC_LOG_TRACE("deinit()");
// Reset daughterboard
@@ -1840,7 +1850,7 @@ private:
}
bool check_topology(const std::vector<size_t>& connected_inputs,
- const std::vector<size_t>& connected_outputs)
+ const std::vector<size_t>& connected_outputs) override
{
RFNOC_LOG_TRACE("check_topology()");
if (!node_t::check_topology(connected_inputs, connected_outputs)) {