From db7ff72a3371fb638461828bab1b14974d73e05f Mon Sep 17 00:00:00 2001 From: Josh Blum Date: Fri, 26 Apr 2013 10:52:29 -0700 Subject: uhd: Use the stream arg setting to correctly map the channels Currently we have been assuming channels are linearly mapped 0, 1, 2... reguardless of how the user has set the stream arg channels. This change makes channel n on the gr-uhd wrapper use the nth channel as set by the streamer channels. Using this, a user can properly use multiple usrp source or sink blocks for a single device and have each block correspond to a particular set of channels as defined by the streamer channels parameter. --- gr-uhd/lib/gr_uhd_usrp_source.cc | 32 +++++++++++++++++++++++++++++--- 1 file changed, 29 insertions(+), 3 deletions(-) (limited to 'gr-uhd/lib/gr_uhd_usrp_source.cc') diff --git a/gr-uhd/lib/gr_uhd_usrp_source.cc b/gr-uhd/lib/gr_uhd_usrp_source.cc index c6c82d56c..efb74d717 100644 --- a/gr-uhd/lib/gr_uhd_usrp_source.cc +++ b/gr-uhd/lib/gr_uhd_usrp_source.cc @@ -74,6 +74,7 @@ public: } uhd::dict get_usrp_info(size_t chan){ + chan = _stream_args.channels[chan]; #ifdef UHD_USRP_MULTI_USRP_GET_USRP_INFO_API return _dev->get_usrp_rx_info(chan); #else @@ -90,18 +91,21 @@ public: } void set_samp_rate(double rate){ - _dev->set_rx_rate(rate); + BOOST_FOREACH(const size_t chan, _stream_args.channels) + { + _dev->set_rx_rate(rate, chan); + } _samp_rate = this->get_samp_rate(); _tag_now = true; } double get_samp_rate(void){ - return _dev->get_rx_rate(); + return _dev->get_rx_rate(_stream_args.channels[0]); } uhd::meta_range_t get_samp_rates(void){ #ifdef UHD_USRP_MULTI_USRP_GET_RATES_API - return _dev->get_rx_rates(); + return _dev->get_rx_rates(_stream_args.channels[0]); #else throw std::runtime_error("not implemented in this version"); #endif @@ -110,6 +114,7 @@ public: uhd::tune_result_t set_center_freq( const uhd::tune_request_t tune_request, size_t chan ){ + chan = _stream_args.channels[chan]; const uhd::tune_result_t res = _dev->set_rx_freq(tune_request, chan); _center_freq = this->get_center_freq(chan); _tag_now = true; @@ -117,66 +122,82 @@ public: } double get_center_freq(size_t chan){ + chan = _stream_args.channels[chan]; return _dev->get_rx_freq(chan); } uhd::freq_range_t get_freq_range(size_t chan){ + chan = _stream_args.channels[chan]; return _dev->get_rx_freq_range(chan); } void set_gain(double gain, size_t chan){ + chan = _stream_args.channels[chan]; return _dev->set_rx_gain(gain, chan); } void set_gain(double gain, const std::string &name, size_t chan){ + chan = _stream_args.channels[chan]; return _dev->set_rx_gain(gain, name, chan); } double get_gain(size_t chan){ + chan = _stream_args.channels[chan]; return _dev->get_rx_gain(chan); } double get_gain(const std::string &name, size_t chan){ + chan = _stream_args.channels[chan]; return _dev->get_rx_gain(name, chan); } std::vector get_gain_names(size_t chan){ + chan = _stream_args.channels[chan]; return _dev->get_rx_gain_names(chan); } uhd::gain_range_t get_gain_range(size_t chan){ + chan = _stream_args.channels[chan]; return _dev->get_rx_gain_range(chan); } uhd::gain_range_t get_gain_range(const std::string &name, size_t chan){ + chan = _stream_args.channels[chan]; return _dev->get_rx_gain_range(name, chan); } void set_antenna(const std::string &ant, size_t chan){ + chan = _stream_args.channels[chan]; return _dev->set_rx_antenna(ant, chan); } std::string get_antenna(size_t chan){ + chan = _stream_args.channels[chan]; return _dev->get_rx_antenna(chan); } std::vector get_antennas(size_t chan){ + chan = _stream_args.channels[chan]; return _dev->get_rx_antennas(chan); } void set_bandwidth(double bandwidth, size_t chan){ + chan = _stream_args.channels[chan]; return _dev->set_rx_bandwidth(bandwidth, chan); } double get_bandwidth(size_t chan){ + chan = _stream_args.channels[chan]; return _dev->get_rx_bandwidth(chan); } uhd::freq_range_t get_bandwidth_range(size_t chan){ + chan = _stream_args.channels[chan]; return _dev->get_rx_bandwidth_range(chan); } void set_auto_dc_offset(const bool enable, size_t chan){ + chan = _stream_args.channels[chan]; #ifdef UHD_USRP_MULTI_USRP_FRONTEND_CAL_API return _dev->set_rx_dc_offset(enable, chan); #else @@ -185,6 +206,7 @@ public: } void set_dc_offset(const std::complex &offset, size_t chan){ + chan = _stream_args.channels[chan]; #ifdef UHD_USRP_MULTI_USRP_FRONTEND_CAL_API return _dev->set_rx_dc_offset(offset, chan); #else @@ -193,6 +215,7 @@ public: } void set_iq_balance(const std::complex &correction, size_t chan){ + chan = _stream_args.channels[chan]; #ifdef UHD_USRP_MULTI_USRP_FRONTEND_CAL_API return _dev->set_rx_iq_balance(correction, chan); #else @@ -201,10 +224,12 @@ public: } uhd::sensor_value_t get_sensor(const std::string &name, size_t chan){ + chan = _stream_args.channels[chan]; return _dev->get_rx_sensor(name, chan); } std::vector get_sensor_names(size_t chan){ + chan = _stream_args.channels[chan]; return _dev->get_rx_sensor_names(chan); } @@ -313,6 +338,7 @@ public: } uhd::usrp::dboard_iface::sptr get_dboard_iface(size_t chan){ + chan = _stream_args.channels[chan]; return _dev->get_rx_dboard_iface(chan); } -- cgit