diff options
-rw-r--r-- | host/lib/include/uhdlib/rfnoc/client_zero.hpp | 4 | ||||
-rw-r--r-- | host/lib/rfnoc/client_zero.cpp | 27 | ||||
-rw-r--r-- | host/lib/rfnoc/rfnoc_graph.cpp | 4 |
3 files changed, 12 insertions, 23 deletions
diff --git a/host/lib/include/uhdlib/rfnoc/client_zero.hpp b/host/lib/include/uhdlib/rfnoc/client_zero.hpp index b9bcb32e5..43f955870 100644 --- a/host/lib/include/uhdlib/rfnoc/client_zero.hpp +++ b/host/lib/include/uhdlib/rfnoc/client_zero.hpp @@ -154,9 +154,9 @@ public: bool complete_flush(uint16_t portno); /*! Go through the entire flush process for all ports - * \throws uhd::runtime_error if flush failed + * \return whether or not the flush succeeded */ - void complete_flush_all_blocks(); + bool complete_flush_all_blocks(); /*! Reset a port's control logic * diff --git a/host/lib/rfnoc/client_zero.cpp b/host/lib/rfnoc/client_zero.cpp index f5a54fd62..af23ba1cc 100644 --- a/host/lib/rfnoc/client_zero.cpp +++ b/host/lib/rfnoc/client_zero.cpp @@ -154,38 +154,25 @@ bool client_zero::complete_flush(uint16_t portno) return poll_flush_done(portno); } -void client_zero::complete_flush_all_blocks() +bool client_zero::complete_flush_all_blocks() { const size_t num_blocks = get_num_blocks(); const size_t first_block_port = 1 + get_num_stream_endpoints(); // Issue flush commands - auto flush_done = std::vector<bool>(); for (size_t portno = 0; portno < num_blocks; ++portno) { auto block_portno = portno + first_block_port; set_flush(block_portno); - flush_done.push_back(false); } // Poll for flush done - auto start = std::chrono::steady_clock::now(); - size_t flushes_done = 0; - while (flushes_done < num_blocks) { - for (size_t portno = 0; portno < num_blocks; ++portno) { - if (flush_done[portno]) { - continue; - } - if (std::chrono::steady_clock::now() > (start + DEFAULT_POLL_TIMEOUT)) { - throw uhd::runtime_error( - str(boost::format("Timeout while flushing port %d") % portno)); - } - auto block_portno = portno + first_block_port; - if (get_flush_done(block_portno)) { - flush_done[portno] = true; - flushes_done++; - } - } + bool all_ports_flushed = true; + for (size_t portno = 0; portno < num_blocks; ++portno) { + size_t block_portno = portno + first_block_port; + all_ports_flushed = all_ports_flushed && poll_flush_done(block_portno); } + + return all_ports_flushed; } void client_zero::reset_ctrl(uint16_t portno) diff --git a/host/lib/rfnoc/rfnoc_graph.cpp b/host/lib/rfnoc/rfnoc_graph.cpp index 795ffd289..f820a6960 100644 --- a/host/lib/rfnoc/rfnoc_graph.cpp +++ b/host/lib/rfnoc/rfnoc_graph.cpp @@ -663,7 +663,9 @@ private: std::string("Flushing and resetting blocks on mboard ") + std::to_string(mb_idx)); - mb_cz->complete_flush_all_blocks(); + if (!mb_cz->complete_flush_all_blocks()) { + UHD_LOG_WARNING(LOG_ID, "One or more blocks timed out during flush!"); + } // Reset for (size_t portno = 0; portno < num_blocks; ++portno) { |