USRP Hardware Driver and USRP Manual  Version: 3.12.0.HEAD-0-gec786351
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 // Copyright 2018 Ettus Research, a National Instruments Company
4 //
5 // SPDX-License-Identifier: GPL-3.0-or-later
6 //
7 
8 #ifndef INCLUDED_UHD_USRP_MULTI_USRP_HPP
9 #define INCLUDED_UHD_USRP_MULTI_USRP_HPP
10 
11 //define API capabilities for compile time detection of new features
12 #define UHD_USRP_MULTI_USRP_REF_SOURCES_API
13 #define UHD_USRP_MULTI_USRP_GET_RATES_API
14 #define UHD_USRP_MULTI_USRP_FRONTEND_CAL_API
15 #define UHD_USRP_MULTI_USRP_FRONTEND_IQ_AUTO_API
16 #define UHD_USRP_MULTI_USRP_COMMAND_TIME_API
17 #define UHD_USRP_MULTI_USRP_BW_RANGE_API
18 #define UHD_USRP_MULTI_USRP_USER_REGS_API
19 #define UHD_USRP_MULTI_USRP_GET_USRP_INFO_API
20 #define UHD_USRP_MULTI_USRP_NORMALIZED_GAIN
21 #define UHD_USRP_MULTI_USRP_GPIO_API
22 #define UHD_USRP_MULTI_USRP_REGISTER_API
23 #define UHD_USRP_MULTI_USRP_FILTER_API
24 #define UHD_USRP_MULTI_USRP_LO_CONFIG_API
25 
26 #include <uhd/config.hpp>
27 #include <uhd/device.hpp>
28 #include <uhd/deprecated.hpp>
29 #include <uhd/types/ranges.hpp>
30 #include <uhd/types/stream_cmd.hpp>
33 #include <uhd/types/sensors.hpp>
34 #include <uhd/types/filters.hpp>
35 #include <uhd/usrp/subdev_spec.hpp>
37 #include <boost/shared_ptr.hpp>
38 #include <boost/utility.hpp>
39 #include <complex>
40 #include <string>
41 #include <vector>
42 
43 namespace uhd{ namespace usrp{
44 
91 class UHD_API multi_usrp : boost::noncopyable{
92 public:
93  typedef boost::shared_ptr<multi_usrp> sptr;
94 
95  virtual ~multi_usrp(void) = 0;
96 
98  static const size_t ALL_MBOARDS = size_t(~0);
99 
101  static const size_t ALL_CHANS = size_t(~0);
102 
104  static const std::string ALL_GAINS;
105 
107  static const std::string ALL_LOS;
108 
116  static sptr make(const device_addr_t &dev_addr);
117 
123  virtual device::sptr get_device(void) = 0;
124 
126  virtual rx_streamer::sptr get_rx_stream(const stream_args_t &args) = 0;
127 
129  virtual tx_streamer::sptr get_tx_stream(const stream_args_t &args) = 0;
130 
138  virtual dict<std::string, std::string> get_usrp_rx_info(size_t chan = 0) = 0;
139 
147  virtual dict<std::string, std::string> get_usrp_tx_info(size_t chan = 0) = 0;
148 
149  /*******************************************************************
150  * Mboard methods
151  ******************************************************************/
152 
175  virtual void set_master_clock_rate(double rate, size_t mboard = ALL_MBOARDS) = 0;
176 
182  virtual double get_master_clock_rate(size_t mboard = 0) = 0;
183 
202  virtual meta_range_t get_master_clock_rate_range(const size_t mboard = 0) = 0;
203 
208  virtual std::string get_pp_string(void) = 0;
209 
215  virtual std::string get_mboard_name(size_t mboard = 0) = 0;
216 
222  virtual time_spec_t get_time_now(size_t mboard = 0) = 0;
223 
229  virtual time_spec_t get_time_last_pps(size_t mboard = 0) = 0;
230 
242  virtual void set_time_now(const time_spec_t &time_spec, size_t mboard = ALL_MBOARDS) = 0;
243 
256  virtual void set_time_next_pps(const time_spec_t &time_spec, size_t mboard = ALL_MBOARDS) = 0;
257 
273  virtual void set_time_unknown_pps(const time_spec_t &time_spec) = 0;
274 
281  virtual bool get_time_synchronized(void) = 0;
282 
293  virtual void set_command_time(const uhd::time_spec_t &time_spec, size_t mboard = ALL_MBOARDS) = 0;
294 
300  virtual void clear_command_time(size_t mboard = ALL_MBOARDS) = 0;
301 
314  virtual void issue_stream_cmd(const stream_cmd_t &stream_cmd, size_t chan = ALL_CHANS) = 0;
315 
324  virtual void set_clock_config(const clock_config_t &clock_config, size_t mboard = ALL_MBOARDS) = 0;
325 
334  virtual void set_time_source(const std::string &source, const size_t mboard = ALL_MBOARDS) = 0;
335 
341  virtual std::string get_time_source(const size_t mboard) = 0;
342 
348  virtual std::vector<std::string> get_time_sources(const size_t mboard) = 0;
349 
357  virtual void set_clock_source(const std::string &source, const size_t mboard = ALL_MBOARDS) = 0;
358 
364  virtual std::string get_clock_source(const size_t mboard) = 0;
365 
371  virtual std::vector<std::string> get_clock_sources(const size_t mboard) = 0;
372 
381  virtual void set_clock_source_out(const bool enb, const size_t mboard = ALL_MBOARDS) = 0;
382 
391  virtual void set_time_source_out(const bool enb, const size_t mboard = ALL_MBOARDS) = 0;
392 
396  virtual size_t get_num_mboards(void) = 0;
397 
404  virtual sensor_value_t get_mboard_sensor(const std::string &name, size_t mboard = 0) = 0;
405 
411  virtual std::vector<std::string> get_mboard_sensor_names(size_t mboard = 0) = 0;
412 
420  virtual void set_user_register(const uint8_t addr, const uint32_t data, size_t mboard = ALL_MBOARDS) = 0;
421 
422  /*******************************************************************
423  * RX methods
424  ******************************************************************/
433  virtual void set_rx_subdev_spec(const uhd::usrp::subdev_spec_t &spec, size_t mboard = ALL_MBOARDS) = 0;
434 
440  virtual uhd::usrp::subdev_spec_t get_rx_subdev_spec(size_t mboard = 0) = 0;
441 
447  virtual size_t get_rx_num_channels(void) = 0;
448 
454  virtual std::string get_rx_subdev_name(size_t chan = 0) = 0;
455 
461  virtual void set_rx_rate(double rate, size_t chan = ALL_CHANS) = 0;
462 
468  virtual double get_rx_rate(size_t chan = 0) = 0;
469 
475  virtual meta_range_t get_rx_rates(size_t chan = 0) = 0;
476 
483  virtual tune_result_t set_rx_freq(
484  const tune_request_t &tune_request, size_t chan = 0
485  ) = 0;
486 
492  virtual double get_rx_freq(size_t chan = 0) = 0;
493 
503  virtual freq_range_t get_rx_freq_range(size_t chan = 0) = 0;
504 
510  virtual freq_range_t get_fe_rx_freq_range(size_t chan = 0) = 0;
511 
512  /**************************************************************************
513  * LO controls
514  *************************************************************************/
528  virtual std::vector<std::string> get_rx_lo_names(size_t chan = 0) = 0;
529 
541  virtual void set_rx_lo_source(
542  const std::string &src,
543  const std::string &name = ALL_LOS,
544  size_t chan = 0
545  ) = 0;
546 
555  virtual const std::string get_rx_lo_source(
556  const std::string &name = ALL_LOS,
557  size_t chan = 0
558  ) = 0;
559 
571  virtual std::vector<std::string> get_rx_lo_sources(
572  const std::string &name = ALL_LOS,
573  size_t chan = 0
574  ) = 0;
575 
586  virtual void set_rx_lo_export_enabled(
587  bool enabled,
588  const std::string &name = ALL_LOS,
589  size_t chan = 0
590  ) = 0;
591 
597  virtual bool get_rx_lo_export_enabled(
598  const std::string &name = ALL_LOS,
599  size_t chan = 0
600  ) = 0;
601 
625  virtual double set_rx_lo_freq(
626  double freq,
627  const std::string &name,
628  size_t chan = 0
629  ) = 0;
630 
641  virtual double get_rx_lo_freq(
642  const std::string &name,
643  size_t chan = 0
644  ) = 0;
645 
655  virtual freq_range_t get_rx_lo_freq_range(
656  const std::string &name,
657  size_t chan = 0
658  ) = 0;
659 
672  virtual std::vector<std::string> get_tx_lo_names(size_t chan = 0) = 0;
673 
685  virtual void set_tx_lo_source(
686  const std::string &src,
687  const std::string &name = ALL_LOS,
688  const size_t chan = 0
689  ) = 0;
690 
699  virtual const std::string get_tx_lo_source(
700  const std::string &name = ALL_LOS,
701  const size_t chan = 0
702  ) = 0;
703 
714  virtual std::vector<std::string> get_tx_lo_sources(
715  const std::string &name = ALL_LOS,
716  const size_t chan = 0
717  ) = 0;
718 
729  virtual void set_tx_lo_export_enabled(
730  const bool enabled,
731  const std::string &name = ALL_LOS,
732  const size_t chan = 0
733  ) = 0;
734 
740  virtual bool get_tx_lo_export_enabled(
741  const std::string &name = ALL_LOS,
742  const size_t chan = 0
743  ) = 0;
744 
768  virtual double set_tx_lo_freq(
769  const double freq,
770  const std::string &name,
771  const size_t chan=0
772  ) = 0;
773 
784  virtual double get_tx_lo_freq(
785  const std::string &name,
786  const size_t chan=0
787  ) = 0;
788 
798  virtual freq_range_t get_tx_lo_freq_range(
799  const std::string &name,
800  const size_t chan=0
801  ) = 0;
802 
803  /**************************************************************************
804  * Gain controls
805  *************************************************************************/
813  virtual void set_rx_gain(double gain, const std::string &name, size_t chan = 0) = 0;
814 
827  virtual std::vector<std::string> get_rx_gain_profile_names(const size_t chan = 0) = 0;
828 
834  virtual void set_rx_gain_profile(const std::string& profile, const size_t chan = 0) = 0;
835 
841  virtual std::string get_rx_gain_profile(const size_t chan = 0) = 0;
842 
844  void set_rx_gain(double gain, size_t chan = 0){
845  return this->set_rx_gain(gain, ALL_GAINS, chan);
846  }
847 
864  virtual void set_normalized_rx_gain(double gain, size_t chan = 0) = 0;
865 
874  virtual void set_rx_agc(bool enable, size_t chan = 0) = 0;
875 
883  virtual double get_rx_gain(const std::string &name, size_t chan = 0) = 0;
884 
886  double get_rx_gain(size_t chan = 0){
887  return this->get_rx_gain(ALL_GAINS, chan);
888  }
889 
900  virtual double get_normalized_rx_gain(size_t chan = 0) = 0;
901 
909  virtual gain_range_t get_rx_gain_range(const std::string &name, size_t chan = 0) = 0;
910 
912  gain_range_t get_rx_gain_range(size_t chan = 0){
913  return this->get_rx_gain_range(ALL_GAINS, chan);
914  }
915 
922  virtual std::vector<std::string> get_rx_gain_names(size_t chan = 0) = 0;
923 
929  virtual void set_rx_antenna(const std::string &ant, size_t chan = 0) = 0;
930 
936  virtual std::string get_rx_antenna(size_t chan = 0) = 0;
937 
943  virtual std::vector<std::string> get_rx_antennas(size_t chan = 0) = 0;
944 
950  virtual void set_rx_bandwidth(double bandwidth, size_t chan = 0) = 0;
951 
957  virtual double get_rx_bandwidth(size_t chan = 0) = 0;
958 
964  virtual meta_range_t get_rx_bandwidth_range(size_t chan = 0) = 0;
965 
973  virtual dboard_iface::sptr get_rx_dboard_iface(size_t chan = 0) = 0;
974 
981  virtual sensor_value_t get_rx_sensor(const std::string &name, size_t chan = 0) = 0;
982 
988  virtual std::vector<std::string> get_rx_sensor_names(size_t chan = 0) = 0;
989 
1002  virtual void set_rx_dc_offset(const bool enb, size_t chan = ALL_CHANS) = 0;
1003 
1011  virtual void set_rx_dc_offset(const std::complex<double> &offset, size_t chan = ALL_CHANS) = 0;
1012 
1019  virtual void set_rx_iq_balance(const bool enb, size_t chan) = 0;
1020 
1028  virtual void set_rx_iq_balance(const std::complex<double> &correction, size_t chan = ALL_CHANS) = 0;
1029 
1030  /*******************************************************************
1031  * TX methods
1032  ******************************************************************/
1041  virtual void set_tx_subdev_spec(const uhd::usrp::subdev_spec_t &spec, size_t mboard = ALL_MBOARDS) = 0;
1042 
1048  virtual uhd::usrp::subdev_spec_t get_tx_subdev_spec(size_t mboard = 0) = 0;
1049 
1055  virtual size_t get_tx_num_channels(void) = 0;
1056 
1062  virtual std::string get_tx_subdev_name(size_t chan = 0) = 0;
1063 
1069  virtual void set_tx_rate(double rate, size_t chan = ALL_CHANS) = 0;
1070 
1076  virtual double get_tx_rate(size_t chan = 0) = 0;
1077 
1083  virtual meta_range_t get_tx_rates(size_t chan = 0) = 0;
1084 
1091  virtual tune_result_t set_tx_freq(
1092  const tune_request_t &tune_request, size_t chan = 0
1093  ) = 0;
1094 
1100  virtual double get_tx_freq(size_t chan = 0) = 0;
1101 
1111  virtual freq_range_t get_tx_freq_range(size_t chan = 0) = 0;
1112 
1118  virtual freq_range_t get_fe_tx_freq_range(size_t chan = 0) = 0;
1119 
1127  virtual void set_tx_gain(double gain, const std::string &name, size_t chan = 0) = 0;
1128 
1141  virtual std::vector<std::string> get_tx_gain_profile_names(const size_t chan = 0) = 0;
1142 
1148  virtual void set_tx_gain_profile(const std::string& profile, const size_t chan = 0) = 0;
1149 
1155  virtual std::string get_tx_gain_profile(const size_t chan = 0) = 0;
1156 
1158  void set_tx_gain(double gain, size_t chan = 0){
1159  return this->set_tx_gain(gain, ALL_GAINS, chan);
1160  }
1161 
1172  virtual void set_normalized_tx_gain(double gain, size_t chan = 0) = 0;
1173 
1181  virtual double get_tx_gain(const std::string &name, size_t chan = 0) = 0;
1182 
1184  double get_tx_gain(size_t chan = 0){
1185  return this->get_tx_gain(ALL_GAINS, chan);
1186  }
1187 
1198  virtual double get_normalized_tx_gain(size_t chan = 0) = 0;
1199 
1207  virtual gain_range_t get_tx_gain_range(const std::string &name, size_t chan = 0) = 0;
1208 
1211  return this->get_tx_gain_range(ALL_GAINS, chan);
1212  }
1213 
1220  virtual std::vector<std::string> get_tx_gain_names(size_t chan = 0) = 0;
1221 
1227  virtual void set_tx_antenna(const std::string &ant, size_t chan = 0) = 0;
1228 
1234  virtual std::string get_tx_antenna(size_t chan = 0) = 0;
1235 
1241  virtual std::vector<std::string> get_tx_antennas(size_t chan = 0) = 0;
1242 
1248  virtual void set_tx_bandwidth(double bandwidth, size_t chan = 0) = 0;
1249 
1255  virtual double get_tx_bandwidth(size_t chan = 0) = 0;
1256 
1262  virtual meta_range_t get_tx_bandwidth_range(size_t chan = 0) = 0;
1263 
1271  virtual dboard_iface::sptr get_tx_dboard_iface(size_t chan = 0) = 0;
1272 
1279  virtual sensor_value_t get_tx_sensor(const std::string &name, size_t chan = 0) = 0;
1280 
1286  virtual std::vector<std::string> get_tx_sensor_names(size_t chan = 0) = 0;
1287 
1294  virtual void set_tx_dc_offset(const std::complex<double> &offset, size_t chan = ALL_CHANS) = 0;
1295 
1303  virtual void set_tx_iq_balance(const std::complex<double> &correction, size_t chan = ALL_CHANS) = 0;
1304 
1305  /*******************************************************************
1306  * GPIO methods
1307  ******************************************************************/
1308 
1314  virtual std::vector<std::string> get_gpio_banks(const size_t mboard) = 0;
1315 
1332  virtual void set_gpio_attr(const std::string &bank, const std::string &attr, const uint32_t value, const uint32_t mask = 0xffffffff, const size_t mboard = 0) = 0;
1333 
1359  virtual void set_gpio_attr(const std::string &bank, const std::string &attr, const std::string &value, const uint32_t mask = 0xffffffff, const size_t mboard = 0) = 0;
1360 
1377  virtual uint32_t get_gpio_attr(const std::string &bank, const std::string &attr, const size_t mboard = 0) = 0;
1378 
1404  virtual std::vector<std::string> get_gpio_string_attr(const std::string &bank, const std::string &attr, const size_t mboard = 0) = 0;
1405 
1406  /*******************************************************************
1407  * Register IO methods
1408  ******************************************************************/
1410  size_t bitwidth;
1411  bool readable;
1412  bool writable;
1413  };
1414 
1420  virtual std::vector<std::string> enumerate_registers(const size_t mboard = 0) = 0;
1421 
1428  virtual register_info_t get_register_info(const std::string &path, const size_t mboard = 0) = 0;
1429 
1437  virtual void write_register(const std::string &path, const uint32_t field, const uint64_t value, const size_t mboard = 0) = 0;
1438 
1446  virtual uint64_t read_register(const std::string &path, const uint32_t field, const size_t mboard = 0) = 0;
1447 
1448  /*******************************************************************
1449  * Filter API methods
1450  ******************************************************************/
1451 
1462  virtual std::vector<std::string> get_filter_names(const std::string &search_mask = "") = 0;
1463 
1469  virtual filter_info_base::sptr get_filter(const std::string &path) = 0;
1470 
1478  virtual void set_filter(const std::string &path, filter_info_base::sptr filter) = 0;
1479 
1480 };
1481 
1482 }}
1483 
1484 #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:912
Definition: stream_cmd.hpp:36
Definition: tune_result.hpp:19
double get_tx_gain(size_t chan=0)
A convenience wrapper for getting overall TX gain.
Definition: multi_usrp.hpp:1184
void set_tx_gain(double gain, size_t chan=0)
A convenience wrapper for setting overall TX gain.
Definition: multi_usrp.hpp:1158
Definition: time_spec.hpp:29
bool readable
Definition: multi_usrp.hpp:1411
boost::shared_ptr< device > sptr
Definition: device.hpp:31
boost::shared_ptr< multi_usrp > sptr
Definition: multi_usrp.hpp:93
Definition: multi_usrp.hpp:1409
double get_rx_gain(size_t chan=0)
A convenience wrapper for getting overall RX gain.
Definition: multi_usrp.hpp:886
Definition: tune_request.hpp:25
boost::shared_ptr< rx_streamer > sptr
Definition: stream.hpp:161
static const std::string ALL_GAINS
A wildcard gain element name.
Definition: multi_usrp.hpp:104
Definition: build_info.hpp:14
Definition: sensors.hpp:29
boost::shared_ptr< filter_info_base > sptr
Definition: filters.hpp:28
Definition: clock_config.hpp:26
Definition: multi_usrp.hpp:91
Definition: stream.hpp:47
#define UHD_API
Definition: config.h:63
UHD_INLINE data_t mask(const soft_reg_field_t field)
Definition: soft_register.hpp:87
boost::shared_ptr< dboard_iface > sptr
Definition: dboard_iface.hpp:54
void set_rx_gain(double gain, size_t chan=0)
A convenience wrapper for setting overall RX gain.
Definition: multi_usrp.hpp:844
static const std::string ALL_LOS
A wildcard LO stage name.
Definition: multi_usrp.hpp:107
Definition: subdev_spec.hpp:62
bool writable
Definition: multi_usrp.hpp:1412
Definition: ranges.hpp:64
size_t bitwidth
Definition: multi_usrp.hpp:1410
boost::shared_ptr< tx_streamer > sptr
Definition: stream.hpp:237
gain_range_t get_tx_gain_range(size_t chan=0)
A convenience wrapper for getting overall TX gain range.
Definition: multi_usrp.hpp:1210
Definition: device_addr.hpp:38