aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--host/include/uhd/features/discoverable_feature.hpp1
-rw-r--r--host/include/uhd/features/gpio_power_iface.hpp84
-rw-r--r--host/lib/include/uhdlib/usrp/common/mpmd_mb_controller.hpp21
-rw-r--r--host/lib/usrp/mpmd/mpmd_mb_controller.cpp41
4 files changed, 147 insertions, 0 deletions
diff --git a/host/include/uhd/features/discoverable_feature.hpp b/host/include/uhd/features/discoverable_feature.hpp
index b1a03eaea..e56c3f6e3 100644
--- a/host/include/uhd/features/discoverable_feature.hpp
+++ b/host/include/uhd/features/discoverable_feature.hpp
@@ -35,6 +35,7 @@ public:
ADC_SELF_CALIBRATION,
REF_CLK_CALIBRATION,
TRIG_IO_MODE,
+ GPIO_POWER,
};
virtual ~discoverable_feature() = default;
diff --git a/host/include/uhd/features/gpio_power_iface.hpp b/host/include/uhd/features/gpio_power_iface.hpp
new file mode 100644
index 000000000..5f236cfec
--- /dev/null
+++ b/host/include/uhd/features/gpio_power_iface.hpp
@@ -0,0 +1,84 @@
+//
+// Copyright 2021 Ettus Research, a National Instruments Brand
+//
+// SPDX-License-Identifier: GPL-3.0-or-later
+//
+
+#pragma once
+
+#include <uhd/features/discoverable_feature.hpp>
+#include <memory>
+#include <string>
+#include <vector>
+
+namespace uhd { namespace features {
+
+/*! Interface to provide access to configuring the voltage level and external
+ * power export configurations of GPIO banks.
+ */
+class gpio_power_iface : public discoverable_feature
+{
+public:
+ using sptr = std::shared_ptr<gpio_power_iface>;
+
+ static discoverable_feature::feature_id_t get_feature_id()
+ {
+ return discoverable_feature::GPIO_POWER;
+ }
+
+ std::string get_feature_name() const
+ {
+ return "GPIO power configuration";
+ }
+
+ virtual ~gpio_power_iface() = default;
+
+ /*! Return what I/O voltage levels are supported on the given port. Voltages
+ * use a V in place of the decimal point - typical values include "1V8" for
+ * 1.8 volts, "3V3" for 3.3 volts, et cetera.
+ *
+ * \param port Port to list supported voltages for.
+ * \return A vector of supported voltage levels.
+ */
+ virtual std::vector<std::string> get_supported_voltages(
+ const std::string& port) const = 0;
+
+ /*! Set the I/O voltage on the given port to the given value.
+ *
+ * \param port Port to set the voltage on.
+ * \param voltage Voltage level to set. See \ref get_supported_voltages for a list
+ * of supported voltages.
+ */
+ virtual void set_port_voltage(
+ const std::string& port, const std::string& voltage) = 0;
+
+ /*! Gets the current I/O voltage level that the port is set to.
+ *
+ * \param port Port to retrieve the voltage level for
+ * \return The voltage level for the given port
+ */
+ virtual std::string get_port_voltage(const std::string& port) const = 0;
+
+ /*! Enables or disables the power supply exposed through the GPIO ports. The
+ * GPIO lines will function without external power enabled - the power supply
+ * is simply to provide a means for external circuitry to receive power from
+ * the device. See your device's documentation for more information on the
+ * voltage and current specifications of the external power supply.
+ *
+ * \param port The port to export power through.
+ * \param enable true to enable power, false to disable.
+ */
+ virtual void set_external_power(const std::string& port, bool enable) = 0;
+
+ /*! Retrieve the status of the external power on the given port. The status
+ * can be one of three values:
+ * "OFF" - External power is disabled (the default)
+ * "ON" - External power is on and functioning normally
+ * "FAULT" - The external power supply has encountered a fault condition.
+ *
+ * \param port Port to retrieve status from
+ */
+ virtual std::string get_external_power_status(const std::string& port) const = 0;
+};
+
+}} // namespace uhd::features
diff --git a/host/lib/include/uhdlib/usrp/common/mpmd_mb_controller.hpp b/host/lib/include/uhdlib/usrp/common/mpmd_mb_controller.hpp
index 2d751a4e5..f4f6e0ba7 100644
--- a/host/lib/include/uhdlib/usrp/common/mpmd_mb_controller.hpp
+++ b/host/lib/include/uhdlib/usrp/common/mpmd_mb_controller.hpp
@@ -6,6 +6,7 @@
#pragma once
+#include <uhd/features/gpio_power_iface.hpp>
#include <uhd/features/ref_clk_calibration_iface.hpp>
#include <uhd/features/trig_io_mode_iface.hpp>
#include <uhd/rfnoc/mb_controller.hpp>
@@ -13,6 +14,7 @@
#include <uhdlib/features/fpga_load_notification_iface.hpp>
#include <uhdlib/usrp/common/rpc.hpp>
#include <uhdlib/utils/rpc.hpp>
+#include <map>
#include <memory>
namespace uhd { namespace rfnoc {
@@ -169,9 +171,28 @@ public:
uhd::usrp::mpmd_rpc_iface::sptr _rpcc;
};
+ class gpio_power : public uhd::features::gpio_power_iface
+ {
+ public:
+ using sptr = std::shared_ptr<gpio_power>;
+
+ gpio_power(uhd::usrp::dio_rpc_iface::sptr rpcc, const std::vector<std::string>& ports);
+
+ std::vector<std::string> get_supported_voltages(const std::string& port) const override;
+ void set_port_voltage(const std::string& port, const std::string& voltage) override;
+ std::string get_port_voltage(const std::string& port) const override;
+ void set_external_power(const std::string& port, bool enable) override;
+ std::string get_external_power_status(const std::string& port) const override;
+
+ private:
+ uhd::usrp::dio_rpc_iface::sptr _rpcc;
+ const std::vector<std::string> _ports;
+ };
+
fpga_onload::sptr _fpga_onload;
ref_clk_calibration::sptr _ref_clk_cal;
trig_io_mode::sptr _trig_io_mode;
+ gpio_power::sptr _gpio_power;
};
}} // namespace uhd::rfnoc
diff --git a/host/lib/usrp/mpmd/mpmd_mb_controller.cpp b/host/lib/usrp/mpmd/mpmd_mb_controller.cpp
index b79abcee0..cdc86b086 100644
--- a/host/lib/usrp/mpmd/mpmd_mb_controller.cpp
+++ b/host/lib/usrp/mpmd/mpmd_mb_controller.cpp
@@ -74,6 +74,41 @@ void mpmd_mb_controller::trig_io_mode::set_trig_io_mode(const uhd::trig_io_mode_
}
}
+mpmd_mb_controller::gpio_power::gpio_power(
+ uhd::usrp::dio_rpc_iface::sptr rpcc, const std::vector<std::string>& ports)
+ : _rpcc(rpcc), _ports(ports)
+{}
+
+std::vector<std::string> mpmd_mb_controller::gpio_power::get_supported_voltages(
+ const std::string& port) const
+{
+ return _rpcc->dio_get_supported_voltage_levels(port);
+}
+
+void mpmd_mb_controller::gpio_power::set_port_voltage(
+ const std::string& port, const std::string& voltage)
+{
+ _rpcc->dio_set_voltage_level(port, voltage);
+}
+
+std::string mpmd_mb_controller::gpio_power::get_port_voltage(
+ const std::string& port) const
+{
+ return _rpcc->dio_get_voltage_level(port);
+}
+
+void mpmd_mb_controller::gpio_power::set_external_power(
+ const std::string& port, bool enable)
+{
+ _rpcc->dio_set_external_power(port, enable);
+}
+
+std::string mpmd_mb_controller::gpio_power::get_external_power_status(
+ const std::string& port) const
+{
+ return _rpcc->dio_get_external_power_state(port);
+}
+
mpmd_mb_controller::mpmd_mb_controller(
uhd::usrp::mpmd_rpc_iface::sptr rpcc, uhd::device_addr_t device_info)
: _rpc(rpcc), _device_info(device_info)
@@ -106,6 +141,12 @@ mpmd_mb_controller::mpmd_mb_controller(
_trig_io_mode = std::make_shared<trig_io_mode>(_rpc);
register_feature(_trig_io_mode);
}
+
+ if (_rpc->supports_feature("gpio_power")) {
+ _gpio_power = std::make_shared<gpio_power>(
+ std::make_shared<uhd::usrp::dio_rpc>(get_rpc_client()), _gpio_banks);
+ register_feature(_gpio_power);
+ }
}
/******************************************************************************