// // Copyright 2013-2014 Ettus Research LLC // Copyright 2018 Ettus Research, a National Instruments Company // // SPDX-License-Identifier: GPL-3.0-or-later // #ifndef INCLUDED_E300_FIFO_CONFIG_HPP #define INCLUDED_E300_FIFO_CONFIG_HPP #include #include #include #include struct e300_fifo_config_t { size_t ctrl_length; size_t buff_length; size_t phys_addr; }; e300_fifo_config_t e300_read_sysfs(void); std::string e300_get_sysfs_attr(const std::string &node, const std::string &attr); struct e300_fifo_interface : boost::enable_shared_from_this { typedef boost::shared_ptr sptr; static sptr make(const e300_fifo_config_t &config); virtual uhd::transport::zero_copy_if::sptr make_recv_xport( const size_t which_stream, const uhd::transport::zero_copy_xport_params ¶ms) = 0; virtual uhd::transport::zero_copy_if::sptr make_send_xport( const size_t which_stream, const uhd::transport::zero_copy_xport_params &parms) = 0; virtual size_t get_global_regs_base(void) const = 0; }; #endif /* INCLUDED_E300_FIFO_CONFIG_HPP */