diff options
Diffstat (limited to 'host')
-rw-r--r-- | host/cmake/Modules/FindLIBERIO.cmake | 35 | ||||
-rw-r--r-- | host/include/config.h.in | 1 | ||||
-rw-r--r-- | host/lib/CMakeLists.txt | 2 | ||||
-rw-r--r-- | host/lib/include/uhdlib/transport/liberio_link.hpp | 178 | ||||
-rw-r--r-- | host/lib/transport/CMakeLists.txt | 7 | ||||
-rw-r--r-- | host/lib/transport/liberio_link.cpp | 154 | ||||
-rw-r--r-- | host/lib/usrp/mpmd/mpmd_link_if_mgr.hpp | 2 |
7 files changed, 1 insertions, 378 deletions
diff --git a/host/cmake/Modules/FindLIBERIO.cmake b/host/cmake/Modules/FindLIBERIO.cmake deleted file mode 100644 index 77fd49735..000000000 --- a/host/cmake/Modules/FindLIBERIO.cmake +++ /dev/null @@ -1,35 +0,0 @@ -# -# Copyright 2017 Ettus Research -# Copyright 2018 Ettus Research, a National Instruments Company -# -# SPDX-License-Identifier: GPL-3.0-or-later -# -# - Find liberio -# Find the liberio includes and client library -# This module defines -# LIBERIO_INCLUDE_DIR, where to find liberio/dma.h -# LIBERIO_LIBRARIES, the libraries needed by a liberio client. -# LIBERIO_FOUND, If false, do not try to use liberio. -# also defined, but not for general use are -# LIBERIO_LIBRARY, where to find the liberio library. - -find_package(PkgConfig) -PKG_CHECK_MODULES(PC_LIBERIO QUIET liberio >= 0.3) - -find_path(LIBERIO_INCLUDE_DIR liberio/liberio.h - HINTS $ENV{LIBERIO_DIR}/include ${PC_LIBERIO_INCLUDE_DIR} - PATH_SUFFIXES liberio -) - -find_library(LIBERIO_LIBRARY - NAMES erio liberio - HINTS $ENV{LIBERIO_DIR}/lib ${PC_LIBERIO_LIBDIR} ${PC_LIBERIO_LIBRARY_DIRS} -) - -include(FindPackageHandleStandardArgs) -FIND_PACKAGE_HANDLE_STANDARD_ARGS(LIBERIO DEFAULT_MSG LIBERIO_LIBRARY LIBERIO_INCLUDE_DIR) -mark_as_advanced(LIBERIO_INCLUDE_DIR LIBERIO_LIBRARY) - -set(LIBERIO_LIBRARIES ${LIBERIO_LIBRARY}) -set(LIBERIO_INCLUDE_DIRS ${LIBERIO_INCLUDE_DIR}) - diff --git a/host/include/config.h.in b/host/include/config.h.in index 6557254b6..0f309d9b8 100644 --- a/host/include/config.h.in +++ b/host/include/config.h.in @@ -13,7 +13,6 @@ #define UHD_VERSION_ABI ${UHD_VERSION_ABI} #define UHD_VERSION_PATCH ${UHD_VERSION_PATCH} #cmakedefine ENABLE_USB -#cmakedefine ENABLE_LIBERIO #ifndef UHD_VERSION #cmakedefine UHD_VERSION @UHD_VERSION_ADDED@ #endif diff --git a/host/lib/CMakeLists.txt b/host/lib/CMakeLists.txt index c0b39faea..3335cfec9 100644 --- a/host/lib/CMakeLists.txt +++ b/host/lib/CMakeLists.txt @@ -60,9 +60,7 @@ endmacro(INCLUDE_SUBDIRECTORY) message(STATUS "") # Dependencies find_package(LIBUSB) -find_package(LIBERIO) find_package(DPDK 18.11 EXACT) -LIBUHD_REGISTER_COMPONENT("LIBERIO" ENABLE_LIBERIO ON "ENABLE_LIBUHD;LIBERIO_FOUND" OFF OFF) LIBUHD_REGISTER_COMPONENT("USB" ENABLE_USB ON "ENABLE_LIBUHD;LIBUSB_FOUND" OFF OFF) # Devices LIBUHD_REGISTER_COMPONENT("B100" ENABLE_B100 ON "ENABLE_LIBUHD;ENABLE_USB" OFF OFF) diff --git a/host/lib/include/uhdlib/transport/liberio_link.hpp b/host/lib/include/uhdlib/transport/liberio_link.hpp deleted file mode 100644 index e81a39393..000000000 --- a/host/lib/include/uhdlib/transport/liberio_link.hpp +++ /dev/null @@ -1,178 +0,0 @@ -// -// Copyright 2019 Ettus Research, a National Instruments brand -// -// SPDX-License-Identifier: GPL-3.0-or-later -// - -#pragma once - -#include <uhd/config.hpp> -#include <uhd/transport/buffer_pool.hpp> -#include <uhd/types/device_addr.hpp> -#include <uhdlib/transport/adapter_info.hpp> -#include <uhdlib/transport/link_base.hpp> -#include <liberio/liberio.h> -#include <cassert> -#include <string> -#include <vector> - -namespace uhd { namespace transport { - -class liberio_frame_buff : public frame_buff -{ -public: - liberio_frame_buff(struct liberio_chan* chan) : _chan(chan) - { - assert(_chan); - // Acquire channel reference - liberio_chan_get(_chan); - } - - ~liberio_frame_buff() - { - if (_buff) { - // Set payload size to signify "empty" - liberio_buf_set_payload(_buff, 0, 0); - - // Release buffer back to liberio - liberio_chan_buf_enqueue(_chan, _buff); - _buff = nullptr; - _data = nullptr; - } - // Release channel reference - liberio_chan_put(_chan); - } - - liberio_frame_buff(const liberio_frame_buff& src) : liberio_frame_buff(src._chan) {} - - UHD_FORCE_INLINE size_t get(int32_t timeout_ms) - { - // Dequeue timeout in microseconds - _buff = liberio_chan_buf_dequeue(_chan, timeout_ms * 1000); - if (!_buff) { - return 0; - } - _packet_size = liberio_buf_get_len(_buff, 0); - _data = liberio_buf_get_mem(_buff, 0); - return _packet_size; - } - - UHD_FORCE_INLINE void release() - { - assert(_buff); - liberio_buf_set_payload(_buff, 0, _packet_size); - liberio_chan_buf_enqueue(_chan, _buff); - _buff = nullptr; - _data = nullptr; - } - -private: - struct liberio_buf* _buff = nullptr; - struct liberio_chan* _chan; -}; - -class liberio_adapter_info : public adapter_info -{ -public: - liberio_adapter_info() = default; - ~liberio_adapter_info() = default; - - std::string to_string() - { - // Currently, there is only ever one liberio adapter - // If that changes, fix this! - return std::string("Liberio"); - } - - bool operator==(const liberio_adapter_info& /*rhs*/) const - { - // Currently, there is only ever one liberio adapter - // If that changes, fix this! - return true; - } -}; - -/*! - * A zero copy transport interface to the liberio DMA library. - */ -class liberio_link : public recv_link_base<liberio_link>, - public send_link_base<liberio_link> -{ -public: - using sptr = std::shared_ptr<liberio_link>; - - liberio_link(const std::string& tx_path, - const std::string& rx_path, - const link_params_t& params); - - ~liberio_link(); - - /*! - * Make a new liberio link. - * - * \param tx_path a path string to the TX DMA device - * \param rx_path a path string to the RX DMA device - * \param params Values for frame sizes, num frames, and buffer sizes - * \return a shared_ptr to a new liberio link - */ - static sptr make(const std::string& tx_path, - const std::string& rx_path, - const link_params_t& params); - - /*! - * Get the physical adapter ID used for this link - */ - adapter_id_t get_send_adapter_id() const - { - return _adapter_id; - } - - /*! - * Get the physical adapter ID used for this link - */ - adapter_id_t get_recv_adapter_id() const - { - return _adapter_id; - } - -private: - using recv_link_base_t = recv_link_base<liberio_link>; - using send_link_base_t = send_link_base<liberio_link>; - - // Friend declarations to allow base classes to call private methods - friend recv_link_base_t; - friend send_link_base_t; - - // Methods called by recv_link_base - size_t get_recv_buff_derived(frame_buff& buff, int32_t timeout_ms) - { - auto& buffer = static_cast<liberio_frame_buff&>(buff); - return buffer.get(timeout_ms); - } - - void release_recv_buff_derived(frame_buff& buff) - { - auto& buffer = static_cast<liberio_frame_buff&>(buff); - buffer.release(); - } - - bool get_send_buff_derived(frame_buff& buff, int32_t timeout_ms) - { - auto& buffer = static_cast<liberio_frame_buff&>(buff); - return buffer.get(timeout_ms); - } - - void release_send_buff_derived(frame_buff& buff) - { - auto& buffer = static_cast<liberio_frame_buff&>(buff); - buffer.release(); - } - - struct liberio_chan* _tx_chan; - struct liberio_chan* _rx_chan; - std::vector<liberio_frame_buff> _recv_buffs; - std::vector<liberio_frame_buff> _send_buffs; - adapter_id_t _adapter_id; -}; - -}} // namespace uhd::transport diff --git a/host/lib/transport/CMakeLists.txt b/host/lib/transport/CMakeLists.txt index 2b1378978..3c60414e0 100644 --- a/host/lib/transport/CMakeLists.txt +++ b/host/lib/transport/CMakeLists.txt @@ -133,13 +133,6 @@ if(ENABLE_X300) ) endif(ENABLE_X300) -if(ENABLE_LIBERIO) - include_directories(${LIBERIO_INCLUDE_DIRS}) - LIBUHD_APPEND_LIBS(${LIBERIO_LIBRARIES}) - LIBUHD_APPEND_SOURCES( - ${CMAKE_CURRENT_SOURCE_DIR}/liberio_link.cpp - ) -endif(ENABLE_LIBERIO) if(ENABLE_DPDK) INCLUDE_SUBDIRECTORY(uhd-dpdk) diff --git a/host/lib/transport/liberio_link.cpp b/host/lib/transport/liberio_link.cpp deleted file mode 100644 index ec8abbca8..000000000 --- a/host/lib/transport/liberio_link.cpp +++ /dev/null @@ -1,154 +0,0 @@ -// -// Copyright 2019 Ettus Research, a National Instruments brand -// -// SPDX-License-Identifier: GPL-3.0-or-later -// - -#include <uhd/config.hpp> -#include <uhd/utils/log.hpp> -#include <uhd/utils/static.hpp> -#include <uhdlib/transport/adapter.hpp> -#include <uhdlib/transport/liberio_link.hpp> -#include <sys/syslog.h> -#include <memory> - -namespace uhd { namespace transport { - -using liberio_ctx_sptr = std::shared_ptr<liberio_ctx>; - -static const uint64_t USEC = 1000000; - -static void liberio_log_cb(int severity, const char* msg, void*) -{ - switch (severity) { - case LOG_WARNING: - UHD_LOG_WARNING("LIBERIO", msg); - return; - case LOG_NOTICE: - case LOG_INFO: - UHD_LOG_INFO("LIBERIO", msg); - return; - default: - UHD_LOG_INFO("LIBERIO", msg); - }; -} - -class liberio_context_holder -{ -public: - UHD_SINGLETON_FCN(liberio_context_holder, get); - - inline struct liberio_chan* alloc_tx_chan(const std::string& path) - { - return liberio_ctx_alloc_chan(_ctx, path.c_str(), TX, USRP_MEMORY_MMAP); - } - - inline struct liberio_chan* alloc_rx_chan(const std::string& path) - { - return liberio_ctx_alloc_chan(_ctx, path.c_str(), RX, USRP_MEMORY_MMAP); - } - -private: - liberio_context_holder(void) - { - _ctx = liberio_ctx_new(); - liberio_ctx_register_logger(_ctx, &liberio_log_cb, nullptr); - } - - ~liberio_context_holder(void) - { - liberio_ctx_put(_ctx); - } - - liberio_ctx* _ctx; -}; - -liberio_link::liberio_link( - const std::string& tx_path, const std::string& rx_path, const link_params_t& params) - : recv_link_base_t(params.num_recv_frames, params.recv_frame_size) - , send_link_base_t(params.num_send_frames, params.send_frame_size) -{ - auto& ctx_holder = liberio_context_holder::get(); - - /* Allocate TX channel (begins with refcount of 1) - */ - _tx_chan = ctx_holder.alloc_tx_chan(tx_path); - UHD_ASSERT_THROW(_tx_chan); - - /* set the size, allocate */ - UHD_ASSERT_THROW(!liberio_chan_set_fixed_size(_tx_chan, 0, params.send_frame_size)); - UHD_ASSERT_THROW(!liberio_chan_request_buffers(_tx_chan, params.num_send_frames)); - - /* TODO: Check params in factory and adjust them there instead of throwing exception - * here? */ - UHD_ASSERT_THROW(params.num_send_frames == liberio_chan_get_num_bufs(_tx_chan)); - for (size_t i = 0; i < params.num_send_frames; i++) { - _send_buffs.push_back(liberio_frame_buff(_tx_chan)); - } - - /* Allocate RX channel (begins with refcount of 1) - */ - _rx_chan = ctx_holder.alloc_rx_chan(rx_path); - UHD_ASSERT_THROW(_rx_chan); - - /* set the size, allocate */ - UHD_ASSERT_THROW(!liberio_chan_set_fixed_size(_rx_chan, 0, params.recv_frame_size)); - UHD_ASSERT_THROW(!liberio_chan_request_buffers(_rx_chan, params.num_recv_frames)); - /* TODO: Check params in factory and adjust them there instead of throwing exception - * here? */ - UHD_ASSERT_THROW(params.num_recv_frames == liberio_chan_get_num_bufs(_rx_chan)); - - for (size_t i = 0; i < params.num_recv_frames; i++) { - _recv_buffs.push_back(liberio_frame_buff(_rx_chan)); - } - UHD_ASSERT_THROW(!liberio_chan_enqueue_all(_rx_chan)); - - /* Start streaming on the devices */ - liberio_chan_start_streaming(_rx_chan); - liberio_chan_start_streaming(_tx_chan); - - /* Finally, preload the buffer pools in parent class */ - for (auto& buff : _send_buffs) { - send_link_base_t::preload_free_buff(&buff); - } - for (auto& buff : _recv_buffs) { - recv_link_base_t::preload_free_buff(&buff); - } - - auto info = liberio_adapter_info(); - auto& adap_ctx = adapter_ctx::get(); - _adapter_id = adap_ctx.register_adapter(info); - - UHD_LOGGER_TRACE("LIBERIO") - << boost::format("Created liberio link (tx:%s, rx:%s)") % tx_path % rx_path; - UHD_LOGGER_TRACE("LIBERIO") - << boost::format("num_recv_frames=%d, recv_frame_size=%d, num_send_frames=%d, " - "send_frame_size=%d") - % params.num_recv_frames % params.recv_frame_size % params.num_send_frames - % params.send_frame_size; -} - -liberio_link::~liberio_link() -{ - /* stop the channel, free the buffers */ - liberio_chan_stop_streaming(_tx_chan); - liberio_chan_request_buffers(_tx_chan, 0); - liberio_chan_put(_tx_chan); - - liberio_chan_stop_streaming(_rx_chan); - liberio_chan_request_buffers(_rx_chan, 0); - liberio_chan_put(_rx_chan); -} - -liberio_link::sptr liberio_link::make( - const std::string& tx_path, const std::string& rx_path, const link_params_t& params) -{ - UHD_ASSERT_THROW(params.recv_frame_size > 0); - UHD_ASSERT_THROW(params.send_frame_size > 0); - UHD_ASSERT_THROW(params.num_send_frames > 0); - UHD_ASSERT_THROW(params.num_recv_frames > 0); - - return std::make_shared<liberio_link>(tx_path, rx_path, params); -} - -}} // namespace uhd::transport diff --git a/host/lib/usrp/mpmd/mpmd_link_if_mgr.hpp b/host/lib/usrp/mpmd/mpmd_link_if_mgr.hpp index 4bf893dd4..8f364c10f 100644 --- a/host/lib/usrp/mpmd/mpmd_link_if_mgr.hpp +++ b/host/lib/usrp/mpmd/mpmd_link_if_mgr.hpp @@ -75,7 +75,7 @@ public: * from mb_args in the \p xport_info. If yes, it will use that for * connections. * - * \param xport_type The type of xport ("udp", "liberio", ...) + * \param xport_type The type of xport ("udp") * \param xport_info The available information on this transport. For * example, if the xport_type is "udp", then this would * contain the available IP addresses. |