summaryrefslogtreecommitdiffstats
path: root/host/include
diff options
context:
space:
mode:
authorJosh Blum <josh@joshknows.com>2011-10-23 18:02:43 -0700
committerJosh Blum <josh@joshknows.com>2011-11-03 20:37:13 -0700
commitc63a38e1f9b383663e5bb52a1ae35b54bbc0104e (patch)
tree60324c9a3eb9ad0bdca8b25669842db8f31a2bf2 /host/include
parentf11d64579a7c1421cc2b0f04c85f0c0e82b6a74e (diff)
downloaduhd-c63a38e1f9b383663e5bb52a1ae35b54bbc0104e.tar.gz
uhd-c63a38e1f9b383663e5bb52a1ae35b54bbc0104e.tar.bz2
uhd-c63a38e1f9b383663e5bb52a1ae35b54bbc0104e.zip
usrp: add api call to adjust phase/mag imbalance
Diffstat (limited to 'host/include')
-rw-r--r--host/include/uhd/usrp/multi_usrp.hpp20
1 files changed, 19 insertions, 1 deletions
diff --git a/host/include/uhd/usrp/multi_usrp.hpp b/host/include/uhd/usrp/multi_usrp.hpp
index 9fbc9cfe6..1cbe3a684 100644
--- a/host/include/uhd/usrp/multi_usrp.hpp
+++ b/host/include/uhd/usrp/multi_usrp.hpp
@@ -22,6 +22,7 @@
#define UHD_USRP_MULTI_USRP_REF_SOURCES_API
#define UHD_USRP_MULTI_USRP_GET_RATES_API
#define UHD_USRP_MULTI_USRP_DC_OFFSET_API
+#define UHD_USRP_MULTI_USRP_CORRECTION_API
#include <uhd/config.hpp>
#include <uhd/device.hpp>
@@ -530,7 +531,6 @@ public:
*/
virtual std::vector<std::string> get_rx_sensor_names(size_t chan = 0) = 0;
-
/*!
* Enable/disable the automatic RX DC offset correction.
* The automatic correction subtracts out the long-run average.
@@ -554,6 +554,15 @@ public:
*/
virtual void set_rx_dc_offset(const std::complex<double> &offset, size_t chan = ALL_CHANS) = 0;
+ /*!
+ * Set the RX frontend IQ imbalance and gain correction.
+ * Use this to adjust the magnitude and phase of I and Q.
+ *
+ * \param correction the complex correction value
+ * \param chan the channel index 0 to N-1
+ */
+ virtual void set_rx_correction(const std::complex<double> &correction, size_t chan = ALL_CHANS) = 0;
+
/*******************************************************************
* TX methods
******************************************************************/
@@ -759,6 +768,15 @@ public:
*/
virtual void set_tx_dc_offset(const std::complex<double> &offset, size_t chan = ALL_CHANS) = 0;
+ /*!
+ * Set the TX frontend IQ imbalance and gain correction.
+ * Use this to adjust the magnitude and phase of I and Q.
+ *
+ * \param correction the complex correction value
+ * \param chan the channel index 0 to N-1
+ */
+ virtual void set_tx_correction(const std::complex<double> &correction, size_t chan = ALL_CHANS) = 0;
+
};
}}