diff options
author | Ciro Nishiguchi <ciro.nishiguchi@ni.com> | 2019-08-13 16:50:47 -0500 |
---|---|---|
committer | Martin Braun <martin.braun@ettus.com> | 2019-11-26 11:49:42 -0800 |
commit | 77a5358dd03669366a162d67f9ea11b2056c78b6 (patch) | |
tree | a80b97c5629c900c69a45fe695597f1b774ce91d /host/lib/rfnoc | |
parent | f5e726b0ad83743c173231d9ac019c917a51be07 (diff) | |
download | uhd-77a5358dd03669366a162d67f9ea11b2056c78b6.tar.gz uhd-77a5358dd03669366a162d67f9ea11b2056c78b6.tar.bz2 uhd-77a5358dd03669366a162d67f9ea11b2056c78b6.zip |
rfnoc: Add MTU property to RX streamer
Diffstat (limited to 'host/lib/rfnoc')
-rw-r--r-- | host/lib/rfnoc/rfnoc_rx_streamer.cpp | 40 | ||||
-rw-r--r-- | host/lib/rfnoc/rfnoc_tx_streamer.cpp | 12 |
2 files changed, 46 insertions, 6 deletions
diff --git a/host/lib/rfnoc/rfnoc_rx_streamer.cpp b/host/lib/rfnoc/rfnoc_rx_streamer.cpp index b50e2fe15..9383e3487 100644 --- a/host/lib/rfnoc/rfnoc_rx_streamer.cpp +++ b/host/lib/rfnoc/rfnoc_rx_streamer.cpp @@ -56,10 +56,34 @@ rfnoc_rx_streamer::rfnoc_rx_streamer( _samp_rate_in.reserve(num_chans); _tick_rate_in.reserve(num_chans); _type_in.reserve(num_chans); + _mtu_in.reserve(num_chans); for (size_t i = 0; i < num_chans; i++) { _register_props(i, stream_args.otw_format); } + + for (size_t i = 0; i < num_chans; i++) { + prop_ptrs_t mtu_resolver_out; + for (auto& mtu_prop : _mtu_in) { + mtu_resolver_out.insert(&mtu_prop); + } + + add_property_resolver({&_mtu_in[i]}, std::move(mtu_resolver_out), + [&mtu_in = _mtu_in[i], i, this]() { + RFNOC_LOG_TRACE("Calling resolver for `mtu_in'@" << i); + if (mtu_in.is_valid()) { + const size_t mtu = std::min(mtu_in.get(), rx_streamer_impl::get_mtu()); + // Set the same MTU value for all chans + for (auto& prop : this->_mtu_in) { + prop.set(mtu); + } + if (mtu < rx_streamer_impl::get_mtu()) { + rx_streamer_impl::set_mtu(mtu); + } + } + }); + } + node_accessor_t node_accessor{}; node_accessor.init_props(this); } @@ -124,6 +148,18 @@ void rfnoc_rx_streamer::_handle_overrun() } } +void rfnoc_rx_streamer::connect_channel( + const size_t channel, chdr_rx_data_xport::uptr xport) +{ + UHD_ASSERT_THROW(channel < _mtu_in.size()); + + // Update MTU property based on xport limits + const size_t mtu = xport->get_max_payload_size(); + set_property<size_t>(PROP_KEY_MTU, mtu, {res_source_info::INPUT_EDGE, channel}); + + rx_streamer_impl<chdr_rx_data_xport>::connect_channel(channel, std::move(xport)); +} + void rfnoc_rx_streamer::_register_props(const size_t chan, const std::string& otw_format) { @@ -136,18 +172,22 @@ void rfnoc_rx_streamer::_register_props(const size_t chan, PROP_KEY_TICK_RATE, {res_source_info::INPUT_EDGE, chan})); _type_in.emplace_back(property_t<std::string>( PROP_KEY_TYPE, otw_format, {res_source_info::INPUT_EDGE, chan})); + _mtu_in.emplace_back(property_t<size_t>( + PROP_KEY_MTU, get_mtu(), {res_source_info::INPUT_EDGE, chan})); // Give us some shorthands for the rest of this function property_t<double>* scaling_in = &_scaling_in.back(); property_t<double>* samp_rate_in = &_samp_rate_in.back(); property_t<double>* tick_rate_in = &_tick_rate_in.back(); property_t<std::string>* type_in = &_type_in.back(); + property_t<size_t>* mtu_in = &_mtu_in.back(); // Register them register_property(scaling_in); register_property(samp_rate_in); register_property(tick_rate_in); register_property(type_in); + register_property(mtu_in); // Add resolvers add_property_resolver({scaling_in}, {}, diff --git a/host/lib/rfnoc/rfnoc_tx_streamer.cpp b/host/lib/rfnoc/rfnoc_tx_streamer.cpp index 4fc1a3ff8..d4aa267af 100644 --- a/host/lib/rfnoc/rfnoc_tx_streamer.cpp +++ b/host/lib/rfnoc/rfnoc_tx_streamer.cpp @@ -60,12 +60,12 @@ rfnoc_tx_streamer::rfnoc_tx_streamer(const size_t num_chans, [&mtu_out = _mtu_out[i], i, this]() { RFNOC_LOG_TRACE("Calling resolver for `mtu_out'@" << i); if (mtu_out.is_valid()) { - const size_t mtu = mtu_out.get(); - // If the current MTU changes, set the same value for all chans + const size_t mtu = std::min(mtu_out.get(), tx_streamer_impl::get_mtu()); + // Set the same MTU value for all chans + for (auto& prop : this->_mtu_out) { + prop.set(mtu); + } if (mtu < tx_streamer_impl::get_mtu()) { - for (auto& prop : this->_mtu_out) { - prop.set(mtu); - } tx_streamer_impl::set_mtu(mtu); } } @@ -155,7 +155,7 @@ void rfnoc_tx_streamer::_register_props(const size_t chan, _type_out.emplace_back(property_t<std::string>( PROP_KEY_TYPE, otw_format, {res_source_info::OUTPUT_EDGE, chan})); _mtu_out.push_back(property_t<size_t>( - PROP_KEY_MTU, {res_source_info::OUTPUT_EDGE, chan})); + PROP_KEY_MTU, get_mtu(), {res_source_info::OUTPUT_EDGE, chan})); // Give us some shorthands for the rest of this function property_t<double>* scaling_out = &_scaling_out.back(); |