//
// Copyright 2013-2014 Ettus Research LLC
//
// This program is free software: you can redistribute it and/or modify
// it under the terms of the GNU General Public License as published by
// the Free Software Foundation, either version 3 of the License, or
// (at your option) any later version.
//
// This program is distributed in the hope that it will be useful,
// but WITHOUT ANY WARRANTY; without even the implied warranty of
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
// GNU General Public License for more details.
//
// You should have received a copy of the GNU General Public License
// along with this program. If not, see .
//
#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 */