aboutsummaryrefslogtreecommitdiffstats
path: root/host/utils
diff options
context:
space:
mode:
Diffstat (limited to 'host/utils')
-rw-r--r--host/utils/CMakeLists.txt1
-rwxr-xr-xhost/utils/rfnoc_image_builder.py4
-rw-r--r--host/utils/uhd_adc_self_cal.cpp76
3 files changed, 79 insertions, 2 deletions
diff --git a/host/utils/CMakeLists.txt b/host/utils/CMakeLists.txt
index ab7d645f4..1ac0b1c99 100644
--- a/host/utils/CMakeLists.txt
+++ b/host/utils/CMakeLists.txt
@@ -16,6 +16,7 @@ set(util_runtime_sources
uhd_cal_rx_iq_balance.cpp
uhd_cal_tx_dc_offset.cpp
uhd_cal_tx_iq_balance.cpp
+ uhd_adc_self_cal.cpp
)
#for each source: build an executable and install
diff --git a/host/utils/rfnoc_image_builder.py b/host/utils/rfnoc_image_builder.py
index 285dfe3e9..07419cb90 100755
--- a/host/utils/rfnoc_image_builder.py
+++ b/host/utils/rfnoc_image_builder.py
@@ -46,7 +46,7 @@ def setup_parser():
help="Path to grc file to generate config from")
parser.add_argument(
"-F", "--fpga-dir",
- help="Path to directory for the FPGA source tree."
+ help="Path to directory for the FPGA source tree. "
"Defaults to the FPGA source tree of the current repo.",
required=False,
default=None)
@@ -79,7 +79,7 @@ def setup_parser():
action="store_true")
parser.add_argument(
"-d", "--device",
- help="Device to be programmed [x300, x310, e310, e320, n300, n310, n320]."
+ help="Device to be programmed [x300, x310, e310, e320, n300, n310, n320, x410]. "
"Needs to be specified either here, or in the configuration file.",
default=None)
parser.add_argument(
diff --git a/host/utils/uhd_adc_self_cal.cpp b/host/utils/uhd_adc_self_cal.cpp
new file mode 100644
index 000000000..39dab3e15
--- /dev/null
+++ b/host/utils/uhd_adc_self_cal.cpp
@@ -0,0 +1,76 @@
+//
+// Copyright 2020 Ettus Research, a National Instruments Brand
+//
+// SPDX-License-Identifier: GPL-3.0-or-later
+//
+
+#include <uhd/features/adc_self_calibration_iface.hpp>
+#include <uhd/rfnoc/radio_control.hpp>
+#include <uhd/rfnoc_graph.hpp>
+#include <uhd/utils/safe_main.hpp>
+#include <uhd/version.hpp>
+#include <boost/program_options.hpp>
+#include <iostream>
+#include <sstream>
+
+namespace po = boost::program_options;
+using namespace uhd;
+
+/****************************************************************************
+ * main
+ ***************************************************************************/
+int UHD_SAFE_MAIN(int argc, char* argv[])
+{
+ po::options_description desc("Allowed options");
+ // clang-format off
+ desc.add_options()
+ ("help", "help message")
+ ("version", "print the version string and exit")
+ ("args", po::value<std::string>()->default_value(""), "device address args")
+ ;
+ // clang-format on
+
+ po::variables_map vm;
+ po::store(po::parse_command_line(argc, argv, desc), vm);
+ po::notify(vm);
+
+ // print the help message
+ if (vm.count("help")) {
+ std::cout << "UHD ADC self calibration " << desc << std::endl;
+ return EXIT_FAILURE;
+ }
+
+ if (vm.count("version")) {
+ std::cout << uhd::get_version_string() << std::endl;
+ return EXIT_SUCCESS;
+ }
+
+ rfnoc::rfnoc_graph::sptr graph =
+ rfnoc::rfnoc_graph::make(vm["args"].as<std::string>());
+
+ size_t num_calibrations = 0;
+ for (auto radio_id : graph->find_blocks("Radio")) {
+ auto radio_blk = graph->get_block<uhd::rfnoc::radio_control>(radio_id);
+ if (radio_blk->has_feature<uhd::features::adc_self_calibration_iface>()) {
+ auto& feature =
+ radio_blk->get_feature<uhd::features::adc_self_calibration_iface>();
+
+ // Run it on all channels
+ const size_t num_channels = radio_blk->get_num_output_ports();
+ for (size_t i = 0; i < num_channels; i++) {
+ std::cout << "Calibrating on channel " << i << " of " << radio_id << "..."
+ << std::endl;
+ feature.run(i);
+ std::cout << "Finished!" << std::endl;
+ num_calibrations++;
+ }
+ }
+ }
+ if (num_calibrations > 0) {
+ std::cout << "Calibrated " << num_calibrations << " channels" << std::endl;
+ } else {
+ std::cerr << "WARNING: Did not find any channels to calibrate!" << std::endl;
+ }
+
+ return EXIT_SUCCESS;
+}