aboutsummaryrefslogtreecommitdiffstats
path: root/host/lib/usrp/x400/x400_radio_control.cpp
diff options
context:
space:
mode:
authorMartin Anderseck <martin.anderseck@ni.com>2021-12-15 16:27:23 +0100
committerAaron Rossetto <aaron.rossetto@ni.com>2022-01-13 14:35:55 -0600
commitee8e4f2c9b1bae8085dff6199c2bade0914748f7 (patch)
treecf3ad50af9318a1556e4425b9389e760833fbc38 /host/lib/usrp/x400/x400_radio_control.cpp
parent6bb7d61251abd303049dfd0f47bd0266656797fb (diff)
downloaduhd-ee8e4f2c9b1bae8085dff6199c2bade0914748f7.tar.gz
uhd-ee8e4f2c9b1bae8085dff6199c2bade0914748f7.tar.bz2
uhd-ee8e4f2c9b1bae8085dff6199c2bade0914748f7.zip
SPI: Implement SPI engine for x410
Add SPI Core host implementation for x410 and a discoverable feature to make it accessible.
Diffstat (limited to 'host/lib/usrp/x400/x400_radio_control.cpp')
-rw-r--r--host/lib/usrp/x400/x400_radio_control.cpp30
1 files changed, 25 insertions, 5 deletions
diff --git a/host/lib/usrp/x400/x400_radio_control.cpp b/host/lib/usrp/x400/x400_radio_control.cpp
index a58f522bf..75719f6a2 100644
--- a/host/lib/usrp/x400/x400_radio_control.cpp
+++ b/host/lib/usrp/x400/x400_radio_control.cpp
@@ -5,14 +5,17 @@
//
#include "x400_radio_control.hpp"
+#include "x400_gpio_control.hpp"
#include <uhd/rfnoc/registry.hpp>
+#include <uhd/types/serial.hpp>
#include <uhd/utils/log.hpp>
#include <uhd/utils/math.hpp>
+#include <uhdlib/rfnoc/reg_iface_adapter.hpp>
#include <uhdlib/usrp/common/x400_rfdc_control.hpp>
+#include <uhdlib/usrp/cores/spi_core_4000.hpp>
#include <uhdlib/usrp/dboard/debug_dboard.hpp>
#include <uhdlib/usrp/dboard/null_dboard.hpp>
#include <uhdlib/usrp/dboard/zbx/zbx_dboard.hpp>
-#include <uhdlib/rfnoc/reg_iface_adapter.hpp>
namespace uhd { namespace rfnoc {
@@ -182,8 +185,25 @@ x400_radio_control_impl::x400_radio_control_impl(make_args_ptr make_args)
auto mpm_rpc = _mb_control->dynamic_cast_rpc_as<uhd::usrp::mpmd_rpc_iface>();
if (mpm_rpc->get_gpio_banks().size() > 0) {
- _gpios = std::make_shared<x400::gpio_control>(_rpcc,
- RFNOC_MAKE_WB_IFACE(regmap::PERIPH_BASE + 0xC000, 0));
+ _gpios = std::make_shared<x400::gpio_control>(
+ _rpcc, RFNOC_MAKE_WB_IFACE(regmap::PERIPH_BASE + 0xC000, 0));
+
+ auto gpio_port_mapper = std::shared_ptr<uhd::mapper::gpio_port_mapper>(
+ new uhd::rfnoc::x400::x400_gpio_port_mapping);
+ auto spicore = uhd::cores::spi_core_4000::make(
+ [this](const uint32_t addr, const uint32_t data) {
+ regs().poke32(addr, data, get_command_time(0));
+ },
+ [this](
+ const uint32_t addr) { return regs().peek32(addr, get_command_time(0)); },
+ x400_regs::SPI_SLAVE_CFG,
+ x400_regs::SPI_TRANSACTION_CFG_REG,
+ x400_regs::SPI_TRANSACTION_GO_REG,
+ x400_regs::SPI_STATUS_REG,
+ gpio_port_mapper);
+
+ _spi_getter_iface = std::make_shared<x400_spi_getter>(spicore);
+ register_feature(_spi_getter_iface);
}
}
@@ -328,8 +348,8 @@ double x400_radio_control_impl::set_rate(const double rate)
// X400 does not support runtime rate changes
if (!uhd::math::frequencies_are_equal(rate, get_rate())) {
RFNOC_LOG_WARNING("Requesting invalid sampling rate from device: "
- << (rate / 1e6) << " MHz. Actual rate is: "
- << (get_rate() / 1e6) << " MHz.");
+ << (rate / 1e6)
+ << " MHz. Actual rate is: " << (get_rate() / 1e6) << " MHz.");
}
return get_rate();
}