diff options
author | Ciro Nishiguchi <ciro.nishiguchi@ni.com> | 2019-12-03 19:18:46 -0600 |
---|---|---|
committer | Brent Stapleton <brent.stapleton@ettus.com> | 2019-12-20 16:32:22 -0800 |
commit | d7e5a630edbec5a9b9b3a2794ee1133ffcc405f5 (patch) | |
tree | 5a70bf9d6a27b540dc0460bbfcfba6d8b3018d01 /host/lib/include | |
parent | 378dc931ab697ee13352008a025ec4732f6f46e1 (diff) | |
download | uhd-d7e5a630edbec5a9b9b3a2794ee1133ffcc405f5.tar.gz uhd-d7e5a630edbec5a9b9b3a2794ee1133ffcc405f5.tar.bz2 uhd-d7e5a630edbec5a9b9b3a2794ee1133ffcc405f5.zip |
usrp: Add I/O service manager for DPDK
Diffstat (limited to 'host/lib/include')
-rw-r--r-- | host/lib/include/uhdlib/usrp/common/dpdk_io_service_mgr.hpp | 69 |
1 files changed, 69 insertions, 0 deletions
diff --git a/host/lib/include/uhdlib/usrp/common/dpdk_io_service_mgr.hpp b/host/lib/include/uhdlib/usrp/common/dpdk_io_service_mgr.hpp new file mode 100644 index 000000000..018f78f38 --- /dev/null +++ b/host/lib/include/uhdlib/usrp/common/dpdk_io_service_mgr.hpp @@ -0,0 +1,69 @@ +// +// Copyright 2019 Ettus Research, a National Instruments brand +// +// SPDX-License-Identifier: GPL-3.0-or-later +// + +#ifndef INCLUDED_UHDLIB_TRANSPORT_DPDK_IO_SERVICE_MGR_HPP +#define INCLUDED_UHDLIB_TRANSPORT_DPDK_IO_SERVICE_MGR_HPP + +#include <uhdlib/transport/dpdk/common.hpp> +#include <uhdlib/transport/dpdk_io_service.hpp> +#include <uhdlib/transport/udp_dpdk_link.hpp> +#include <uhdlib/usrp/common/io_service_mgr.hpp> + +namespace uhd { namespace usrp { + +class dpdk_io_service_mgr_impl : public io_service_mgr +{ +public: + dpdk_io_service_mgr_impl() + { + _dpdk_ctx = transport::dpdk::dpdk_ctx::get(); + } + + transport::io_service::sptr connect_links(transport::recv_link_if::sptr recv_link, + transport::send_link_if::sptr send_link, + const transport::link_type_t /*link_type*/, + const io_service_args_t& /*default_args*/, + const uhd::device_addr_t& /*stream_args*/, + const std::string& /*streamer_id*/) + { + auto io_srv = _get_io_service(recv_link, send_link); + io_srv->attach_recv_link(recv_link); + io_srv->attach_send_link(send_link); + return io_srv; + } + + void disconnect_links( + transport::recv_link_if::sptr recv_link, transport::send_link_if::sptr send_link) + { + auto io_srv = _get_io_service(recv_link, send_link); + io_srv->detach_recv_link(recv_link); + io_srv->detach_send_link(send_link); + } + +private: + transport::io_service::sptr _get_io_service( + transport::recv_link_if::sptr recv_link, transport::send_link_if::sptr send_link) + { + using namespace transport::dpdk; + + // For DPDK, the same object implements the send and recv link + // interfaces so we should always have both parameters. + UHD_ASSERT_THROW(recv_link && send_link); + + auto link = std::dynamic_pointer_cast<transport::udp_dpdk_link>(recv_link); + port_id_t port_id = link->get_port()->get_port_id(); + + auto io_srv = _dpdk_ctx->get_io_service(port_id); + UHD_ASSERT_THROW(io_srv); + return io_srv; + } + + transport::dpdk::dpdk_ctx::sptr _dpdk_ctx; +}; + +}} // namespace uhd::usrp + +#endif /* INCLUDED_UHDLIB_TRANSPORT_DPDK_IO_SERVICE_MGR_HPP */ |