USRP Hardware Driver and USRP Manual  Version: 003.010.001.HEAD-0-g929e3b32
UHD and USRP Manual
multi_usrp.hpp
Go to the documentation of this file.
1 //
2 // Copyright 2010-2012,2014-2015 Ettus Research LLC
3 //
4 // This program is free software: you can redistribute it and/or modify
5 // it under the terms of the GNU General Public License as published by
6 // the Free Software Foundation, either version 3 of the License, or
7 // (at your option) any later version.
8 //
9 // This program is distributed in the hope that it will be useful,
10 // but WITHOUT ANY WARRANTY; without even the implied warranty of
11 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
12 // GNU General Public License for more details.
13 //
14 // You should have received a copy of the GNU General Public License
15 // along with this program. If not, see <http://www.gnu.org/licenses/>.
16 //
17 
18 #ifndef INCLUDED_UHD_USRP_MULTI_USRP_HPP
19 #define INCLUDED_UHD_USRP_MULTI_USRP_HPP
20 
21 //define API capabilities for compile time detection of new features
22 #define UHD_USRP_MULTI_USRP_REF_SOURCES_API
23 #define UHD_USRP_MULTI_USRP_GET_RATES_API
24 #define UHD_USRP_MULTI_USRP_FRONTEND_CAL_API
25 #define UHD_USRP_MULTI_USRP_FRONTEND_IQ_AUTO_API
26 #define UHD_USRP_MULTI_USRP_COMMAND_TIME_API
27 #define UHD_USRP_MULTI_USRP_BW_RANGE_API
28 #define UHD_USRP_MULTI_USRP_USER_REGS_API
29 #define UHD_USRP_MULTI_USRP_GET_USRP_INFO_API
30 #define UHD_USRP_MULTI_USRP_NORMALIZED_GAIN
31 #define UHD_USRP_MULTI_USRP_GPIO_API
32 #define UHD_USRP_MULTI_USRP_REGISTER_API
33 #define UHD_USRP_MULTI_USRP_FILTER_API
34 #define UHD_USRP_MULTI_USRP_LO_CONFIG_API
35 
36 #include <uhd/config.hpp>
37 #include <uhd/device.hpp>
38 #include <uhd/deprecated.hpp>
39 #include <uhd/types/ranges.hpp>
40 #include <uhd/types/stream_cmd.hpp>
43 #include <uhd/types/sensors.hpp>
44 #include <uhd/types/filters.hpp>
45 #include <uhd/usrp/subdev_spec.hpp>
47 #include <boost/shared_ptr.hpp>
48 #include <boost/utility.hpp>
49 #include <complex>
50 #include <string>
51 #include <vector>
52 
53 namespace uhd{ namespace usrp{
54 
101 class UHD_API multi_usrp : boost::noncopyable{
102 public:
103  typedef boost::shared_ptr<multi_usrp> sptr;
104 
105  virtual ~multi_usrp(void) = 0;
106 
108  static const size_t ALL_MBOARDS = size_t(~0);
109 
111  static const size_t ALL_CHANS = size_t(~0);
112 
114  static const std::string ALL_GAINS;
115 
117  static const std::string ALL_LOS;
118 
124  static sptr make(const device_addr_t &dev_addr);
125 
131  virtual device::sptr get_device(void) = 0;
132 
134  virtual rx_streamer::sptr get_rx_stream(const stream_args_t &args) = 0;
135 
137  virtual tx_streamer::sptr get_tx_stream(const stream_args_t &args) = 0;
138 
146  virtual dict<std::string, std::string> get_usrp_rx_info(size_t chan = 0) = 0;
147 
155  virtual dict<std::string, std::string> get_usrp_tx_info(size_t chan = 0) = 0;
156 
157  /*******************************************************************
158  * Mboard methods
159  ******************************************************************/
160 
183  virtual void set_master_clock_rate(double rate, size_t mboard = ALL_MBOARDS) = 0;
184 
190  virtual double get_master_clock_rate(size_t mboard = 0) = 0;
191 
196  virtual std::string get_pp_string(void) = 0;
197 
203  virtual std::string get_mboard_name(size_t mboard = 0) = 0;
204 
210  virtual time_spec_t get_time_now(size_t mboard = 0) = 0;
211 
217  virtual time_spec_t get_time_last_pps(size_t mboard = 0) = 0;
218 
230  virtual void set_time_now(const time_spec_t &time_spec, size_t mboard = ALL_MBOARDS) = 0;
231 
244  virtual void set_time_next_pps(const time_spec_t &time_spec, size_t mboard = ALL_MBOARDS) = 0;
245 
261  virtual void set_time_unknown_pps(const time_spec_t &time_spec) = 0;
262 
269  virtual bool get_time_synchronized(void) = 0;
270 
281  virtual void set_command_time(const uhd::time_spec_t &time_spec, size_t mboard = ALL_MBOARDS) = 0;
282 
288  virtual void clear_command_time(size_t mboard = ALL_MBOARDS) = 0;
289 
302  virtual void issue_stream_cmd(const stream_cmd_t &stream_cmd, size_t chan = ALL_CHANS) = 0;
303 
312  virtual void set_clock_config(const clock_config_t &clock_config, size_t mboard = ALL_MBOARDS) = 0;
313 
322  virtual void set_time_source(const std::string &source, const size_t mboard = ALL_MBOARDS) = 0;
323 
329  virtual std::string get_time_source(const size_t mboard) = 0;
330 
336  virtual std::vector<std::string> get_time_sources(const size_t mboard) = 0;
337 
345  virtual void set_clock_source(const std::string &source, const size_t mboard = ALL_MBOARDS) = 0;
346 
352  virtual std::string get_clock_source(const size_t mboard) = 0;
353 
359  virtual std::vector<std::string> get_clock_sources(const size_t mboard) = 0;
360 
369  virtual void set_clock_source_out(const bool enb, const size_t mboard = ALL_MBOARDS) = 0;
370 
379  virtual void set_time_source_out(const bool enb, const size_t mboard = ALL_MBOARDS) = 0;
380 
384  virtual size_t get_num_mboards(void) = 0;
385 
392  virtual sensor_value_t get_mboard_sensor(const std::string &name, size_t mboard = 0) = 0;
393 
399  virtual std::vector<std::string> get_mboard_sensor_names(size_t mboard = 0) = 0;
400 
408  virtual void set_user_register(const boost::uint8_t addr, const boost::uint32_t data, size_t mboard = ALL_MBOARDS) = 0;
409 
410  /*******************************************************************
411  * RX methods
412  ******************************************************************/
421  virtual void set_rx_subdev_spec(const uhd::usrp::subdev_spec_t &spec, size_t mboard = ALL_MBOARDS) = 0;
422 
428  virtual uhd::usrp::subdev_spec_t get_rx_subdev_spec(size_t mboard = 0) = 0;
429 
435  virtual size_t get_rx_num_channels(void) = 0;
436 
442  virtual std::string get_rx_subdev_name(size_t chan = 0) = 0;
443 
449  virtual void set_rx_rate(double rate, size_t chan = ALL_CHANS) = 0;
450 
456  virtual double get_rx_rate(size_t chan = 0) = 0;
457 
463  virtual meta_range_t get_rx_rates(size_t chan = 0) = 0;
464 
471  virtual tune_result_t set_rx_freq(
472  const tune_request_t &tune_request, size_t chan = 0
473  ) = 0;
474 
480  virtual double get_rx_freq(size_t chan = 0) = 0;
481 
491  virtual freq_range_t get_rx_freq_range(size_t chan = 0) = 0;
492 
498  virtual freq_range_t get_fe_rx_freq_range(size_t chan = 0) = 0;
499 
505  virtual std::vector<std::string> get_rx_lo_names(size_t chan = 0) = 0;
506 
516  virtual void set_rx_lo_source(const std::string &src, const std::string &name = ALL_LOS, size_t chan = 0) = 0;
517 
526  virtual const std::string get_rx_lo_source(const std::string &name = ALL_LOS, size_t chan = 0) = 0;
527 
536  virtual std::vector<std::string> get_rx_lo_sources(const std::string &name = ALL_LOS, size_t chan = 0) = 0;
537 
546  virtual void set_rx_lo_export_enabled(bool enabled, const std::string &name = ALL_LOS, size_t chan = 0) = 0;
547 
553  virtual bool get_rx_lo_export_enabled(const std::string &name = ALL_LOS, size_t chan = 0) = 0;
554 
562  virtual double set_rx_lo_freq(double freq, const std::string &name, size_t chan = 0) = 0;
563 
572  virtual double get_rx_lo_freq(const std::string &name, size_t chan = 0) = 0;
573 
582  virtual freq_range_t get_rx_lo_freq_range(const std::string &name, size_t chan = 0) = 0;
583 
591  virtual void set_rx_gain(double gain, const std::string &name, size_t chan = 0) = 0;
592 
594  void set_rx_gain(double gain, size_t chan = 0){
595  return this->set_rx_gain(gain, ALL_GAINS, chan);
596  }
597 
614  virtual void set_normalized_rx_gain(double gain, size_t chan = 0) = 0;
615 
624  virtual void set_rx_agc(bool enable, size_t chan = 0) = 0;
625 
633  virtual double get_rx_gain(const std::string &name, size_t chan = 0) = 0;
634 
636  double get_rx_gain(size_t chan = 0){
637  return this->get_rx_gain(ALL_GAINS, chan);
638  }
639 
650  virtual double get_normalized_rx_gain(size_t chan = 0) = 0;
651 
659  virtual gain_range_t get_rx_gain_range(const std::string &name, size_t chan = 0) = 0;
660 
662  gain_range_t get_rx_gain_range(size_t chan = 0){
663  return this->get_rx_gain_range(ALL_GAINS, chan);
664  }
665 
672  virtual std::vector<std::string> get_rx_gain_names(size_t chan = 0) = 0;
673 
679  virtual void set_rx_antenna(const std::string &ant, size_t chan = 0) = 0;
680 
686  virtual std::string get_rx_antenna(size_t chan = 0) = 0;
687 
693  virtual std::vector<std::string> get_rx_antennas(size_t chan = 0) = 0;
694 
700  virtual void set_rx_bandwidth(double bandwidth, size_t chan = 0) = 0;
701 
707  virtual double get_rx_bandwidth(size_t chan = 0) = 0;
708 
714  virtual meta_range_t get_rx_bandwidth_range(size_t chan = 0) = 0;
715 
723  virtual dboard_iface::sptr get_rx_dboard_iface(size_t chan = 0) = 0;
724 
731  virtual sensor_value_t get_rx_sensor(const std::string &name, size_t chan = 0) = 0;
732 
738  virtual std::vector<std::string> get_rx_sensor_names(size_t chan = 0) = 0;
739 
752  virtual void set_rx_dc_offset(const bool enb, size_t chan = ALL_CHANS) = 0;
753 
761  virtual void set_rx_dc_offset(const std::complex<double> &offset, size_t chan = ALL_CHANS) = 0;
762 
769  virtual void set_rx_iq_balance(const bool enb, size_t chan) = 0;
770 
778  virtual void set_rx_iq_balance(const std::complex<double> &correction, size_t chan = ALL_CHANS) = 0;
779 
780  /*******************************************************************
781  * TX methods
782  ******************************************************************/
791  virtual void set_tx_subdev_spec(const uhd::usrp::subdev_spec_t &spec, size_t mboard = ALL_MBOARDS) = 0;
792 
798  virtual uhd::usrp::subdev_spec_t get_tx_subdev_spec(size_t mboard = 0) = 0;
799 
805  virtual size_t get_tx_num_channels(void) = 0;
806 
812  virtual std::string get_tx_subdev_name(size_t chan = 0) = 0;
813 
819  virtual void set_tx_rate(double rate, size_t chan = ALL_CHANS) = 0;
820 
826  virtual double get_tx_rate(size_t chan = 0) = 0;
827 
833  virtual meta_range_t get_tx_rates(size_t chan = 0) = 0;
834 
841  virtual tune_result_t set_tx_freq(
842  const tune_request_t &tune_request, size_t chan = 0
843  ) = 0;
844 
850  virtual double get_tx_freq(size_t chan = 0) = 0;
851 
861  virtual freq_range_t get_tx_freq_range(size_t chan = 0) = 0;
862 
868  virtual freq_range_t get_fe_tx_freq_range(size_t chan = 0) = 0;
869 
877  virtual void set_tx_gain(double gain, const std::string &name, size_t chan = 0) = 0;
878 
880  void set_tx_gain(double gain, size_t chan = 0){
881  return this->set_tx_gain(gain, ALL_GAINS, chan);
882  }
883 
894  virtual void set_normalized_tx_gain(double gain, size_t chan = 0) = 0;
895 
903  virtual double get_tx_gain(const std::string &name, size_t chan = 0) = 0;
904 
906  double get_tx_gain(size_t chan = 0){
907  return this->get_tx_gain(ALL_GAINS, chan);
908  }
909 
920  virtual double get_normalized_tx_gain(size_t chan = 0) = 0;
921 
929  virtual gain_range_t get_tx_gain_range(const std::string &name, size_t chan = 0) = 0;
930 
932  gain_range_t get_tx_gain_range(size_t chan = 0){
933  return this->get_tx_gain_range(ALL_GAINS, chan);
934  }
935 
942  virtual std::vector<std::string> get_tx_gain_names(size_t chan = 0) = 0;
943 
949  virtual void set_tx_antenna(const std::string &ant, size_t chan = 0) = 0;
950 
956  virtual std::string get_tx_antenna(size_t chan = 0) = 0;
957 
963  virtual std::vector<std::string> get_tx_antennas(size_t chan = 0) = 0;
964 
970  virtual void set_tx_bandwidth(double bandwidth, size_t chan = 0) = 0;
971 
977  virtual double get_tx_bandwidth(size_t chan = 0) = 0;
978 
984  virtual meta_range_t get_tx_bandwidth_range(size_t chan = 0) = 0;
985 
993  virtual dboard_iface::sptr get_tx_dboard_iface(size_t chan = 0) = 0;
994 
1001  virtual sensor_value_t get_tx_sensor(const std::string &name, size_t chan = 0) = 0;
1002 
1008  virtual std::vector<std::string> get_tx_sensor_names(size_t chan = 0) = 0;
1009 
1016  virtual void set_tx_dc_offset(const std::complex<double> &offset, size_t chan = ALL_CHANS) = 0;
1017 
1025  virtual void set_tx_iq_balance(const std::complex<double> &correction, size_t chan = ALL_CHANS) = 0;
1026 
1027  /*******************************************************************
1028  * GPIO methods
1029  ******************************************************************/
1030 
1036  virtual std::vector<std::string> get_gpio_banks(const size_t mboard) = 0;
1037 
1054  virtual void set_gpio_attr(const std::string &bank, const std::string &attr, const boost::uint32_t value, const boost::uint32_t mask = 0xffffffff, const size_t mboard = 0) = 0;
1055 
1072  virtual boost::uint32_t get_gpio_attr(const std::string &bank, const std::string &attr, const size_t mboard = 0) = 0;
1073 
1074  /*******************************************************************
1075  * Register IO methods
1076  ******************************************************************/
1078  size_t bitwidth;
1079  bool readable;
1080  bool writable;
1081  };
1082 
1088  virtual std::vector<std::string> enumerate_registers(const size_t mboard = 0) = 0;
1089 
1096  virtual register_info_t get_register_info(const std::string &path, const size_t mboard = 0) = 0;
1097 
1105  virtual void write_register(const std::string &path, const boost::uint32_t field, const boost::uint64_t value, const size_t mboard = 0) = 0;
1106 
1114  virtual boost::uint64_t read_register(const std::string &path, const boost::uint32_t field, const size_t mboard = 0) = 0;
1115 
1116  /*******************************************************************
1117  * Filter API methods
1118  ******************************************************************/
1119 
1130  virtual std::vector<std::string> get_filter_names(const std::string &search_mask = "") = 0;
1131 
1137  virtual filter_info_base::sptr get_filter(const std::string &path) = 0;
1138 
1146  virtual void set_filter(const std::string &path, filter_info_base::sptr filter) = 0;
1147 
1148 };
1149 
1150 }}
1151 
1152 #endif /* INCLUDED_UHD_USRP_MULTI_USRP_HPP */
gain_range_t get_rx_gain_range(size_t chan=0)
A convenience wrapper for getting overall RX gain range.
Definition: multi_usrp.hpp:662
Definition: stream_cmd.hpp:46
Definition: tune_result.hpp:29
double get_tx_gain(size_t chan=0)
A convenience wrapper for getting overall TX gain.
Definition: multi_usrp.hpp:906
void set_tx_gain(double gain, size_t chan=0)
A convenience wrapper for setting overall TX gain.
Definition: multi_usrp.hpp:880
Definition: time_spec.hpp:39
bool readable
Definition: multi_usrp.hpp:1079
boost::shared_ptr< device > sptr
Definition: device.hpp:41
boost::shared_ptr< multi_usrp > sptr
Definition: multi_usrp.hpp:103
Definition: multi_usrp.hpp:1077
double get_rx_gain(size_t chan=0)
A convenience wrapper for getting overall RX gain.
Definition: multi_usrp.hpp:636
Definition: tune_request.hpp:33
boost::shared_ptr< rx_streamer > sptr
Definition: stream.hpp:171
static const std::string ALL_GAINS
A wildcard gain element name.
Definition: multi_usrp.hpp:114
Definition: build_info.hpp:25
Definition: sensors.hpp:38
boost::shared_ptr< filter_info_base > sptr
Definition: filters.hpp:38
Definition: clock_config.hpp:36
Definition: multi_usrp.hpp:101
Definition: stream.hpp:57
#define UHD_API
Definition: config.h:73
UHD_INLINE data_t mask(const soft_reg_field_t field)
Definition: soft_register.hpp:98
boost::shared_ptr< dboard_iface > sptr
Definition: dboard_iface.hpp:64
void set_rx_gain(double gain, size_t chan=0)
A convenience wrapper for setting overall RX gain.
Definition: multi_usrp.hpp:594
static const std::string ALL_LOS
A wildcard gain element name.
Definition: multi_usrp.hpp:117
Definition: subdev_spec.hpp:66
bool writable
Definition: multi_usrp.hpp:1080
Definition: ranges.hpp:68
size_t bitwidth
Definition: multi_usrp.hpp:1078
boost::shared_ptr< tx_streamer > sptr
Definition: stream.hpp:247
gain_range_t get_tx_gain_range(size_t chan=0)
A convenience wrapper for getting overall TX gain range.
Definition: multi_usrp.hpp:932
Definition: device_addr.hpp:47