aboutsummaryrefslogtreecommitdiffstats
path: root/host/lib/rfnoc
diff options
context:
space:
mode:
Diffstat (limited to 'host/lib/rfnoc')
-rw-r--r--host/lib/rfnoc/graph.cpp45
1 files changed, 41 insertions, 4 deletions
diff --git a/host/lib/rfnoc/graph.cpp b/host/lib/rfnoc/graph.cpp
index 9b8b9ec59..897eade57 100644
--- a/host/lib/rfnoc/graph.cpp
+++ b/host/lib/rfnoc/graph.cpp
@@ -709,11 +709,48 @@ void graph_t::_check_topology()
}
if (!node_accessor.check_topology(node, connected_inputs, connected_outputs)) {
+ std::ostringstream input_topology;
+ input_topology << " requested inputs: (";
+ for (auto connected_input : connected_inputs) {
+ input_topology << connected_input;
+ if (connected_input != connected_inputs.back()) {
+ input_topology << ", ";
+ }
+ }
+ input_topology << ")";
+ input_topology << " valid inputs: (";
+ for (size_t expected_input = 0; expected_input < node->get_num_input_ports();
+ expected_input++) {
+ input_topology << expected_input;
+ if (expected_input < node->get_num_input_ports() - 1) {
+ input_topology << ", ";
+ }
+ }
+ input_topology << ")";
+
+ std::ostringstream output_topology;
+ output_topology << " requested outputs: (";
+ for (auto connected_output : connected_outputs) {
+ output_topology << connected_output;
+ if (connected_output != connected_outputs.back()) {
+ output_topology << ", ";
+ }
+ }
+ output_topology << ")";
+ output_topology << " valid outputs: (";
+ for (size_t expected_output = 0;
+ expected_output < node->get_num_output_ports();
+ expected_output++) {
+ output_topology << expected_output;
+ if (expected_output < node->get_num_output_ports() - 1) {
+ output_topology << ", ";
+ }
+ }
+ output_topology << ")";
+
UHD_LOG_ERROR(LOG_ID,
- "Node " << node->get_unique_id()
- << "cannot handle its current topology! ("
- << connected_inputs.size() << "inputs, "
- << connected_outputs.size() << " outputs)");
+ "Node " << node->get_unique_id() << " using invalid inputs or outputs! "
+ << input_topology.str() << ", " << output_topology.str());
topo_ok = false;
}
}