aboutsummaryrefslogtreecommitdiffstats
path: root/host
diff options
context:
space:
mode:
Diffstat (limited to 'host')
-rw-r--r--host/lib/include/uhdlib/rfnoc/chdr_ctrl_xport.hpp7
-rw-r--r--host/lib/rfnoc/chdr_ctrl_xport.cpp69
2 files changed, 50 insertions, 26 deletions
diff --git a/host/lib/include/uhdlib/rfnoc/chdr_ctrl_xport.hpp b/host/lib/include/uhdlib/rfnoc/chdr_ctrl_xport.hpp
index f247761e7..d4564e935 100644
--- a/host/lib/include/uhdlib/rfnoc/chdr_ctrl_xport.hpp
+++ b/host/lib/include/uhdlib/rfnoc/chdr_ctrl_xport.hpp
@@ -136,6 +136,13 @@ public:
private:
chdr_ctrl_xport(const chdr_ctrl_xport&) = delete;
+ void _release_cb(uhd::transport::frame_buff::uptr buff,
+ uhd::transport::recv_link_if* recv_link);
+
+ bool _ctrl_recv_cb(uhd::transport::frame_buff::uptr& buff);
+
+ bool _mgmt_recv_cb(uhd::transport::frame_buff::uptr& buff);
+
sep_id_t _my_epid;
// Packet for received data
diff --git a/host/lib/rfnoc/chdr_ctrl_xport.cpp b/host/lib/rfnoc/chdr_ctrl_xport.cpp
index 637d2c302..043055b75 100644
--- a/host/lib/rfnoc/chdr_ctrl_xport.cpp
+++ b/host/lib/rfnoc/chdr_ctrl_xport.cpp
@@ -35,22 +35,12 @@ chdr_ctrl_xport::chdr_ctrl_xport(io_service::sptr io_srv,
recv_link_if* /*recv_link*/,
send_link_if
* /*send_link*/) -> bool {
- _recv_packet->refresh(buff->data());
- auto hdr = _recv_packet->get_chdr_header();
- auto pkt_type = hdr.get_pkt_type();
- auto dst_epid = hdr.get_dst_epid();
-
- /* Check type and destination EPID */
- if ((pkt_type == PKT_TYPE_CTRL) && (dst_epid == _my_epid)) {
- return true;
- } else {
- return false;
- }
- return false;
+ return this->_ctrl_recv_cb(buff);
};
+
recv_io_if::fc_callback_t release_cb =
- [](frame_buff::uptr buff, recv_link_if* link, send_link_if* /*send_link*/) {
- link->release_recv_buff(std::move(buff));
+ [this](frame_buff::uptr buff, recv_link_if* link, send_link_if* /*send_link*/) {
+ this->_release_cb(std::move(buff), link);
};
_ctrl_recv_if = io_srv->make_recv_client(
@@ -60,24 +50,51 @@ chdr_ctrl_xport::chdr_ctrl_xport(io_service::sptr io_srv,
recv_link_if* /*recv_link*/,
send_link_if
* /*send_link*/) -> bool {
- _recv_packet->refresh(buff->data());
- auto hdr = _recv_packet->get_chdr_header();
- auto pkt_type = hdr.get_pkt_type();
- auto dst_epid = hdr.get_dst_epid();
-
- /* Check type and destination EPID */
- if ((pkt_type == PKT_TYPE_MGMT) && (dst_epid == _my_epid)) {
- return true;
- } else {
- return false;
- }
- return false;
+ return this->_mgmt_recv_cb(buff);
};
_mgmt_recv_if = io_srv->make_recv_client(
recv_link, 1, mgmt_recv_cb, send_link_if::sptr(), 0, release_cb);
}
+bool chdr_ctrl_xport::_ctrl_recv_cb(uhd::transport::frame_buff::uptr& buff)
+{
+ _recv_packet->refresh(buff->data());
+ auto hdr = _recv_packet->get_chdr_header();
+ auto pkt_type = hdr.get_pkt_type();
+ auto dst_epid = hdr.get_dst_epid();
+
+ /* Check type and destination EPID */
+ if ((pkt_type == PKT_TYPE_CTRL) && (dst_epid == _my_epid)) {
+ return true;
+ } else {
+ return false;
+ }
+ return false;
+}
+
+bool chdr_ctrl_xport::_mgmt_recv_cb(uhd::transport::frame_buff::uptr& buff)
+{
+ _recv_packet->refresh(buff->data());
+ auto hdr = _recv_packet->get_chdr_header();
+ auto pkt_type = hdr.get_pkt_type();
+ auto dst_epid = hdr.get_dst_epid();
+
+ /* Check type and destination EPID */
+ if ((pkt_type == PKT_TYPE_MGMT) && (dst_epid == _my_epid)) {
+ return true;
+ } else {
+ return false;
+ }
+ return false;
+}
+
+void chdr_ctrl_xport::_release_cb(uhd::transport::frame_buff::uptr buff,
+ uhd::transport::recv_link_if* recv_link)
+{
+ recv_link->release_recv_buff(std::move(buff));
+}
+
chdr_ctrl_xport::~chdr_ctrl_xport()
{