aboutsummaryrefslogtreecommitdiffstats
path: root/host/lib/rfnoc/graph_impl.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'host/lib/rfnoc/graph_impl.cpp')
-rw-r--r--host/lib/rfnoc/graph_impl.cpp219
1 files changed, 0 insertions, 219 deletions
diff --git a/host/lib/rfnoc/graph_impl.cpp b/host/lib/rfnoc/graph_impl.cpp
deleted file mode 100644
index 4c04a0c1e..000000000
--- a/host/lib/rfnoc/graph_impl.cpp
+++ /dev/null
@@ -1,219 +0,0 @@
-//
-// Copyright 2016 Ettus Research LLC
-// Copyright 2018 Ettus Research, a National Instruments Company
-//
-// SPDX-License-Identifier: GPL-3.0-or-later
-//
-
-#include <uhd/rfnoc/sink_block_ctrl_base.hpp>
-#include <uhd/rfnoc/source_block_ctrl_base.hpp>
-#include <uhd/utils/log.hpp>
-#include <uhdlib/rfnoc/graph_impl.hpp>
-
-using namespace uhd::rfnoc;
-
-/****************************************************************************
- * Structors
- ***************************************************************************/
-graph_impl::graph_impl(const std::string& name,
- boost::weak_ptr<uhd::device3> device_ptr,
- async_msg_handler::sptr msg_handler)
- : _name(name), _device_ptr(device_ptr), _msg_handler(msg_handler)
-{
- UHD_LOG_TRACE("RFNOC", "Instantiating RFNoC graph " << _name);
-}
-
-/****************************************************************************
- * Connection API
- ***************************************************************************/
-void graph_impl::connect(const block_id_t& src_block,
- size_t src_block_port,
- const block_id_t& dst_block,
- size_t dst_block_port,
- const size_t pkt_size_)
-{
- device3::sptr device_ptr = _device_ptr.lock();
- if (not device_ptr) {
- throw uhd::runtime_error("Invalid device");
- }
-
- uhd::rfnoc::source_block_ctrl_base::sptr src =
- device_ptr->get_block_ctrl<rfnoc::source_block_ctrl_base>(src_block);
- uhd::rfnoc::sink_block_ctrl_base::sptr dst =
- device_ptr->get_block_ctrl<rfnoc::sink_block_ctrl_base>(dst_block);
- UHD_LOGGER_TRACE("RFNOC") << "[" << _name << "] Attempting to connect " << src_block
- << ":" << src_block_port << " --> " << dst_block << ":"
- << dst_block_port;
-
- /********************************************************************
- * 1. Draw the edges (logically connect the nodes)
- ********************************************************************/
- size_t actual_src_block_port = src->connect_downstream(
- boost::dynamic_pointer_cast<uhd::rfnoc::node_ctrl_base>(dst), src_block_port);
- if (src_block_port == uhd::rfnoc::ANY_PORT) {
- src_block_port = actual_src_block_port;
- } else if (src_block_port != actual_src_block_port) {
- throw uhd::runtime_error(
- str(boost::format("Can't connect to port %d on block %s.") % src_block_port
- % src->unique_id()));
- }
- size_t actual_dst_block_port = dst->connect_upstream(
- boost::dynamic_pointer_cast<uhd::rfnoc::node_ctrl_base>(src), dst_block_port);
- if (dst_block_port == uhd::rfnoc::ANY_PORT) {
- dst_block_port = actual_dst_block_port;
- } else if (dst_block_port != actual_dst_block_port) {
- throw uhd::runtime_error(
- str(boost::format("Can't connect to port %d on block %s.") % dst_block_port
- % dst->unique_id()));
- }
- src->set_downstream_port(actual_src_block_port, actual_dst_block_port);
- dst->set_upstream_port(actual_dst_block_port, actual_src_block_port);
- // At this point, ports are locked and no one else can simply connect
- // into them.
- UHD_LOGGER_TRACE("RFNOC") << "[" << _name << "] Connecting " << src_block << ":"
- << actual_src_block_port << " --> " << dst_block << ":"
- << actual_dst_block_port;
-
- /********************************************************************
- * 2. Check IO signatures match
- ********************************************************************/
- if (not rfnoc::stream_sig_t::is_compatible(
- src->get_output_signature(actual_src_block_port),
- dst->get_input_signature(actual_dst_block_port))) {
- throw uhd::runtime_error(
- str(boost::format("Can't connect block %s to %s: IO signature mismatch\n(%s "
- "is incompatible with %s).")
- % src->get_block_id().get() % dst->get_block_id().get()
- % src->get_output_signature(actual_src_block_port)
- % dst->get_input_signature(actual_dst_block_port)));
- }
- UHD_LOG_TRACE("RFNOC", "IO signatures match.");
-
- /********************************************************************
- * 3. Configure the source block's destination
- ********************************************************************/
- // Calculate SID
- sid_t sid = dst->get_address(dst_block_port);
- sid.set_src(src->get_address(src_block_port));
-
- // Set SID on source block
- src->set_destination(sid.get(), src_block_port);
-
- /********************************************************************
- * 4. Configure flow control
- ********************************************************************/
- size_t pkt_size = (pkt_size_ != 0)
- ? pkt_size_
- : src->get_output_signature(src_block_port).packet_size;
- if (pkt_size == 0) { // Unspecified packet rate. Assume max packet size.
- UHD_LOGGER_WARNING("RFNOC")
- << "Assuming max packet size for " << src->get_block_id();
- pkt_size = uhd::rfnoc::MAX_PACKET_SIZE;
- }
- // FC window (in bytes) depends on FIFO size.
- size_t buf_size_bytes = dst->get_fifo_size(dst_block_port);
- if (buf_size_bytes < pkt_size) {
- throw uhd::runtime_error(
- str(boost::format("Input FIFO for block %s is too small (%d kiB) for packets "
- "of size %d kiB\n"
- "coming from block %s.")
- % dst->get_block_id().get() % (dst->get_fifo_size(dst_block_port) / 1024)
- % (pkt_size / 1024) % src->get_block_id().get()));
- }
- const bool same_xbar = sid.get_src_addr() == sid.get_dst_addr();
- src->configure_flow_control_out(true, /* enable output */
- false, // Keep packets from jamming the crossbar
- buf_size_bytes,
- 0, /* no packet limit. We need to revisit this at some point. */
- src_block_port);
- // On the same crossbar, use lots of FC packets
- // Over the network, use less or we'd flood the transport
- const size_t bytes_per_response =
- same_xbar ? buf_size_bytes / uhd::rfnoc::DEFAULT_FC_XBAR_RESPONSE_FREQ
- : buf_size_bytes / uhd::rfnoc::DEFAULT_FC_TX_RESPONSE_FREQ;
- UHD_ASSERT_THROW(bytes_per_response != 0);
- dst->configure_flow_control_in(bytes_per_response, dst_block_port);
-
- /********************************************************************
- * 5. Configure error policy
- ********************************************************************/
- dst->set_error_policy("next_burst");
-
- /********************************************************************
- * 6. Set async message handling
- ********************************************************************/
- src->sr_write(
- uhd::rfnoc::SR_RESP_OUT_DST_SID, _msg_handler->get_local_addr(), src_block_port);
- dst->sr_write(
- uhd::rfnoc::SR_RESP_IN_DST_SID, _msg_handler->get_local_addr(), dst_block_port);
-}
-
-void graph_impl::connect(const block_id_t& src_block, const block_id_t& dst_block)
-{
- connect(src_block, ANY_PORT, dst_block, ANY_PORT);
-}
-
-void graph_impl::connect_src(const block_id_t& src_block,
- const size_t src_block_port,
- const uhd::sid_t dst_sid,
- const size_t buf_size_dst_bytes,
- const size_t pkt_size_)
-{
- device3::sptr device_ptr = _device_ptr.lock();
- if (not device_ptr) {
- throw uhd::runtime_error("Invalid device");
- }
-
- UHD_LOGGER_DEBUG("RFNOC") << "[" << _name << "] Connecting " << src_block << ":"
- << src_block_port << " --> " << dst_sid.to_pp_string_hex();
-
- uhd::rfnoc::source_block_ctrl_base::sptr src =
- device_ptr->get_block_ctrl<rfnoc::source_block_ctrl_base>(src_block);
-
- src->set_destination(dst_sid.get(), src_block_port);
-
- size_t pkt_size = (pkt_size_ != 0)
- ? pkt_size_
- : src->get_output_signature(src_block_port).packet_size;
- if (pkt_size == 0) { // Unspecified packet rate. Assume max packet size.
- UHD_LOGGER_WARNING("RFNOC")
- << "Assuming max packet size for " << src->get_block_id();
- pkt_size = uhd::rfnoc::MAX_PACKET_SIZE;
- }
- size_t buf_size_pkts = buf_size_dst_bytes / pkt_size;
- if (buf_size_pkts == 0) {
- throw uhd::runtime_error(
- str(boost::format("Input FIFO for unknown destination is too small "
- "(%d kiB) for packets of size %d kiB\n coming from "
- "block %s.")
- % (buf_size_dst_bytes / 1024) % (pkt_size / 1024)
- % src->get_block_id().get()));
- }
-
- src->configure_flow_control_out(true, /* enable output */
- (dst_sid.get_src_addr() == dst_sid.get_dst_addr()),
- buf_size_dst_bytes,
- 0, /* no packet limit. We need to revisit this at some point. */
- src_block_port);
-}
-
-void graph_impl::connect_sink(
- const block_id_t& sink_block, const size_t dst_block_port, const size_t bytes_per_ack)
-{
- device3::sptr device_ptr = _device_ptr.lock();
- if (not device_ptr) {
- throw uhd::runtime_error("Invalid device");
- }
-
- UHD_LOGGER_DEBUG("RFNOC") << "[" << _name << "] Connecting unknown source to"
- << sink_block << ":" << dst_block_port;
-
- uhd::rfnoc::sink_block_ctrl_base::sptr dst =
- device_ptr->get_block_ctrl<rfnoc::sink_block_ctrl_base>(sink_block);
- dst->configure_flow_control_in(bytes_per_ack, dst_block_port);
-
- /********************************************************************
- * 5. Configure error policy
- ********************************************************************/
- dst->set_error_policy("next_burst");
-}