// // Copyright 2011 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_LIBUHD_USRP_WB_IFACE_HPP #define INCLUDED_LIBUHD_USRP_WB_IFACE_HPP #include #include #include class wb_iface{ public: typedef boost::shared_ptr sptr; typedef boost::uint32_t wb_addr_type; /*! * Write a register (32 bits) * \param addr the address * \param data the 32bit data */ virtual void poke32(wb_addr_type addr, boost::uint32_t data) = 0; /*! * Read a register (32 bits) * \param addr the address * \return the 32bit data */ virtual boost::uint32_t peek32(wb_addr_type addr) = 0; /*! * Write a register (16 bits) * \param addr the address * \param data the 16bit data */ virtual void poke16(wb_addr_type addr, boost::uint16_t data) = 0; /*! * Read a register (16 bits) * \param addr the address * \return the 16bit data */ virtual boost::uint16_t peek16(wb_addr_type addr) = 0; }; #endif /* INCLUDED_LIBUHD_USRP_WB_IFACE_HPP */