diff options
author | Martin Braun <martin.braun@ettus.com> | 2019-11-27 21:36:46 -0800 |
---|---|---|
committer | atrnati <54334261+atrnati@users.noreply.github.com> | 2020-01-29 08:57:25 -0600 |
commit | 0a49a8844a65698b11fe979441a97939dad80044 (patch) | |
tree | 30bbd6fb82c17abf7db4627250f3586a8d6fb175 /host/lib/rfnoc | |
parent | 25b434ae858dd476e13738e0acaa9edeb019cee4 (diff) | |
download | uhd-0a49a8844a65698b11fe979441a97939dad80044.tar.gz uhd-0a49a8844a65698b11fe979441a97939dad80044.tar.bz2 uhd-0a49a8844a65698b11fe979441a97939dad80044.zip |
rfnoc: Create mock factory
This is an API that allows creating mock block controllers, to write
unit tests for block controllers. See rfnoc_blocks_test for an example
how to use them.
Diffstat (limited to 'host/lib/rfnoc')
-rw-r--r-- | host/lib/rfnoc/CMakeLists.txt | 1 | ||||
-rw-r--r-- | host/lib/rfnoc/mock_block.cpp | 52 | ||||
-rw-r--r-- | host/lib/rfnoc/registry_factory.cpp | 8 |
3 files changed, 58 insertions, 3 deletions
diff --git a/host/lib/rfnoc/CMakeLists.txt b/host/lib/rfnoc/CMakeLists.txt index e685cef26..ea774b2c8 100644 --- a/host/lib/rfnoc/CMakeLists.txt +++ b/host/lib/rfnoc/CMakeLists.txt @@ -38,6 +38,7 @@ LIBUHD_APPEND_SOURCES( ${CMAKE_CURRENT_SOURCE_DIR}/rfnoc_rx_streamer.cpp ${CMAKE_CURRENT_SOURCE_DIR}/rfnoc_tx_streamer.cpp ${CMAKE_CURRENT_SOURCE_DIR}/tx_async_msg_queue.cpp + ${CMAKE_CURRENT_SOURCE_DIR}/mock_block.cpp # Default block control classes: ${CMAKE_CURRENT_SOURCE_DIR}/block_control.cpp ${CMAKE_CURRENT_SOURCE_DIR}/ddc_block_control.cpp diff --git a/host/lib/rfnoc/mock_block.cpp b/host/lib/rfnoc/mock_block.cpp new file mode 100644 index 000000000..867311097 --- /dev/null +++ b/host/lib/rfnoc/mock_block.cpp @@ -0,0 +1,52 @@ +// +// Copyright 2019 Ettus Research, a National Instruments Brand +// +// SPDX-License-Identifier: GPL-3.0-or-later +// + +#include <uhd/property_tree.hpp> +#include <uhd/rfnoc/defaults.hpp> +#include <uhd/rfnoc/mock_block.hpp> +#include <uhd/types/device_addr.hpp> +#include <uhdlib/rfnoc/clock_iface.hpp> +#include <uhdlib/rfnoc/factory.hpp> + +using namespace uhd::rfnoc; + +uhd::rfnoc::mock_block_container uhd::rfnoc::get_mock_block(const noc_id_t noc_id, + const size_t num_inputs, + const size_t num_outputs, + const device_addr_t& args, + const size_t mtu, + const device_type_t device_id) +{ + block_factory_info_t fac_info = factory::get_block_factory(noc_id, device_id); + + mock_block_container ret_val; + ret_val.factory = fac_info.factory_fn; + ret_val.reg_iface = std::make_shared<mock_reg_iface_t>(); + ret_val.tree = uhd::property_tree::make(); + // Create make args + ret_val.make_args = std::make_unique<noc_block_base::make_args_t>(); + ret_val.make_args->noc_id = noc_id; + ret_val.make_args->block_id = block_id_t(fac_info.block_name); + ret_val.make_args->num_input_ports = num_inputs; + ret_val.make_args->num_output_ports = num_outputs; + ret_val.make_args->mtu = mtu; + ret_val.make_args->reg_iface = ret_val.reg_iface; + ret_val.make_args->tree = ret_val.tree; + ret_val.make_args->args = args; + ret_val.make_args->tb_clk_iface = + std::make_shared<clock_iface>(fac_info.timebase_clk); + ret_val.make_args->ctrlport_clk_iface = + std::make_shared<clock_iface>(fac_info.ctrlport_clk); + // TODO Make a mock mb controller too + ret_val.make_args->mb_control = nullptr; + if (fac_info.mb_access) { + UHD_LOG_WARNING("MOCK", "Mock block controllers cannot have mb_controllers."); + } + + // Make block and return + return ret_val; +} + diff --git a/host/lib/rfnoc/registry_factory.cpp b/host/lib/rfnoc/registry_factory.cpp index bf1bc60a5..b251410bf 100644 --- a/host/lib/rfnoc/registry_factory.cpp +++ b/host/lib/rfnoc/registry_factory.cpp @@ -5,13 +5,14 @@ // #include <uhd/exception.hpp> -#include <uhd/rfnoc/registry.hpp> -#include <uhd/rfnoc/defaults.hpp> #include <uhd/rfnoc/constants.hpp> +#include <uhd/rfnoc/defaults.hpp> +#include <uhd/rfnoc/mock_block.hpp> +#include <uhd/rfnoc/registry.hpp> #include <uhd/utils/static.hpp> #include <uhdlib/rfnoc/factory.hpp> -#include <boost/functional/hash.hpp> #include <unordered_map> +#include <boost/functional/hash.hpp> #include <iomanip> #include <iostream> #include <sstream> @@ -106,3 +107,4 @@ block_factory_info_t factory::get_block_factory(noc_id_t noc_id, device_type_t d } return get_direct_block_registry().at(key); } + |