USRP Hardware Driver and USRP Manual  Version: 3.14.0.HEAD-0-g28fe2e2c
UHD and USRP Manual
All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Friends Macros Pages
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 #define UHD_USRP_MULTI_USRP_TX_LO_CONFIG_API
26 
27 #include <uhd/config.hpp>
28 #include <uhd/device.hpp>
29 #include <uhd/deprecated.hpp>
30 #include <uhd/types/ranges.hpp>
31 #include <uhd/types/stream_cmd.hpp>
34 #include <uhd/types/sensors.hpp>
35 #include <uhd/types/filters.hpp>
36 #include <uhd/types/wb_iface.hpp>
37 #include <uhd/usrp/subdev_spec.hpp>
39 #include <boost/shared_ptr.hpp>
40 #include <boost/utility.hpp>
41 #include <complex>
42 #include <string>
43 #include <vector>
44 
45 namespace uhd {
46  class device3;
47 
48  namespace usrp{
49 
96 class UHD_API multi_usrp : boost::noncopyable{
97 public:
98  typedef boost::shared_ptr<multi_usrp> sptr;
99 
100  virtual ~multi_usrp(void) = 0;
101 
103  static const size_t ALL_MBOARDS;
104 
106  static const size_t ALL_CHANS;
107 
109  static const std::string ALL_GAINS;
110 
112  static const std::string ALL_LOS;
113 
121  static sptr make(const device_addr_t &dev_addr);
122 
128  virtual device::sptr get_device(void) = 0;
129 
132  virtual bool is_device3(void) = 0;
133 
142  virtual boost::shared_ptr<uhd::device3> get_device3(void) = 0;
143 
145  virtual rx_streamer::sptr get_rx_stream(const stream_args_t &args) = 0;
146 
148  virtual tx_streamer::sptr get_tx_stream(const stream_args_t &args) = 0;
149 
157  virtual dict<std::string, std::string> get_usrp_rx_info(size_t chan = 0) = 0;
158 
166  virtual dict<std::string, std::string> get_usrp_tx_info(size_t chan = 0) = 0;
167 
168  /*******************************************************************
169  * Mboard methods
170  ******************************************************************/
171 
194  virtual void set_master_clock_rate(double rate, size_t mboard = ALL_MBOARDS) = 0;
195 
201  virtual double get_master_clock_rate(size_t mboard = 0) = 0;
202 
221  virtual meta_range_t get_master_clock_rate_range(const size_t mboard = 0) = 0;
222 
227  virtual std::string get_pp_string(void) = 0;
228 
234  virtual std::string get_mboard_name(size_t mboard = 0) = 0;
235 
241  virtual time_spec_t get_time_now(size_t mboard = 0) = 0;
242 
248  virtual time_spec_t get_time_last_pps(size_t mboard = 0) = 0;
249 
261  virtual void set_time_now(const time_spec_t &time_spec, size_t mboard = ALL_MBOARDS) = 0;
262 
275  virtual void set_time_next_pps(const time_spec_t &time_spec, size_t mboard = ALL_MBOARDS) = 0;
276 
292  virtual void set_time_unknown_pps(const time_spec_t &time_spec) = 0;
293 
300  virtual bool get_time_synchronized(void) = 0;
301 
312  virtual void set_command_time(const uhd::time_spec_t &time_spec, size_t mboard = ALL_MBOARDS) = 0;
313 
319  virtual void clear_command_time(size_t mboard = ALL_MBOARDS) = 0;
320 
333  virtual void issue_stream_cmd(const stream_cmd_t &stream_cmd, size_t chan = ALL_CHANS) = 0;
334 
343  virtual void set_clock_config(const clock_config_t &clock_config, size_t mboard = ALL_MBOARDS) = 0;
344 
387  virtual void set_time_source(
388  const std::string &source,
389  const size_t mboard = ALL_MBOARDS
390  ) = 0;
391 
397  virtual std::string get_time_source(const size_t mboard) = 0;
398 
404  virtual std::vector<std::string> get_time_sources(const size_t mboard) = 0;
405 
448  virtual void set_clock_source(
449  const std::string &source,
450  const size_t mboard = ALL_MBOARDS
451  ) = 0;
452 
458  virtual std::string get_clock_source(const size_t mboard) = 0;
459 
465  virtual std::vector<std::string> get_clock_sources(const size_t mboard) = 0;
466 
477  virtual void set_sync_source(
478  const std::string &clock_source,
479  const std::string &time_source,
480  const size_t mboard = ALL_MBOARDS
481  ) = 0;
482 
505  virtual void set_sync_source(
506  const device_addr_t& sync_source,
507  const size_t mboard = ALL_MBOARDS
508  ) = 0;
509 
515  virtual device_addr_t get_sync_source(const size_t mboard) = 0;
516 
522  virtual std::vector<device_addr_t> get_sync_sources(const size_t mboard) = 0;
523 
532  virtual void set_clock_source_out(const bool enb, const size_t mboard = ALL_MBOARDS) = 0;
533 
542  virtual void set_time_source_out(const bool enb, const size_t mboard = ALL_MBOARDS) = 0;
543 
547  virtual size_t get_num_mboards(void) = 0;
548 
555  virtual sensor_value_t get_mboard_sensor(const std::string &name, size_t mboard = 0) = 0;
556 
562  virtual std::vector<std::string> get_mboard_sensor_names(size_t mboard = 0) = 0;
563 
571  virtual void set_user_register(const uint8_t addr, const uint32_t data, size_t mboard = ALL_MBOARDS) = 0;
572 
597  virtual uhd::wb_iface::sptr get_user_settings_iface(const size_t chan = 0) = 0;
598 
599  /*******************************************************************
600  * RX methods
601  ******************************************************************/
610  virtual void set_rx_subdev_spec(const uhd::usrp::subdev_spec_t &spec, size_t mboard = ALL_MBOARDS) = 0;
611 
617  virtual uhd::usrp::subdev_spec_t get_rx_subdev_spec(size_t mboard = 0) = 0;
618 
624  virtual size_t get_rx_num_channels(void) = 0;
625 
631  virtual std::string get_rx_subdev_name(size_t chan = 0) = 0;
632 
638  virtual void set_rx_rate(double rate, size_t chan = ALL_CHANS) = 0;
639 
645  virtual double get_rx_rate(size_t chan = 0) = 0;
646 
652  virtual meta_range_t get_rx_rates(size_t chan = 0) = 0;
653 
660  virtual tune_result_t set_rx_freq(
661  const tune_request_t &tune_request, size_t chan = 0
662  ) = 0;
663 
669  virtual double get_rx_freq(size_t chan = 0) = 0;
670 
680  virtual freq_range_t get_rx_freq_range(size_t chan = 0) = 0;
681 
687  virtual freq_range_t get_fe_rx_freq_range(size_t chan = 0) = 0;
688 
689  /**************************************************************************
690  * LO controls
691  *************************************************************************/
705  virtual std::vector<std::string> get_rx_lo_names(size_t chan = 0) = 0;
706 
718  virtual void set_rx_lo_source(
719  const std::string &src,
720  const std::string &name = ALL_LOS,
721  size_t chan = 0
722  ) = 0;
723 
732  virtual const std::string get_rx_lo_source(
733  const std::string &name = ALL_LOS,
734  size_t chan = 0
735  ) = 0;
736 
748  virtual std::vector<std::string> get_rx_lo_sources(
749  const std::string &name = ALL_LOS,
750  size_t chan = 0
751  ) = 0;
752 
763  virtual void set_rx_lo_export_enabled(
764  bool enabled,
765  const std::string &name = ALL_LOS,
766  size_t chan = 0
767  ) = 0;
768 
774  virtual bool get_rx_lo_export_enabled(
775  const std::string &name = ALL_LOS,
776  size_t chan = 0
777  ) = 0;
778 
802  virtual double set_rx_lo_freq(
803  double freq,
804  const std::string &name,
805  size_t chan = 0
806  ) = 0;
807 
818  virtual double get_rx_lo_freq(
819  const std::string &name,
820  size_t chan = 0
821  ) = 0;
822 
832  virtual freq_range_t get_rx_lo_freq_range(
833  const std::string &name,
834  size_t chan = 0
835  ) = 0;
836 
849  virtual std::vector<std::string> get_tx_lo_names(size_t chan = 0) = 0;
850 
862  virtual void set_tx_lo_source(
863  const std::string &src,
864  const std::string &name = ALL_LOS,
865  const size_t chan = 0
866  ) = 0;
867 
876  virtual const std::string get_tx_lo_source(
877  const std::string &name = ALL_LOS,
878  const size_t chan = 0
879  ) = 0;
880 
891  virtual std::vector<std::string> get_tx_lo_sources(
892  const std::string &name = ALL_LOS,
893  const size_t chan = 0
894  ) = 0;
895 
906  virtual void set_tx_lo_export_enabled(
907  const bool enabled,
908  const std::string &name = ALL_LOS,
909  const size_t chan = 0
910  ) = 0;
911 
917  virtual bool get_tx_lo_export_enabled(
918  const std::string &name = ALL_LOS,
919  const size_t chan = 0
920  ) = 0;
921 
945  virtual double set_tx_lo_freq(
946  const double freq,
947  const std::string &name,
948  const size_t chan=0
949  ) = 0;
950 
961  virtual double get_tx_lo_freq(
962  const std::string &name,
963  const size_t chan=0
964  ) = 0;
965 
975  virtual freq_range_t get_tx_lo_freq_range(
976  const std::string &name,
977  const size_t chan=0
978  ) = 0;
979 
980  /**************************************************************************
981  * Gain controls
982  *************************************************************************/
990  virtual void set_rx_gain(double gain, const std::string &name, size_t chan = 0) = 0;
991 
1004  virtual std::vector<std::string> get_rx_gain_profile_names(const size_t chan = 0) = 0;
1005 
1011  virtual void set_rx_gain_profile(const std::string& profile, const size_t chan = 0) = 0;
1012 
1018  virtual std::string get_rx_gain_profile(const size_t chan = 0) = 0;
1019 
1021  void set_rx_gain(double gain, size_t chan = 0){
1022  return this->set_rx_gain(gain, ALL_GAINS, chan);
1023  }
1024 
1041  virtual void set_normalized_rx_gain(double gain, size_t chan = 0) = 0;
1042 
1051  virtual void set_rx_agc(bool enable, size_t chan = 0) = 0;
1052 
1060  virtual double get_rx_gain(const std::string &name, size_t chan = 0) = 0;
1061 
1063  double get_rx_gain(size_t chan = 0){
1064  return this->get_rx_gain(ALL_GAINS, chan);
1065  }
1066 
1077  virtual double get_normalized_rx_gain(size_t chan = 0) = 0;
1078 
1086  virtual gain_range_t get_rx_gain_range(const std::string &name, size_t chan = 0) = 0;
1087 
1090  return this->get_rx_gain_range(ALL_GAINS, chan);
1091  }
1092 
1099  virtual std::vector<std::string> get_rx_gain_names(size_t chan = 0) = 0;
1100 
1106  virtual void set_rx_antenna(const std::string &ant, size_t chan = 0) = 0;
1107 
1113  virtual std::string get_rx_antenna(size_t chan = 0) = 0;
1114 
1120  virtual std::vector<std::string> get_rx_antennas(size_t chan = 0) = 0;
1121 
1127  virtual void set_rx_bandwidth(double bandwidth, size_t chan = 0) = 0;
1128 
1134  virtual double get_rx_bandwidth(size_t chan = 0) = 0;
1135 
1141  virtual meta_range_t get_rx_bandwidth_range(size_t chan = 0) = 0;
1142 
1150  virtual dboard_iface::sptr get_rx_dboard_iface(size_t chan = 0) = 0;
1151 
1158  virtual sensor_value_t get_rx_sensor(const std::string &name, size_t chan = 0) = 0;
1159 
1165  virtual std::vector<std::string> get_rx_sensor_names(size_t chan = 0) = 0;
1166 
1179  virtual void set_rx_dc_offset(const bool enb, size_t chan = ALL_CHANS) = 0;
1180 
1188  virtual void set_rx_dc_offset(const std::complex<double> &offset, size_t chan = ALL_CHANS) = 0;
1189 
1194  virtual meta_range_t get_rx_dc_offset_range(size_t chan = ALL_CHANS) = 0;
1195 
1202  virtual void set_rx_iq_balance(const bool enb, size_t chan) = 0;
1203 
1211  virtual void set_rx_iq_balance(const std::complex<double> &correction, size_t chan = ALL_CHANS) = 0;
1212 
1213  /*******************************************************************
1214  * TX methods
1215  ******************************************************************/
1224  virtual void set_tx_subdev_spec(const uhd::usrp::subdev_spec_t &spec, size_t mboard = ALL_MBOARDS) = 0;
1225 
1231  virtual uhd::usrp::subdev_spec_t get_tx_subdev_spec(size_t mboard = 0) = 0;
1232 
1238  virtual size_t get_tx_num_channels(void) = 0;
1239 
1245  virtual std::string get_tx_subdev_name(size_t chan = 0) = 0;
1246 
1252  virtual void set_tx_rate(double rate, size_t chan = ALL_CHANS) = 0;
1253 
1259  virtual double get_tx_rate(size_t chan = 0) = 0;
1260 
1266  virtual meta_range_t get_tx_rates(size_t chan = 0) = 0;
1267 
1274  virtual tune_result_t set_tx_freq(
1275  const tune_request_t &tune_request, size_t chan = 0
1276  ) = 0;
1277 
1283  virtual double get_tx_freq(size_t chan = 0) = 0;
1284 
1294  virtual freq_range_t get_tx_freq_range(size_t chan = 0) = 0;
1295 
1301  virtual freq_range_t get_fe_tx_freq_range(size_t chan = 0) = 0;
1302 
1310  virtual void set_tx_gain(double gain, const std::string &name, size_t chan = 0) = 0;
1311 
1324  virtual std::vector<std::string> get_tx_gain_profile_names(const size_t chan = 0) = 0;
1325 
1331  virtual void set_tx_gain_profile(const std::string& profile, const size_t chan = 0) = 0;
1332 
1338  virtual std::string get_tx_gain_profile(const size_t chan = 0) = 0;
1339 
1341  void set_tx_gain(double gain, size_t chan = 0){
1342  return this->set_tx_gain(gain, ALL_GAINS, chan);
1343  }
1344 
1355  virtual void set_normalized_tx_gain(double gain, size_t chan = 0) = 0;
1356 
1364  virtual double get_tx_gain(const std::string &name, size_t chan = 0) = 0;
1365 
1367  double get_tx_gain(size_t chan = 0){
1368  return this->get_tx_gain(ALL_GAINS, chan);
1369  }
1370 
1381  virtual double get_normalized_tx_gain(size_t chan = 0) = 0;
1382 
1390  virtual gain_range_t get_tx_gain_range(const std::string &name, size_t chan = 0) = 0;
1391 
1394  return this->get_tx_gain_range(ALL_GAINS, chan);
1395  }
1396 
1403  virtual std::vector<std::string> get_tx_gain_names(size_t chan = 0) = 0;
1404 
1410  virtual void set_tx_antenna(const std::string &ant, size_t chan = 0) = 0;
1411 
1417  virtual std::string get_tx_antenna(size_t chan = 0) = 0;
1418 
1424  virtual std::vector<std::string> get_tx_antennas(size_t chan = 0) = 0;
1425 
1431  virtual void set_tx_bandwidth(double bandwidth, size_t chan = 0) = 0;
1432 
1438  virtual double get_tx_bandwidth(size_t chan = 0) = 0;
1439 
1445  virtual meta_range_t get_tx_bandwidth_range(size_t chan = 0) = 0;
1446 
1454  virtual dboard_iface::sptr get_tx_dboard_iface(size_t chan = 0) = 0;
1455 
1462  virtual sensor_value_t get_tx_sensor(const std::string &name, size_t chan = 0) = 0;
1463 
1469  virtual std::vector<std::string> get_tx_sensor_names(size_t chan = 0) = 0;
1470 
1477  virtual void set_tx_dc_offset(const std::complex<double> &offset, size_t chan = ALL_CHANS) = 0;
1478 
1483  virtual meta_range_t get_tx_dc_offset_range(size_t chan = ALL_CHANS) = 0;
1484 
1492  virtual void set_tx_iq_balance(const std::complex<double> &correction, size_t chan = ALL_CHANS) = 0;
1493 
1494  /*******************************************************************
1495  * GPIO methods
1496  ******************************************************************/
1497 
1503  virtual std::vector<std::string> get_gpio_banks(const size_t mboard) = 0;
1504 
1521  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;
1522 
1548  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;
1549 
1566  virtual uint32_t get_gpio_attr(const std::string &bank, const std::string &attr, const size_t mboard = 0) = 0;
1567 
1593  virtual std::vector<std::string> get_gpio_string_attr(const std::string &bank, const std::string &attr, const size_t mboard = 0) = 0;
1594 
1595  /*******************************************************************
1596  * Register IO methods
1597  ******************************************************************/
1599  size_t bitwidth;
1600  bool readable;
1601  bool writable;
1602  };
1603 
1609  virtual std::vector<std::string> enumerate_registers(const size_t mboard = 0) = 0;
1610 
1617  virtual register_info_t get_register_info(const std::string &path, const size_t mboard = 0) = 0;
1618 
1626  virtual void write_register(const std::string &path, const uint32_t field, const uint64_t value, const size_t mboard = 0) = 0;
1627 
1635  virtual uint64_t read_register(const std::string &path, const uint32_t field, const size_t mboard = 0) = 0;
1636 
1637  /*******************************************************************
1638  * Filter API methods
1639  ******************************************************************/
1640 
1651  virtual std::vector<std::string> get_filter_names(const std::string &search_mask = "") = 0;
1652 
1658  virtual filter_info_base::sptr get_filter(const std::string &path) = 0;
1659 
1667  virtual void set_filter(const std::string &path, filter_info_base::sptr filter) = 0;
1668 
1669 };
1670 
1671 }}
1672 
1673 #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:1089
boost::shared_ptr< wb_iface > sptr
Definition: wb_iface.hpp:22
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:1367
void set_tx_gain(double gain, size_t chan=0)
A convenience wrapper for setting overall TX gain.
Definition: multi_usrp.hpp:1341
Definition: time_spec.hpp:29
static const size_t ALL_MBOARDS
A wildcard motherboard index.
Definition: multi_usrp.hpp:103
bool readable
Definition: multi_usrp.hpp:1600
boost::shared_ptr< device > sptr
Definition: device.hpp:31
boost::shared_ptr< multi_usrp > sptr
Definition: multi_usrp.hpp:98
Definition: multi_usrp.hpp:1598
double get_rx_gain(size_t chan=0)
A convenience wrapper for getting overall RX gain.
Definition: multi_usrp.hpp:1063
Definition: tune_request.hpp:25
boost::shared_ptr< rx_streamer > sptr
Definition: stream.hpp:172
static const std::string ALL_GAINS
A wildcard gain element name.
Definition: multi_usrp.hpp:109
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:96
Definition: stream.hpp:58
#define UHD_API
Definition: config.h:68
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:1021
static const std::string ALL_LOS
A wildcard LO stage name.
Definition: multi_usrp.hpp:112
Definition: subdev_spec.hpp:62
bool writable
Definition: multi_usrp.hpp:1601
Definition: ranges.hpp:64
size_t bitwidth
Definition: multi_usrp.hpp:1599
boost::shared_ptr< tx_streamer > sptr
Definition: stream.hpp:248
static const size_t ALL_CHANS
A wildcard channel index.
Definition: multi_usrp.hpp:106
gain_range_t get_tx_gain_range(size_t chan=0)
A convenience wrapper for getting overall TX gain range.
Definition: multi_usrp.hpp:1393
Definition: device_addr.hpp:38