From a8e286b106f19c37d6cf20de886c65f3c04da162 Mon Sep 17 00:00:00 2001 From: Ciro Nishiguchi Date: Mon, 28 Oct 2019 14:28:33 -0500 Subject: rfnoc: Make polling I/O service not block on flow control Add a new method to io_service::send_io to check whether the destination is ready for data, to make it possible to poll send_io rather than block waiting for flow control credits. --- host/lib/rfnoc/chdr_ctrl_xport.cpp | 4 ++-- host/lib/rfnoc/chdr_tx_data_xport.cpp | 16 +++++++++++----- 2 files changed, 13 insertions(+), 7 deletions(-) (limited to 'host/lib/rfnoc') diff --git a/host/lib/rfnoc/chdr_ctrl_xport.cpp b/host/lib/rfnoc/chdr_ctrl_xport.cpp index 6b185efab..637d2c302 100644 --- a/host/lib/rfnoc/chdr_ctrl_xport.cpp +++ b/host/lib/rfnoc/chdr_ctrl_xport.cpp @@ -23,12 +23,12 @@ chdr_ctrl_xport::chdr_ctrl_xport(io_service::sptr io_srv, : _my_epid(my_epid), _recv_packet(pkt_factory.make_generic()) { /* Make dumb send pipe */ - send_io_if::send_callback_t send_cb = [this](frame_buff::uptr& buff, + send_io_if::send_callback_t send_cb = [this](frame_buff::uptr buff, send_link_if* link) { link->release_send_buff(std::move(buff)); }; _send_if = io_srv->make_send_client( - send_link, num_send_frames, send_cb, recv_link_if::sptr(), 0, nullptr); + send_link, num_send_frames, send_cb, recv_link_if::sptr(), 0, nullptr, nullptr); /* Make dumb recv pipe that matches management and control packets */ uhd::transport::recv_callback_t ctrl_recv_cb = [this](frame_buff::uptr& buff, diff --git a/host/lib/rfnoc/chdr_tx_data_xport.cpp b/host/lib/rfnoc/chdr_tx_data_xport.cpp index bb9d1b63e..8837e2dbe 100644 --- a/host/lib/rfnoc/chdr_tx_data_xport.cpp +++ b/host/lib/rfnoc/chdr_tx_data_xport.cpp @@ -36,6 +36,7 @@ chdr_tx_data_xport::chdr_tx_data_xport(uhd::transport::io_service::sptr io_srv, , _fc_sender(pkt_factory, epids) , _epid(epids.first) , _chdr_w_bytes(chdr_w_to_bits(pkt_factory.get_chdr_w()) / 8) + , _frame_size(send_link->get_send_frame_size()) { UHD_LOG_TRACE("XPORT::TX_DATA_XPORT", "Creating tx xport with local epid=" << epids.first @@ -51,8 +52,8 @@ chdr_tx_data_xport::chdr_tx_data_xport(uhd::transport::io_service::sptr io_srv, _max_payload_size = send_link->get_send_frame_size() - pyld_offset; // Now create the send I/O we will use for data - auto send_cb = [this](buff_t::uptr& buff, transport::send_link_if* send_link) { - this->_send_callback(buff, send_link); + auto send_cb = [this](buff_t::uptr buff, transport::send_link_if* send_link) { + this->_send_callback(std::move(buff), send_link); }; auto recv_cb = [this](buff_t::uptr& buff, @@ -61,13 +62,18 @@ chdr_tx_data_xport::chdr_tx_data_xport(uhd::transport::io_service::sptr io_srv, return this->_recv_callback(buff, recv_link, send_link); }; + auto fc_cb = [this](size_t num_bytes) { + return this->_fc_callback(num_bytes); + }; + // Needs just a single recv frame for strs packets _send_io = io_srv->make_send_client(send_link, num_send_frames, send_cb, recv_link, /* num_recv_frames */ 1, - recv_cb); + recv_cb, + fc_cb); } chdr_tx_data_xport::~chdr_tx_data_xport() @@ -96,9 +102,8 @@ static chdr_tx_data_xport::fc_params_t configure_flow_ctrl(io_service::sptr io_s chdr::chdr_packet::uptr recv_packet = pkt_factory.make_generic(); // No flow control at initialization, just release all send buffs - auto send_cb = [](frame_buff::uptr& buff, send_link_if* send_link) { + auto send_cb = [](frame_buff::uptr buff, send_link_if* send_link) { send_link->release_send_buff(std::move(buff)); - buff = nullptr; }; // For recv, just queue strs packets for recv_io to read @@ -124,6 +129,7 @@ static chdr_tx_data_xport::fc_params_t configure_flow_ctrl(io_service::sptr io_s send_cb, nullptr, 0, // num_recv_frames + nullptr, nullptr); auto recv_io = io_srv->make_recv_client(recv_link, -- cgit v1.2.3