diff options
Diffstat (limited to 'host/lib/usrp/usrp2')
| -rw-r--r-- | host/lib/usrp/usrp2/CMakeLists.txt | 2 | ||||
| -rw-r--r-- | host/lib/usrp/usrp2/dboard_iface.cpp | 81 | ||||
| -rw-r--r-- | host/lib/usrp/usrp2/usrp2_impl.cpp | 93 | ||||
| -rw-r--r-- | host/lib/usrp/usrp2/usrp2_impl.hpp | 1 | 
4 files changed, 105 insertions, 72 deletions
diff --git a/host/lib/usrp/usrp2/CMakeLists.txt b/host/lib/usrp/usrp2/CMakeLists.txt index d9894adaf..edf77a654 100644 --- a/host/lib/usrp/usrp2/CMakeLists.txt +++ b/host/lib/usrp/usrp2/CMakeLists.txt @@ -22,8 +22,6 @@  ########################################################################  # Conditionally configure the USRP2 support  ######################################################################## -LIBUHD_REGISTER_COMPONENT("USRP2" ENABLE_USRP2 ON "ENABLE_LIBUHD" OFF OFF) -  IF(ENABLE_USRP2)      LIBUHD_APPEND_SOURCES(          ${CMAKE_CURRENT_SOURCE_DIR}/clock_ctrl.cpp diff --git a/host/lib/usrp/usrp2/dboard_iface.cpp b/host/lib/usrp/usrp2/dboard_iface.cpp index 7bb69c7b7..a6ba1e0b7 100644 --- a/host/lib/usrp/usrp2/dboard_iface.cpp +++ b/host/lib/usrp/usrp2/dboard_iface.cpp @@ -1,5 +1,5 @@  // -// Copyright 2010-2012,2015 Ettus Research LLC +// Copyright 2010-2012,2015,2016 Ettus Research LLC  //  // This program is free software: you can redistribute it and/or modify  // it under the terms of the GNU General Public License as published by @@ -54,12 +54,16 @@ public:      void write_aux_dac(unit_t, aux_dac_t, double);      double read_aux_adc(unit_t, aux_adc_t); -    void _set_pin_ctrl(unit_t, boost::uint16_t); -    void _set_atr_reg(unit_t, atr_reg_t, boost::uint16_t); -    void _set_gpio_ddr(unit_t, boost::uint16_t); -    void _set_gpio_out(unit_t, boost::uint16_t); -    void set_gpio_debug(unit_t, int); -    boost::uint16_t read_gpio(unit_t); +    void set_pin_ctrl(unit_t unit, boost::uint32_t value, boost::uint32_t mask = 0xffffffff); +    boost::uint32_t get_pin_ctrl(unit_t unit); +    void set_atr_reg(unit_t unit, atr_reg_t reg, boost::uint32_t value, boost::uint32_t mask = 0xffffffff); +    boost::uint32_t get_atr_reg(unit_t unit, atr_reg_t reg); +    void set_gpio_ddr(unit_t unit, boost::uint32_t value, boost::uint32_t mask = 0xffffffff); +    boost::uint32_t get_gpio_ddr(unit_t unit); +    void set_gpio_out(unit_t unit, boost::uint32_t value, boost::uint32_t mask = 0xffffffff); +    boost::uint32_t get_gpio_out(unit_t unit); +    boost::uint32_t read_gpio(unit_t unit); +      void set_command_time(const uhd::time_spec_t& t);      uhd::time_spec_t get_command_time(void); @@ -71,6 +75,7 @@ public:      std::vector<double> get_clock_rates(unit_t);      void set_clock_enabled(unit_t, bool);      double get_codec_rate(unit_t); +    void set_fe_connection(unit_t unit, const std::string&, const fe_connection_t& fe_conn);      void write_spi(          unit_t unit, @@ -149,18 +154,22 @@ usrp2_dboard_iface::~usrp2_dboard_iface(void){   * Clocks   **********************************************************************/  void usrp2_dboard_iface::set_clock_rate(unit_t unit, double rate){ +    if (unit == UNIT_BOTH) throw uhd::runtime_error("UNIT_BOTH not supported.");      _clock_rates[unit] = rate; //set to shadow      switch(unit){      case UNIT_RX: _clock_ctrl->set_rate_rx_dboard_clock(rate); return;      case UNIT_TX: _clock_ctrl->set_rate_tx_dboard_clock(rate); return; +    default: UHD_THROW_INVALID_CODE_PATH();      }  }  double usrp2_dboard_iface::get_clock_rate(unit_t unit){ +    if (unit == UNIT_BOTH) throw uhd::runtime_error("UNIT_BOTH not supported.");      return _clock_rates[unit]; //get from shadow  }  std::vector<double> usrp2_dboard_iface::get_clock_rates(unit_t unit){ +    if (unit == UNIT_BOTH) throw uhd::runtime_error("UNIT_BOTH not supported.");      switch(unit){      case UNIT_RX: return _clock_ctrl->get_rates_rx_dboard_clock();      case UNIT_TX: return _clock_ctrl->get_rates_tx_dboard_clock(); @@ -169,40 +178,56 @@ std::vector<double> usrp2_dboard_iface::get_clock_rates(unit_t unit){  }  void usrp2_dboard_iface::set_clock_enabled(unit_t unit, bool enb){ +    if (unit == UNIT_BOTH) throw uhd::runtime_error("UNIT_BOTH not supported.");      switch(unit){ -    case UNIT_RX: _clock_ctrl->enable_rx_dboard_clock(enb); return; -    case UNIT_TX: _clock_ctrl->enable_tx_dboard_clock(enb); return; +    case UNIT_RX:   _clock_ctrl->enable_rx_dboard_clock(enb); return; +    case UNIT_TX:   _clock_ctrl->enable_tx_dboard_clock(enb); return; +    case UNIT_BOTH: set_clock_enabled(UNIT_RX, enb); set_clock_enabled(UNIT_TX, enb); return;      }  } -double usrp2_dboard_iface::get_codec_rate(unit_t){ +double usrp2_dboard_iface::get_codec_rate(unit_t unit){ +    if (unit == UNIT_BOTH) throw uhd::runtime_error("UNIT_BOTH not supported.");      return _clock_ctrl->get_master_clock_rate();  } +  /***********************************************************************   * GPIO   **********************************************************************/ -void usrp2_dboard_iface::_set_pin_ctrl(unit_t unit, boost::uint16_t value){ -    return _gpio->set_pin_ctrl(unit, value); +void usrp2_dboard_iface::set_pin_ctrl(unit_t unit, boost::uint32_t value, boost::uint32_t mask){ +    _gpio->set_pin_ctrl(unit, static_cast<boost::uint16_t>(value), static_cast<boost::uint16_t>(mask));  } -void usrp2_dboard_iface::_set_gpio_ddr(unit_t unit, boost::uint16_t value){ -    return _gpio->set_gpio_ddr(unit, value); +boost::uint32_t usrp2_dboard_iface::get_pin_ctrl(unit_t unit){ +    return static_cast<boost::uint32_t>(_gpio->get_pin_ctrl(unit));  } -void usrp2_dboard_iface::_set_gpio_out(unit_t unit, boost::uint16_t value){ -    return _gpio->set_gpio_out(unit, value); +void usrp2_dboard_iface::set_atr_reg(unit_t unit, atr_reg_t reg, boost::uint32_t value, boost::uint32_t mask){ +    _gpio->set_atr_reg(unit, reg, static_cast<boost::uint16_t>(value), static_cast<boost::uint16_t>(mask));  } -boost::uint16_t usrp2_dboard_iface::read_gpio(unit_t unit){ -    return _gpio->read_gpio(unit); +boost::uint32_t usrp2_dboard_iface::get_atr_reg(unit_t unit, atr_reg_t reg){ +    return static_cast<boost::uint32_t>(_gpio->get_atr_reg(unit, reg)); +} + +void usrp2_dboard_iface::set_gpio_ddr(unit_t unit, boost::uint32_t value, boost::uint32_t mask){ +    _gpio->set_gpio_ddr(unit, static_cast<boost::uint16_t>(value), static_cast<boost::uint16_t>(mask)); +} + +boost::uint32_t usrp2_dboard_iface::get_gpio_ddr(unit_t unit){ +    return static_cast<boost::uint32_t>(_gpio->get_gpio_ddr(unit));  } -void usrp2_dboard_iface::_set_atr_reg(unit_t unit, atr_reg_t atr, boost::uint16_t value){ -    return _gpio->set_atr_reg(unit, atr, value); +void usrp2_dboard_iface::set_gpio_out(unit_t unit, boost::uint32_t value, boost::uint32_t mask){ +    _gpio->set_gpio_out(unit, static_cast<boost::uint16_t>(value), static_cast<boost::uint16_t>(mask));  } -void usrp2_dboard_iface::set_gpio_debug(unit_t, int){ -    throw uhd::not_implemented_error("no set_gpio_debug implemented"); +boost::uint32_t usrp2_dboard_iface::get_gpio_out(unit_t unit){ +    return static_cast<boost::uint32_t>(_gpio->get_gpio_out(unit)); +} + +boost::uint32_t usrp2_dboard_iface::read_gpio(unit_t unit){ +    return _gpio->read_gpio(unit);  }  /*********************************************************************** @@ -219,6 +244,7 @@ void usrp2_dboard_iface::write_spi(      boost::uint32_t data,      size_t num_bits  ){ +    if (unit == UNIT_BOTH) throw uhd::runtime_error("UNIT_BOTH not supported.");      _spi_iface->write_spi(unit_to_spi_dev[unit], config, data, num_bits);  } @@ -228,6 +254,7 @@ boost::uint32_t usrp2_dboard_iface::read_write_spi(      boost::uint32_t data,      size_t num_bits  ){ +    if (unit == UNIT_BOTH) throw uhd::runtime_error("UNIT_BOTH not supported.");      return _spi_iface->read_spi(unit_to_spi_dev[unit], config, data, num_bits);  } @@ -250,6 +277,7 @@ void usrp2_dboard_iface::_write_aux_dac(unit_t unit){          (UNIT_RX, SPI_SS_RX_DAC)          (UNIT_TX, SPI_SS_TX_DAC)      ; +    if (unit == UNIT_BOTH) throw uhd::runtime_error("UNIT_BOTH not supported.");      _spi_iface->write_spi(          unit_to_spi_dac[unit], spi_config_t::EDGE_FALL,          _dac_regs[unit].get_reg(), 24 @@ -257,6 +285,8 @@ void usrp2_dboard_iface::_write_aux_dac(unit_t unit){  }  void usrp2_dboard_iface::write_aux_dac(unit_t unit, aux_dac_t which, double value){ +    if (unit == UNIT_BOTH) throw uhd::runtime_error("UNIT_BOTH not supported."); +      _dac_regs[unit].data = boost::math::iround(4095*value/3.3);      _dac_regs[unit].cmd = ad5623_regs_t::CMD_WR_UP_DAC_CHAN_N; @@ -285,6 +315,8 @@ double usrp2_dboard_iface::read_aux_adc(unit_t unit, aux_adc_t which){          (UNIT_TX, SPI_SS_TX_ADC)      ; +    if (unit == UNIT_BOTH) throw uhd::runtime_error("UNIT_BOTH not supported."); +      //setup spi config args      spi_config_t config;      config.mosi_edge = spi_config_t::EDGE_FALL; @@ -320,3 +352,8 @@ void usrp2_dboard_iface::set_command_time(const uhd::time_spec_t& t)  {      _wb_iface->set_time(t);  } + +void usrp2_dboard_iface::set_fe_connection(unit_t, const std::string&, const fe_connection_t&) +{ +    throw uhd::not_implemented_error("fe connection configuration support not implemented"); +} diff --git a/host/lib/usrp/usrp2/usrp2_impl.cpp b/host/lib/usrp/usrp2/usrp2_impl.cpp index 7b59dfaf1..b0c29392c 100644 --- a/host/lib/usrp/usrp2/usrp2_impl.cpp +++ b/host/lib/usrp/usrp2/usrp2_impl.cpp @@ -474,15 +474,15 @@ usrp2_impl::usrp2_impl(const device_addr_t &_device_addr) :          ////////////////////////////////////////////////////////////////          _tree->create<mboard_eeprom_t>(mb_path / "eeprom")              .set(_mbc[mb].iface->mb_eeprom) -            .subscribe(boost::bind(&usrp2_impl::set_mb_eeprom, this, mb, _1)); +            .add_coerced_subscriber(boost::bind(&usrp2_impl::set_mb_eeprom, this, mb, _1));          ////////////////////////////////////////////////////////////////          // create clock control objects          ////////////////////////////////////////////////////////////////          _mbc[mb].clock = usrp2_clock_ctrl::make(_mbc[mb].iface, _mbc[mb].spiface);          _tree->create<double>(mb_path / "tick_rate") -            .publish(boost::bind(&usrp2_clock_ctrl::get_master_clock_rate, _mbc[mb].clock)) -            .subscribe(boost::bind(&usrp2_impl::update_tick_rate, this, _1)); +            .set_publisher(boost::bind(&usrp2_clock_ctrl::get_master_clock_rate, _mbc[mb].clock)) +            .add_coerced_subscriber(boost::bind(&usrp2_impl::update_tick_rate, this, _1));          ////////////////////////////////////////////////////////////////          // create codec control objects @@ -500,10 +500,10 @@ usrp2_impl::usrp2_impl(const device_addr_t &_device_addr) :              _tree->create<std::string>(rx_codec_path / "name").set("ads62p44");              _tree->create<meta_range_t>(rx_codec_path / "gains/digital/range").set(meta_range_t(0, 6.0, 0.5));              _tree->create<double>(rx_codec_path / "gains/digital/value") -                .subscribe(boost::bind(&usrp2_codec_ctrl::set_rx_digital_gain, _mbc[mb].codec, _1)).set(0); +                .add_coerced_subscriber(boost::bind(&usrp2_codec_ctrl::set_rx_digital_gain, _mbc[mb].codec, _1)).set(0);              _tree->create<meta_range_t>(rx_codec_path / "gains/fine/range").set(meta_range_t(0, 0.5, 0.05));              _tree->create<double>(rx_codec_path / "gains/fine/value") -                .subscribe(boost::bind(&usrp2_codec_ctrl::set_rx_digital_fine_gain, _mbc[mb].codec, _1)).set(0); +                .add_coerced_subscriber(boost::bind(&usrp2_codec_ctrl::set_rx_digital_fine_gain, _mbc[mb].codec, _1)).set(0);          }break;          case usrp2_iface::USRP2_REV3: @@ -550,7 +550,7 @@ usrp2_impl::usrp2_impl(const device_addr_t &_device_addr) :                  BOOST_FOREACH(const std::string &name, _mbc[mb].gps->get_sensors())                  {                      _tree->create<sensor_value_t>(mb_path / "sensors" / name) -                        .publish(boost::bind(&gps_ctrl::get_sensor, _mbc[mb].gps, name)); +                        .set_publisher(boost::bind(&gps_ctrl::get_sensor, _mbc[mb].gps, name));                  }              }              else @@ -563,9 +563,9 @@ usrp2_impl::usrp2_impl(const device_addr_t &_device_addr) :          // and do the misc mboard sensors          ////////////////////////////////////////////////////////////////          _tree->create<sensor_value_t>(mb_path / "sensors/mimo_locked") -            .publish(boost::bind(&usrp2_impl::get_mimo_locked, this, mb)); +            .set_publisher(boost::bind(&usrp2_impl::get_mimo_locked, this, mb));          _tree->create<sensor_value_t>(mb_path / "sensors/ref_locked") -            .publish(boost::bind(&usrp2_impl::get_ref_locked, this, mb)); +            .set_publisher(boost::bind(&usrp2_impl::get_ref_locked, this, mb));          ////////////////////////////////////////////////////////////////          // create frontend control objects @@ -578,27 +578,27 @@ usrp2_impl::usrp2_impl(const device_addr_t &_device_addr) :          );          _tree->create<subdev_spec_t>(mb_path / "rx_subdev_spec") -            .subscribe(boost::bind(&usrp2_impl::update_rx_subdev_spec, this, mb, _1)); +            .add_coerced_subscriber(boost::bind(&usrp2_impl::update_rx_subdev_spec, this, mb, _1));          _tree->create<subdev_spec_t>(mb_path / "tx_subdev_spec") -            .subscribe(boost::bind(&usrp2_impl::update_tx_subdev_spec, this, mb, _1)); +            .add_coerced_subscriber(boost::bind(&usrp2_impl::update_tx_subdev_spec, this, mb, _1));          const fs_path rx_fe_path = mb_path / "rx_frontends" / "A";          const fs_path tx_fe_path = mb_path / "tx_frontends" / "A";          _tree->create<std::complex<double> >(rx_fe_path / "dc_offset" / "value") -            .coerce(boost::bind(&rx_frontend_core_200::set_dc_offset, _mbc[mb].rx_fe, _1)) +            .set_coercer(boost::bind(&rx_frontend_core_200::set_dc_offset, _mbc[mb].rx_fe, _1))              .set(std::complex<double>(0.0, 0.0));          _tree->create<bool>(rx_fe_path / "dc_offset" / "enable") -            .subscribe(boost::bind(&rx_frontend_core_200::set_dc_offset_auto, _mbc[mb].rx_fe, _1)) +            .add_coerced_subscriber(boost::bind(&rx_frontend_core_200::set_dc_offset_auto, _mbc[mb].rx_fe, _1))              .set(true);          _tree->create<std::complex<double> >(rx_fe_path / "iq_balance" / "value") -            .subscribe(boost::bind(&rx_frontend_core_200::set_iq_balance, _mbc[mb].rx_fe, _1)) +            .add_coerced_subscriber(boost::bind(&rx_frontend_core_200::set_iq_balance, _mbc[mb].rx_fe, _1))              .set(std::complex<double>(0.0, 0.0));          _tree->create<std::complex<double> >(tx_fe_path / "dc_offset" / "value") -            .coerce(boost::bind(&tx_frontend_core_200::set_dc_offset, _mbc[mb].tx_fe, _1)) +            .set_coercer(boost::bind(&tx_frontend_core_200::set_dc_offset, _mbc[mb].tx_fe, _1))              .set(std::complex<double>(0.0, 0.0));          _tree->create<std::complex<double> >(tx_fe_path / "iq_balance" / "value") -            .subscribe(boost::bind(&tx_frontend_core_200::set_iq_balance, _mbc[mb].tx_fe, _1)) +            .add_coerced_subscriber(boost::bind(&tx_frontend_core_200::set_iq_balance, _mbc[mb].tx_fe, _1))              .set(std::complex<double>(0.0, 0.0));          //////////////////////////////////////////////////////////////// @@ -613,20 +613,20 @@ usrp2_impl::usrp2_impl(const device_addr_t &_device_addr) :          for (size_t dspno = 0; dspno < _mbc[mb].rx_dsps.size(); dspno++){              _mbc[mb].rx_dsps[dspno]->set_link_rate(USRP2_LINK_RATE_BPS);              _tree->access<double>(mb_path / "tick_rate") -                .subscribe(boost::bind(&rx_dsp_core_200::set_tick_rate, _mbc[mb].rx_dsps[dspno], _1)); +                .add_coerced_subscriber(boost::bind(&rx_dsp_core_200::set_tick_rate, _mbc[mb].rx_dsps[dspno], _1));              fs_path rx_dsp_path = mb_path / str(boost::format("rx_dsps/%u") % dspno);              _tree->create<meta_range_t>(rx_dsp_path / "rate/range") -                .publish(boost::bind(&rx_dsp_core_200::get_host_rates, _mbc[mb].rx_dsps[dspno])); +                .set_publisher(boost::bind(&rx_dsp_core_200::get_host_rates, _mbc[mb].rx_dsps[dspno]));              _tree->create<double>(rx_dsp_path / "rate/value")                  .set(1e6) //some default -                .coerce(boost::bind(&rx_dsp_core_200::set_host_rate, _mbc[mb].rx_dsps[dspno], _1)) -                .subscribe(boost::bind(&usrp2_impl::update_rx_samp_rate, this, mb, dspno, _1)); +                .set_coercer(boost::bind(&rx_dsp_core_200::set_host_rate, _mbc[mb].rx_dsps[dspno], _1)) +                .add_coerced_subscriber(boost::bind(&usrp2_impl::update_rx_samp_rate, this, mb, dspno, _1));              _tree->create<double>(rx_dsp_path / "freq/value") -                .coerce(boost::bind(&rx_dsp_core_200::set_freq, _mbc[mb].rx_dsps[dspno], _1)); +                .set_coercer(boost::bind(&rx_dsp_core_200::set_freq, _mbc[mb].rx_dsps[dspno], _1));              _tree->create<meta_range_t>(rx_dsp_path / "freq/range") -                .publish(boost::bind(&rx_dsp_core_200::get_freq_range, _mbc[mb].rx_dsps[dspno])); +                .set_publisher(boost::bind(&rx_dsp_core_200::get_freq_range, _mbc[mb].rx_dsps[dspno]));              _tree->create<stream_cmd_t>(rx_dsp_path / "stream_cmd") -                .subscribe(boost::bind(&rx_dsp_core_200::issue_stream_command, _mbc[mb].rx_dsps[dspno], _1)); +                .add_coerced_subscriber(boost::bind(&rx_dsp_core_200::issue_stream_command, _mbc[mb].rx_dsps[dspno], _1));          }          //////////////////////////////////////////////////////////////// @@ -637,17 +637,17 @@ usrp2_impl::usrp2_impl(const device_addr_t &_device_addr) :          );          _mbc[mb].tx_dsp->set_link_rate(USRP2_LINK_RATE_BPS);          _tree->access<double>(mb_path / "tick_rate") -            .subscribe(boost::bind(&tx_dsp_core_200::set_tick_rate, _mbc[mb].tx_dsp, _1)); +            .add_coerced_subscriber(boost::bind(&tx_dsp_core_200::set_tick_rate, _mbc[mb].tx_dsp, _1));          _tree->create<meta_range_t>(mb_path / "tx_dsps/0/rate/range") -            .publish(boost::bind(&tx_dsp_core_200::get_host_rates, _mbc[mb].tx_dsp)); +            .set_publisher(boost::bind(&tx_dsp_core_200::get_host_rates, _mbc[mb].tx_dsp));          _tree->create<double>(mb_path / "tx_dsps/0/rate/value")              .set(1e6) //some default -            .coerce(boost::bind(&tx_dsp_core_200::set_host_rate, _mbc[mb].tx_dsp, _1)) -            .subscribe(boost::bind(&usrp2_impl::update_tx_samp_rate, this, mb, 0, _1)); +            .set_coercer(boost::bind(&tx_dsp_core_200::set_host_rate, _mbc[mb].tx_dsp, _1)) +            .add_coerced_subscriber(boost::bind(&usrp2_impl::update_tx_samp_rate, this, mb, 0, _1));          _tree->create<double>(mb_path / "tx_dsps/0/freq/value") -            .coerce(boost::bind(&tx_dsp_core_200::set_freq, _mbc[mb].tx_dsp, _1)); +            .set_coercer(boost::bind(&tx_dsp_core_200::set_freq, _mbc[mb].tx_dsp, _1));          _tree->create<meta_range_t>(mb_path / "tx_dsps/0/freq/range") -            .publish(boost::bind(&tx_dsp_core_200::get_freq_range, _mbc[mb].tx_dsp)); +            .set_publisher(boost::bind(&tx_dsp_core_200::get_freq_range, _mbc[mb].tx_dsp));          //setup dsp flow control          const double ups_per_sec = device_args_i.cast<double>("ups_per_sec", 20); @@ -670,22 +670,22 @@ usrp2_impl::usrp2_impl(const device_addr_t &_device_addr) :              _mbc[mb].wbiface, U2_REG_SR_ADDR(SR_TIME64), time64_rb_bases, mimo_clock_sync_delay_cycles          );          _tree->access<double>(mb_path / "tick_rate") -            .subscribe(boost::bind(&time64_core_200::set_tick_rate, _mbc[mb].time64, _1)); +            .add_coerced_subscriber(boost::bind(&time64_core_200::set_tick_rate, _mbc[mb].time64, _1));          _tree->create<time_spec_t>(mb_path / "time/now") -            .publish(boost::bind(&time64_core_200::get_time_now, _mbc[mb].time64)) -            .subscribe(boost::bind(&time64_core_200::set_time_now, _mbc[mb].time64, _1)); +            .set_publisher(boost::bind(&time64_core_200::get_time_now, _mbc[mb].time64)) +            .add_coerced_subscriber(boost::bind(&time64_core_200::set_time_now, _mbc[mb].time64, _1));          _tree->create<time_spec_t>(mb_path / "time/pps") -            .publish(boost::bind(&time64_core_200::get_time_last_pps, _mbc[mb].time64)) -            .subscribe(boost::bind(&time64_core_200::set_time_next_pps, _mbc[mb].time64, _1)); +            .set_publisher(boost::bind(&time64_core_200::get_time_last_pps, _mbc[mb].time64)) +            .add_coerced_subscriber(boost::bind(&time64_core_200::set_time_next_pps, _mbc[mb].time64, _1));          //setup time source props          _tree->create<std::string>(mb_path / "time_source/value") -            .subscribe(boost::bind(&time64_core_200::set_time_source, _mbc[mb].time64, _1)) +            .add_coerced_subscriber(boost::bind(&time64_core_200::set_time_source, _mbc[mb].time64, _1))              .set("none");          _tree->create<std::vector<std::string> >(mb_path / "time_source/options") -            .publish(boost::bind(&time64_core_200::get_time_sources, _mbc[mb].time64)); +            .set_publisher(boost::bind(&time64_core_200::get_time_sources, _mbc[mb].time64));          //setup reference source props          _tree->create<std::string>(mb_path / "clock_source/value") -            .subscribe(boost::bind(&usrp2_impl::update_clock_source, this, mb, _1)) +            .add_coerced_subscriber(boost::bind(&usrp2_impl::update_clock_source, this, mb, _1))              .set("internal");          std::vector<std::string> clock_sources = boost::assign::list_of("internal")("external")("mimo");          if (_mbc[mb].gps and _mbc[mb].gps->gps_detected()) clock_sources.push_back("gpsdo"); @@ -697,18 +697,18 @@ usrp2_impl::usrp2_impl(const device_addr_t &_device_addr) :          case usrp2_iface::USRP_N200_R4:          case usrp2_iface::USRP_N210_R4:              _tree->create<time_spec_t>(mb_path / "time/cmd") -                .subscribe(boost::bind(&usrp2_fifo_ctrl::set_time, _mbc[mb].fifo_ctrl, _1)); +                .add_coerced_subscriber(boost::bind(&usrp2_fifo_ctrl::set_time, _mbc[mb].fifo_ctrl, _1));          default: break; //otherwise, do not register          }          _tree->access<double>(mb_path / "tick_rate") -            .subscribe(boost::bind(&usrp2_fifo_ctrl::set_tick_rate, _mbc[mb].fifo_ctrl, _1)); +            .add_coerced_subscriber(boost::bind(&usrp2_fifo_ctrl::set_tick_rate, _mbc[mb].fifo_ctrl, _1));          ////////////////////////////////////////////////////////////////////          // create user-defined control objects          ////////////////////////////////////////////////////////////////////          _mbc[mb].user = user_settings_core_200::make(_mbc[mb].wbiface, U2_REG_SR_ADDR(SR_USER_REGS));          _tree->create<user_settings_core_200::user_reg_t>(mb_path / "user/regs") -            .subscribe(boost::bind(&user_settings_core_200::set_reg, _mbc[mb].user, _1)); +            .add_coerced_subscriber(boost::bind(&user_settings_core_200::set_reg, _mbc[mb].user, _1));          ////////////////////////////////////////////////////////////////          // create dboard control objects @@ -726,32 +726,31 @@ usrp2_impl::usrp2_impl(const device_addr_t &_device_addr) :          //create the properties and register subscribers          _tree->create<dboard_eeprom_t>(mb_path / "dboards/A/rx_eeprom")              .set(rx_db_eeprom) -            .subscribe(boost::bind(&usrp2_impl::set_db_eeprom, this, mb, "rx", _1)); +            .add_coerced_subscriber(boost::bind(&usrp2_impl::set_db_eeprom, this, mb, "rx", _1));          _tree->create<dboard_eeprom_t>(mb_path / "dboards/A/tx_eeprom")              .set(tx_db_eeprom) -            .subscribe(boost::bind(&usrp2_impl::set_db_eeprom, this, mb, "tx", _1)); +            .add_coerced_subscriber(boost::bind(&usrp2_impl::set_db_eeprom, this, mb, "tx", _1));          _tree->create<dboard_eeprom_t>(mb_path / "dboards/A/gdb_eeprom")              .set(gdb_eeprom) -            .subscribe(boost::bind(&usrp2_impl::set_db_eeprom, this, mb, "gdb", _1)); +            .add_coerced_subscriber(boost::bind(&usrp2_impl::set_db_eeprom, this, mb, "gdb", _1));          //create a new dboard interface and manager -        _mbc[mb].dboard_iface = make_usrp2_dboard_iface(_mbc[mb].wbiface, _mbc[mb].iface/*i2c*/, _mbc[mb].spiface, _mbc[mb].clock); -        _tree->create<dboard_iface::sptr>(mb_path / "dboards/A/iface").set(_mbc[mb].dboard_iface);          _mbc[mb].dboard_manager = dboard_manager::make(              rx_db_eeprom.id, tx_db_eeprom.id, gdb_eeprom.id, -            _mbc[mb].dboard_iface, _tree->subtree(mb_path / "dboards/A") +            make_usrp2_dboard_iface(_mbc[mb].wbiface, _mbc[mb].iface/*i2c*/, _mbc[mb].spiface, _mbc[mb].clock), +            _tree->subtree(mb_path / "dboards/A")          );          //bind frontend corrections to the dboard freq props          const fs_path db_tx_fe_path = mb_path / "dboards" / "A" / "tx_frontends";          BOOST_FOREACH(const std::string &name, _tree->list(db_tx_fe_path)){              _tree->access<double>(db_tx_fe_path / name / "freq" / "value") -                .subscribe(boost::bind(&usrp2_impl::set_tx_fe_corrections, this, mb, _1)); +                .add_coerced_subscriber(boost::bind(&usrp2_impl::set_tx_fe_corrections, this, mb, _1));          }          const fs_path db_rx_fe_path = mb_path / "dboards" / "A" / "rx_frontends";          BOOST_FOREACH(const std::string &name, _tree->list(db_rx_fe_path)){              _tree->access<double>(db_rx_fe_path / name / "freq" / "value") -                .subscribe(boost::bind(&usrp2_impl::set_rx_fe_corrections, this, mb, _1)); +                .add_coerced_subscriber(boost::bind(&usrp2_impl::set_rx_fe_corrections, this, mb, _1));          }      } diff --git a/host/lib/usrp/usrp2/usrp2_impl.hpp b/host/lib/usrp/usrp2/usrp2_impl.hpp index 07cd98b4c..47fcec657 100644 --- a/host/lib/usrp/usrp2/usrp2_impl.hpp +++ b/host/lib/usrp/usrp2/usrp2_impl.hpp @@ -102,7 +102,6 @@ private:          uhd::transport::zero_copy_if::sptr tx_dsp_xport;          uhd::transport::zero_copy_if::sptr fifo_ctrl_xport;          uhd::usrp::dboard_manager::sptr dboard_manager; -        uhd::usrp::dboard_iface::sptr dboard_iface;          size_t rx_chan_occ, tx_chan_occ;          mb_container_type(void): rx_chan_occ(0), tx_chan_occ(0){}      };  | 
