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.cpp174
1 files changed, 74 insertions, 100 deletions
diff --git a/host/lib/rfnoc/graph_impl.cpp b/host/lib/rfnoc/graph_impl.cpp
index 0d90150c1..989bcb0c4 100644
--- a/host/lib/rfnoc/graph_impl.cpp
+++ b/host/lib/rfnoc/graph_impl.cpp
@@ -5,8 +5,8 @@
// SPDX-License-Identifier: GPL-3.0-or-later
//
-#include <uhd/rfnoc/source_block_ctrl_base.hpp>
#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>
@@ -15,13 +15,10 @@ 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)
+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);
}
@@ -29,13 +26,12 @@ graph_impl::graph_impl(
/****************************************************************************
* 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_
-) {
+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");
@@ -45,62 +41,51 @@ void graph_impl::connect(
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
- ;
+ 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
- );
+ 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()
- ));
+ 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
- );
+ 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()
- ));
+ 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
- ;
+ 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)
- ));
+ 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.");
@@ -117,38 +102,37 @@ void graph_impl::connect(
/********************************************************************
* 4. Configure flow control
********************************************************************/
- size_t pkt_size = (pkt_size_ != 0) ? pkt_size_ : src->get_output_signature(src_block_port).packet_size;
+ 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() ;
+ 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()
- ));
+ 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()));
}
- src->configure_flow_control_out(
- true, /* enable output */
- buf_size_bytes,
- 0, /* no packet limit. We need to revisit this at some point. */
- src_block_port
- );
+ src->configure_flow_control_out(true, /* enable output */
+ 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
- size_t bytes_per_response = buf_size_bytes / uhd::rfnoc::DEFAULT_FC_XBAR_RESPONSE_FREQ;
+ size_t bytes_per_response =
+ buf_size_bytes / uhd::rfnoc::DEFAULT_FC_XBAR_RESPONSE_FREQ;
// Over the network, use less or we'd flood the transport
if (sid.get_src_addr() != sid.get_dst_addr()) {
bytes_per_response = 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
- );
+ dst->configure_flow_control_in(bytes_per_response, dst_block_port);
/********************************************************************
* 5. Configure error policy
@@ -158,33 +142,30 @@ void graph_impl::connect(
/********************************************************************
* 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);
+ 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
-) {
+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,
+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_
-) {
+ 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_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);
@@ -192,8 +173,8 @@ void graph_impl::connect_src(
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;
+ ? 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();
@@ -201,32 +182,26 @@ void graph_impl::connect_src(
}
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()
- ));
+ 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(buf_size_pkts, 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
-) {
+ 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_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);
@@ -237,4 +212,3 @@ void graph_impl::connect_sink(
********************************************************************/
dst->set_error_policy("next_burst");
}
-