From fe3fa1dd31b6da9c90cf181d64d6829313804cdd Mon Sep 17 00:00:00 2001 From: Sugandha Gupta Date: Fri, 25 Jan 2019 17:36:26 -0800 Subject: device3: Constraint send/recv_frame_size based on down/upstream MTU We need to properly contraint the send/recv_frame_size based on the minimum MTU of all the down/upstream blocks. This fixes the issue with E310 tx/rx streaming as it has smaller MTU sizes than the other usrps. --- host/lib/usrp/device3/device3_io_impl.cpp | 54 +++++++++++++++++++++++++++++++ 1 file changed, 54 insertions(+) (limited to 'host/lib/usrp/device3/device3_io_impl.cpp') diff --git a/host/lib/usrp/device3/device3_io_impl.cpp b/host/lib/usrp/device3/device3_io_impl.cpp index ce8ff2cbf..081f881d5 100644 --- a/host/lib/usrp/device3/device3_io_impl.cpp +++ b/host/lib/usrp/device3/device3_io_impl.cpp @@ -338,6 +338,33 @@ rx_streamer::sptr device3_impl::get_rx_stream(const stream_args_t& args_) // Setup the DSP transport hints device_addr_t rx_hints = get_rx_hints(mb_index); + // Traverse the upstream nodes for minimum mtu + size_t min_mtu = blk_ctrl->get_mtu(block_port); + UHD_RX_STREAMER_LOG() << "Maximum MTU supported by " << blk_ctrl->unique_id() + << ": " << min_mtu; + std::vector> + upstream_source_nodes = + blk_ctrl->find_upstream_node(); + for (const boost::shared_ptr& node : + upstream_source_nodes) { + // Get MTU from Port 0 of the upstream nodes. This is okay for now as + // currently we use port 0 of a block in case of channel 1. + UHD_RX_STREAMER_LOG() << "Maximum MTU supported by " << node->unique_id() + << ": " << node->get_mtu(0); + min_mtu = std::min(min_mtu, node->get_mtu(0)); + } + // Contraint min_mtu by device mtu + min_mtu = std::min(min_mtu, get_mtu(mb_index, uhd::direction_t::RX_DIRECTION)); + if (rx_hints.has_key("recv_frame_size")) { + if (rx_hints.cast("recv_frame_size", min_mtu) > min_mtu) { + UHD_RX_STREAMER_LOG() << "Requested recv_frame_size of " << rx_hints["recv_frame_size"] + << " exceeds the maximum possible on this stream. Using " << min_mtu; + } + min_mtu = + std::min(min_mtu, rx_hints.cast("recv_frame_size", min_mtu)); + } + rx_hints["recv_frame_size"] = std::to_string(min_mtu); + // allocate sid and create transport uhd::sid_t stream_address = blk_ctrl->get_address(block_port); UHD_RX_STREAMER_LOG() << "creating rx stream " << rx_hints.to_string(); @@ -577,6 +604,33 @@ tx_streamer::sptr device3_impl::get_tx_stream(const uhd::stream_args_t& args_) // Setup the dsp transport hints device_addr_t tx_hints = get_tx_hints(mb_index); + + // Traverse the downstream nodes for minimum mtu + size_t min_mtu = blk_ctrl->get_mtu(block_port); + UHD_TX_STREAMER_LOG() << "Maximum MTU supported by " << blk_ctrl->unique_id() + << ": " << min_mtu; + std::vector> + downstream_sink_nodes = + blk_ctrl->find_downstream_node(); + for (const boost::shared_ptr& node : + downstream_sink_nodes) { + // Get MTU from Port 0 of the downstream nodes. This is okay for now as + // currently we use port 0 of a block in case of channel 1. + UHD_TX_STREAMER_LOG() << "Maximum MTU supported by " << node->unique_id() + << ": " << node->get_mtu(0); + min_mtu = std::min(min_mtu, node->get_mtu(0)); + } + min_mtu = std::min(min_mtu, get_mtu(mb_index, uhd::direction_t::TX_DIRECTION)); + if (tx_hints.has_key("send_frame_size")) { + if (tx_hints.cast("send_frame_size", min_mtu) > min_mtu) { + UHD_TX_STREAMER_LOG() << "Requested send_frame_size of " << tx_hints["send_frame_size"] + << " exceeds the maximum possible on this stream. Using " << min_mtu; + } + min_mtu = + std::min(min_mtu, tx_hints.cast("send_frame_size", min_mtu)); + } + tx_hints["send_frame_size"] = std::to_string(min_mtu); + const size_t fifo_size = blk_ctrl->get_fifo_size(block_port); // Allocate sid and create transport uhd::sid_t stream_address = blk_ctrl->get_address(block_port); -- cgit v1.2.3