diff options
author | michael-west <michael.west@ettus.com> | 2020-06-12 10:14:55 -0700 |
---|---|---|
committer | Aaron Rossetto <aaron.rossetto@ni.com> | 2020-08-04 15:41:07 -0500 |
commit | f659c1af8f5a0e2e629ec67c9a3a4d54f8c7d529 (patch) | |
tree | 2f5dceff2c6af501d880f2d09afb506c2b922f92 /host/lib/rfnoc | |
parent | 5a00f4d7864c6258f0d070b4753569413c7cfc4f (diff) | |
download | uhd-f659c1af8f5a0e2e629ec67c9a3a4d54f8c7d529.tar.gz uhd-f659c1af8f5a0e2e629ec67c9a3a4d54f8c7d529.tar.bz2 uhd-f659c1af8f5a0e2e629ec67c9a3a4d54f8c7d529.zip |
RFNoC: Added support for destruction of streamers
- Added rfnoc_graph method to disconnect a connection.
- Added rfnoc_graph method to disconnect a streamer.
- Added rfnoc_graph method to disconnect a port on a streamer.
- Added disconnect callback to rfnoc_rx_streamer and rfnoc_tx_streamer.
- Registered disconnect callback functions to streamers returned by
get_rx_streamer and get_tx_streamer methods.
Signed-off-by: michael-west <michael.west@ettus.com>
Diffstat (limited to 'host/lib/rfnoc')
-rw-r--r-- | host/lib/rfnoc/rfnoc_rx_streamer.cpp | 15 | ||||
-rw-r--r-- | host/lib/rfnoc/rfnoc_tx_streamer.cpp | 15 |
2 files changed, 24 insertions, 6 deletions
diff --git a/host/lib/rfnoc/rfnoc_rx_streamer.cpp b/host/lib/rfnoc/rfnoc_rx_streamer.cpp index 081682a94..180f5e87f 100644 --- a/host/lib/rfnoc/rfnoc_rx_streamer.cpp +++ b/host/lib/rfnoc/rfnoc_rx_streamer.cpp @@ -18,11 +18,13 @@ using namespace uhd::rfnoc; const std::string STREAMER_ID = "RxStreamer"; static std::atomic<uint64_t> streamer_inst_ctr; -rfnoc_rx_streamer::rfnoc_rx_streamer( - const size_t num_chans, const uhd::stream_args_t stream_args) - : rx_streamer_impl<chdr_rx_data_xport>(num_chans, stream_args) +rfnoc_rx_streamer::rfnoc_rx_streamer(const size_t num_chans, + const uhd::stream_args_t stream_args, + disconnect_fn_t disconnect_cb) + : rx_streamer_impl<chdr_rx_data_xport>(stream_args.channels.size(), stream_args) , _unique_id(STREAMER_ID + "#" + std::to_string(streamer_inst_ctr++)) , _stream_args(stream_args) + , _disconnect_cb(disconnect_cb) { set_overrun_handler([this]() { this->_handle_overrun(); }); @@ -90,6 +92,13 @@ rfnoc_rx_streamer::rfnoc_rx_streamer( node_accessor.init_props(this); } +rfnoc_rx_streamer::~rfnoc_rx_streamer() +{ + if (_disconnect_cb) { + _disconnect_cb(_unique_id); + } +} + std::string rfnoc_rx_streamer::get_unique_id() const { return _unique_id; diff --git a/host/lib/rfnoc/rfnoc_tx_streamer.cpp b/host/lib/rfnoc/rfnoc_tx_streamer.cpp index 9b511818e..578db5cdf 100644 --- a/host/lib/rfnoc/rfnoc_tx_streamer.cpp +++ b/host/lib/rfnoc/rfnoc_tx_streamer.cpp @@ -16,11 +16,13 @@ const std::string STREAMER_ID = "TxStreamer"; static std::atomic<uint64_t> streamer_inst_ctr; static constexpr size_t ASYNC_MSG_QUEUE_SIZE = 1000; -rfnoc_tx_streamer::rfnoc_tx_streamer( - const size_t num_chans, const uhd::stream_args_t stream_args) - : tx_streamer_impl<chdr_tx_data_xport>(num_chans, stream_args) +rfnoc_tx_streamer::rfnoc_tx_streamer(const size_t num_chans, + const uhd::stream_args_t stream_args, + disconnect_fn_t disconnect_cb) + : tx_streamer_impl<chdr_tx_data_xport>(stream_args.channels.size(), stream_args) , _unique_id(STREAMER_ID + "#" + std::to_string(streamer_inst_ctr++)) , _stream_args(stream_args) + , _disconnect_cb(disconnect_cb) { _async_msg_queue = std::make_shared<tx_async_msg_queue>(ASYNC_MSG_QUEUE_SIZE); @@ -78,6 +80,13 @@ rfnoc_tx_streamer::rfnoc_tx_streamer( node_accessor.init_props(this); } +rfnoc_tx_streamer::~rfnoc_tx_streamer() +{ + if (_disconnect_cb) { + _disconnect_cb(_unique_id); + } +} + std::string rfnoc_tx_streamer::get_unique_id() const { return _unique_id; |