// // Copyright 2019 Ettus Research, a National Instruments Brand // // SPDX-License-Identifier: GPL-3.0-or-later // #include #include #include #include #include #include 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(); ret_val.tree = uhd::property_tree::make(); // Create make args ret_val.make_args = std::make_unique(); 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(fac_info.timebase_clk); ret_val.make_args->ctrlport_clk_iface = std::make_shared(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; }