aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorAaron Rossetto <aaron.rossetto@ni.com>2020-06-01 15:21:43 -0500
committerAaron Rossetto <aaron.rossetto@ni.com>2020-06-09 07:10:57 -0500
commit18460e34787772d606846c3b09190b80ae1e621d (patch)
treecf53cdc4043c0fb59eac624eb1b9a5b7fd30f49b
parent87ba553c3f4504ce4bce09b67744a92edec1a41b (diff)
downloaduhd-18460e34787772d606846c3b09190b80ae1e621d.tar.gz
uhd-18460e34787772d606846c3b09190b80ae1e621d.tar.bz2
uhd-18460e34787772d606846c3b09190b80ae1e621d.zip
python: Add radio RFNoC block controller bindings
-rw-r--r--host/include/uhd/rfnoc/radio_control.hpp2
-rw-r--r--host/lib/rfnoc/radio_control_impl.cpp1
-rw-r--r--host/lib/rfnoc/radio_control_python.hpp171
-rw-r--r--host/python/pyuhd.cpp2
-rw-r--r--host/python/uhd/rfnoc.py1
5 files changed, 175 insertions, 2 deletions
diff --git a/host/include/uhd/rfnoc/radio_control.hpp b/host/include/uhd/rfnoc/radio_control.hpp
index 867b2a919..349cca536 100644
--- a/host/include/uhd/rfnoc/radio_control.hpp
+++ b/host/include/uhd/rfnoc/radio_control.hpp
@@ -24,7 +24,7 @@ class radio_control : public noc_block_base
public:
static const std::string ALL_LOS;
static const std::string ALL_GAINS;
- static const size_t ALL_CHANS;
+ static constexpr size_t ALL_CHANS = size_t(~0);
RFNOC_DECLARE_BLOCK(radio_control)
diff --git a/host/lib/rfnoc/radio_control_impl.cpp b/host/lib/rfnoc/radio_control_impl.cpp
index b3da7ec13..c6eac11f8 100644
--- a/host/lib/rfnoc/radio_control_impl.cpp
+++ b/host/lib/rfnoc/radio_control_impl.cpp
@@ -24,7 +24,6 @@ const std::string DEFAULT_GAIN_PROFILE("default");
const std::string radio_control::ALL_LOS = "all";
const std::string radio_control::ALL_GAINS = "";
-const size_t radio_control::ALL_CHANS = size_t(~0);
const uint16_t radio_control_impl::MAJOR_COMPAT = 0;
const uint16_t radio_control_impl::MINOR_COMPAT = 0;
diff --git a/host/lib/rfnoc/radio_control_python.hpp b/host/lib/rfnoc/radio_control_python.hpp
new file mode 100644
index 000000000..f16f0b6e9
--- /dev/null
+++ b/host/lib/rfnoc/radio_control_python.hpp
@@ -0,0 +1,171 @@
+//
+// Copyright 2020 Ettus Research, a National Instruments Brand
+//
+// SPDX-License-Identifier: GPL-3.0-or-later
+//
+
+#pragma once
+
+#include <uhd/rfnoc/radio_control.hpp>
+#include "block_controller_factory_python.hpp"
+
+using namespace uhd::rfnoc;
+
+void export_radio_control(py::module& m)
+{
+ py::class_<radio_control, noc_block_base, radio_control::sptr>(m, "radio_control")
+ .def(py::init(&block_controller_factory<radio_control>::make_from))
+ .def("set_rate", &radio_control::set_rate)
+ .def("get_rate", &radio_control::get_rate)
+ .def("get_rate_range", &radio_control::get_rate_range)
+ .def("get_tx_antenna", &radio_control::get_tx_antenna)
+ .def("get_tx_antennas", &radio_control::get_tx_antennas)
+ .def("set_tx_antenna", &radio_control::set_tx_antenna)
+ .def("get_rx_antenna", &radio_control::get_rx_antenna)
+ .def("get_rx_antennas", &radio_control::get_rx_antennas)
+ .def("set_rx_antenna", &radio_control::set_rx_antenna)
+ .def("get_tx_frequency", &radio_control::get_tx_frequency)
+ .def("set_tx_frequency", &radio_control::set_tx_frequency)
+ .def("set_tx_tune_args", &radio_control::set_tx_tune_args)
+ .def("get_tx_frequency_range", &radio_control::get_tx_frequency_range)
+ .def("get_rx_frequency", &radio_control::get_rx_frequency)
+ .def("set_rx_frequency", &radio_control::set_rx_frequency)
+ .def("set_rx_tune_args", &radio_control::set_rx_tune_args)
+ .def("get_rx_frequency_range", &radio_control::get_rx_frequency_range)
+ .def("get_tx_gain_names", &radio_control::get_tx_gain_names)
+ .def("get_tx_gain_range",
+ py::overload_cast<const size_t>(
+ &radio_control::get_tx_gain_range, py::const_),
+ py::arg("chan"))
+ .def("get_tx_gain_range",
+ py::overload_cast<const std::string&, const size_t>(
+ &radio_control::get_tx_gain_range, py::const_),
+ py::arg("name"),
+ py::arg("chan"))
+ .def("get_tx_gain",
+ py::overload_cast<const size_t>(&radio_control::get_tx_gain),
+ py::arg("chan"))
+ .def("get_tx_gain",
+ py::overload_cast<const std::string&, const size_t>(
+ &radio_control::get_tx_gain),
+ py::arg("name"),
+ py::arg("chan"))
+ .def("set_tx_gain",
+ py::overload_cast<const double, const size_t>(&radio_control::set_tx_gain),
+ py::arg("gain"),
+ py::arg("chan"))
+ .def("set_tx_gain",
+ py::overload_cast<const double, const std::string&, const size_t>(
+ &radio_control::set_tx_gain),
+ py::arg("gain"),
+ py::arg("name"),
+ py::arg("chan"))
+ .def("has_tx_power_reference", &radio_control::has_tx_power_reference)
+ .def("set_tx_power_reference", &radio_control::set_tx_power_reference)
+ .def("get_tx_power_reference", &radio_control::get_tx_power_reference)
+ .def("get_tx_power_ref_keys",
+ &radio_control::get_tx_power_ref_keys,
+ py::arg("chan") = 0)
+ .def("get_rx_gain_names", &radio_control::get_rx_gain_names)
+ .def("get_rx_gain_range",
+ py::overload_cast<const size_t>(
+ &radio_control::get_rx_gain_range, py::const_),
+ py::arg("chan"))
+ .def("get_rx_gain_range",
+ py::overload_cast<const std::string&, const size_t>(
+ &radio_control::get_rx_gain_range, py::const_),
+ py::arg("name"),
+ py::arg("chan"))
+ .def("get_rx_gain",
+ py::overload_cast<const size_t>(&radio_control::get_rx_gain),
+ py::arg("chan"))
+ .def("get_rx_gain",
+ py::overload_cast<const std::string&, const size_t>(
+ &radio_control::get_rx_gain),
+ py::arg("name"),
+ py::arg("chan"))
+ .def("set_rx_gain",
+ py::overload_cast<const double, const size_t>(&radio_control::set_rx_gain),
+ py::arg("gain"),
+ py::arg("chan"))
+ .def("set_rx_gain",
+ py::overload_cast<const double, const std::string&, const size_t>(
+ &radio_control::set_rx_gain),
+ py::arg("gain"),
+ py::arg("name"),
+ py::arg("chan"))
+ .def("set_rx_agc", &radio_control::set_rx_agc)
+ .def("has_rx_power_reference", &radio_control::has_rx_power_reference)
+ .def("set_rx_power_reference", &radio_control::set_rx_power_reference)
+ .def("get_rx_power_reference", &radio_control::get_rx_power_reference)
+ .def("get_rx_power_ref_keys",
+ &radio_control::get_rx_power_ref_keys,
+ py::arg("chan") = 0)
+ .def("get_tx_gain_profile_names", &radio_control::get_tx_gain_profile_names)
+ .def("get_rx_gain_profile_names", &radio_control::get_rx_gain_profile_names)
+ .def("set_tx_gain_profile", &radio_control::set_tx_gain_profile)
+ .def("set_rx_gain_profile", &radio_control::set_rx_gain_profile)
+ .def("get_tx_gain_profile", &radio_control::get_tx_gain_profile)
+ .def("get_rx_gain_profile", &radio_control::get_rx_gain_profile)
+ .def("get_tx_bandwidth_range", &radio_control::get_tx_bandwidth_range)
+ .def("get_tx_bandwidth", &radio_control::get_tx_bandwidth)
+ .def("set_tx_bandwidth", &radio_control::set_tx_bandwidth)
+ .def("get_rx_bandwidth_range", &radio_control::get_rx_bandwidth_range)
+ .def("get_rx_bandwidth", &radio_control::get_rx_bandwidth)
+ .def("set_rx_bandwidth", &radio_control::set_rx_bandwidth)
+ .def("get_rx_lo_names", &radio_control::get_rx_lo_names)
+ .def("get_rx_lo_sources", &radio_control::get_rx_lo_sources)
+ .def("get_rx_lo_freq_range", &radio_control::get_rx_lo_freq_range)
+ .def("set_rx_lo_source", &radio_control::set_rx_lo_source)
+ .def("get_rx_lo_source", &radio_control::get_rx_lo_source)
+ .def("set_rx_lo_export_enabled", &radio_control::set_rx_lo_export_enabled)
+ .def("get_rx_lo_export_enabled", &radio_control::get_rx_lo_export_enabled)
+ .def("set_rx_lo_freq", &radio_control::set_rx_lo_freq)
+ .def("get_rx_lo_freq", &radio_control::get_rx_lo_freq)
+ .def("get_tx_lo_names", &radio_control::get_tx_lo_names)
+ .def("get_tx_lo_sources", &radio_control::get_tx_lo_sources)
+ .def("get_tx_lo_freq_range", &radio_control::get_tx_lo_freq_range)
+ .def("set_tx_lo_source", &radio_control::set_tx_lo_source)
+ .def("get_tx_lo_source", &radio_control::get_tx_lo_source)
+ .def("set_tx_lo_export_enabled", &radio_control::set_tx_lo_export_enabled)
+ .def("get_tx_lo_export_enabled", &radio_control::get_tx_lo_export_enabled)
+ .def("set_tx_lo_freq", &radio_control::set_tx_lo_freq)
+ .def("get_tx_lo_freq", &radio_control::get_tx_lo_freq)
+ .def("set_tx_dc_offset", &radio_control::set_tx_dc_offset)
+ .def("get_tx_dc_offset_range", &radio_control::get_tx_dc_offset_range)
+ .def("set_tx_iq_balance", &radio_control::set_tx_iq_balance)
+ .def("set_rx_dc_offset",
+ py::overload_cast<const bool, size_t>(&radio_control::set_rx_dc_offset),
+ py::arg("enb"),
+ py::arg("chan") = radio_control::ALL_CHANS)
+ .def("set_rx_dc_offset",
+ py::overload_cast<const std::complex<double>&, size_t>(
+ &radio_control::set_rx_dc_offset),
+ py::arg("offset"),
+ py::arg("chan"))
+ .def("get_rx_dc_offset_range", &radio_control::get_rx_dc_offset_range)
+ .def("set_rx_iq_balance",
+ py::overload_cast<const bool, size_t>(&radio_control::set_rx_iq_balance),
+ py::arg("enb"),
+ py::arg("chan"))
+ .def("set_rx_iq_balance",
+ py::overload_cast<const std::complex<double>&, size_t>(
+ &radio_control::set_rx_iq_balance),
+ py::arg("correction"),
+ py::arg("chan"))
+ .def("get_gpio_banks", &radio_control::get_gpio_banks)
+ .def("set_gpio_attr", &radio_control::set_gpio_attr)
+ .def("get_gpio_attr", &radio_control::get_gpio_attr)
+ .def("get_rx_sensor_names", &radio_control::get_rx_sensor_names)
+ .def("get_rx_sensor", &radio_control::get_rx_sensor)
+ .def("get_tx_sensor_names", &radio_control::get_tx_sensor_names)
+ .def("get_tx_sensor", &radio_control::get_tx_sensor)
+ .def("issue_stream_cmd", &radio_control::issue_stream_cmd)
+ .def("enable_rx_timestamps", &radio_control::enable_rx_timestamps)
+ .def("get_slot_name", &radio_control::get_slot_name)
+ .def("get_chan_from_dboard_fe", &radio_control::get_chan_from_dboard_fe)
+ .def("get_dboard_fe_from_chan", &radio_control::get_dboard_fe_from_chan)
+ .def("get_fe_name", &radio_control::get_fe_name)
+ .def("set_db_eeprom", &radio_control::set_db_eeprom)
+ .def("get_db_eeprom", &radio_control::get_db_eeprom);
+}
diff --git a/host/python/pyuhd.cpp b/host/python/pyuhd.cpp
index 2551c8320..45752d6d1 100644
--- a/host/python/pyuhd.cpp
+++ b/host/python/pyuhd.cpp
@@ -18,6 +18,7 @@ namespace py = pybind11;
#include "rfnoc/duc_block_control_python.hpp"
#include "rfnoc/fir_filter_block_control_python.hpp"
#include "rfnoc/fosphor_block_control_python.hpp"
+#include "rfnoc/radio_control_python.hpp"
#include "rfnoc/rfnoc_python.hpp"
#include "stream_python.hpp"
#include "types/filters_python.hpp"
@@ -82,6 +83,7 @@ PYBIND11_MODULE(libpyuhd, m)
export_duc_block_control(rfnoc_module);
export_fosphor_block_control(rfnoc_module);
export_fir_filter_block_control(rfnoc_module);
+ export_radio_control(rfnoc_module);
// Register calibration submodule
auto cal_module = m.def_submodule("cal", "Calibration Objects");
diff --git a/host/python/uhd/rfnoc.py b/host/python/uhd/rfnoc.py
index a238b5bb5..0bbf2c998 100644
--- a/host/python/uhd/rfnoc.py
+++ b/host/python/uhd/rfnoc.py
@@ -22,4 +22,5 @@ DdcBlockControl = lib.rfnoc.ddc_block_control
DucBlockControl = lib.rfnoc.duc_block_control
FosphorBlockControl = lib.rfnoc.fosphor_block_control
FirFilterBlockControl = lib.rfnoc.fir_filter_block_control
+RadioControl = lib.rfnoc.radio_control